Skalowanie grafiki SVG za pomocą CSS
Opublikowany: 2023-02-03Jeśli chodzi o tworzenie grafiki wektorowej do Internetu, tak naprawdę jest tylko jeden format, o którym musisz wiedzieć: SVG. I chociaż możliwe jest tworzenie prostych grafik SVG za pomocą kodu, znacznie łatwiej jest z nimi pracować za pomocą CSS. W tym artykule przyjrzymy się, jak skalować grafikę SVG za pomocą CSS. Omówimy również niektóre zalety korzystania z SVG w porównaniu z innymi formatami, takimi jak PNG lub JPEG.
Wykorzystanie grafiki wektorowej (SVG) do skalowania. Amelia Bellamy-Royds dzieli się wspaniałym przewodnikiem po skalowaniu SVG. Pomimo faktu, że skalowanie grafiki rastrowej jest trudniejsze, ma potencjał, aby otworzyć nowe możliwości. Początkującym może być trudno zrozumieć, jak sprawić, by zachowywał się tak, jak tego chcą. Obrazy Anaster są wyraźnie zdefiniowane przez ich współczynnik proporcji, czyli stosunek szerokości do wysokości w tekście. Jeśli wymusisz, aby obraz rastrowy był mniejszy niż jego wewnętrzna wysokość i szerokość, zostanie on zniekształcony; jeśli jednak zmusisz go do powiększenia, zostanie zniekształcony. wbudowane pliki SVG będą rysowane w rozmiarze określonym w kodzie, niezależnie od rozmiaru płótna określonego w kodzie.
ViewBox, ostatni element, odpowiada za projektowanie grafiki wektorowej, którą można skalować. Element viewBox jest komponentem elementu >svg>. Wartość to lista czterech liczb oddzielonych spacjami lub przecinkami, z których każda reprezentuje inny aspekt wartości. x i y określają układ współrzędnych lewego górnego rogu rzutni. Liczba pikseli/współrzędnych do przeskalowania nazywana jest wysokością. W przypadku określenia wymiarów, które nie są zgodne ze współczynnikiem proporcji, obraz nie zostanie rozciągnięty ani zniekształcony. Możliwe jest wyrównanie innych typów obrazów za pomocą nowej właściwości CSS dopasowanej do obiektu.
Możesz także ustawić ustawienie keepRatioAspect=”none”, aby przeskalować obraz do tego samego rozmiaru, co obraz rastrowy. Możesz określić szerokość i wysokość obrazu za pomocą obrazów rastrowych, a także możesz dopasować inną skalę do obrazu. W jaki sposób sva generuje dane z grafiką wektorową? Z wiekiem staje się to bardziej skomplikowane. Jeśli chcesz automatycznie zmienić rozmiar obrazu w pliku *.img, powinieneś pomyśleć o użyciu *. Możesz zmienić proporcje elementu, dostosowując jego wysokość i margines za pomocą różnych właściwości CSS. Inne przeglądarki automatycznie ustawią domyślny rozmiar obrazu 300*150 dla obrazów z viewBoxes bez określania zachowania.
Możliwe jest skalowanie obrazu, aby zmieścił się w oknie viewBox przy użyciu najnowszych przeglądarek Blink/Firefox. Te przeglądarki będą używać tych samych domyślnych rozmiarów niezależnie od tego, czy określisz wysokość czy szerokość. Element kontenera, na przykład, jest najprostszą metodą dla wbudowanych SVG, jak również innych zastąpionych elementów. Oficjalna wysokość będzie wynosić zero w grafice, która jest wbudowana i svg. Gdy wartość keepRatioAspect jest ustawiona na true, grafika zostanie zredukowana do zera. Zamiast rozciągać grafikę, powinieneś podkreślić, że rozciąga się ona aż do obszaru wypełnienia, który starannie odłożyłeś na bok, aby uzyskać odpowiedni współczynnik proporcji. Atrybuty viewBox i maintenanceRatio są niezwykle elastyczne. zagnieżdżonych elementów <svg>, z których każdy ma własne atrybuty skalowania, można użyć do oddzielenia części skali graficznej. Ta metoda umożliwia utworzenie grafiki nagłówka, która jest zarówno długa, jak i wystarczająco płaska, aby wypełnić ekran panoramiczny bez nadmiernej wysokości.
Czy SVG można skalować za pomocą CSS?
Jeśli chcesz, możesz zmienić atrybuty wysokości i szerokości pliku *svg* w pliku *svg*. Możesz użyć tej reguły, aby anulować wymiary i współczynniki proporcji określone w kodzie, a także ustawić domyślną wysokość wbudowanej części svg.
Ponieważ właściwości CSS width i height są ustawione na false, nie można skalować obrazów SVG . Ponieważ ikony mają stałą wysokość w swoim kształcie, zwiększenie szerokości img nie spowoduje, że będą wyższe, jeśli wysokość jest ograniczona. Właściwość CSS transform umożliwia obracanie, skalowanie, pochylanie i translację elementów. ViewBox=0 0 Nie jestem pewien, czy [w] [h] jest poprawne dla niektórych plików SVG, mam na myśli podwójne zero. Pierwsze dwie cyfry określają położenie ikony w ramce (czy jest to pełna szerokość lub pełna wysokość) oraz czy ikona jest kwadratowa (ponieważ kwadratowe ikony działają tylko wtedy, gdy są pełnej szerokości lub pełnej wysokości).
Możesz to zrobić na różne sposoby. Najprostszym sposobem na utworzenie nowego pliku SVG z wymiarami jest wyeksportowanie go jako obrazu. Może być konieczne utworzenie określonych wymiarów, co może być czasochłonne i może nie być akceptowane przez wszystkie przeglądarki. Alternatywnie możesz użyć Responsive Generator SVG. Narzędzie automatycznie tworzy responsywne pliki SVG, w zależności od Twoich wymiarów i określonych przez Ciebie zapytań o media, niezależnie od Twoich zapytań o media. Ta opcja jest dobra, jeśli wiesz, co robisz, ale nie zawsze jest łatwa do wdrożenia. Jednak najlepszą opcją jest użycie atrybutów zawartych w programie Illustrator CC, takich jak szerokość i wysokość. Jeśli określisz inny rozmiar, Twój plik SVG będzie zawsze responsywny we wszystkich przeglądarkach. Ten krok nie musi być wykonywany na komputerze, jeśli się spieszysz lub masz dużą liczbę plików SVG. Możesz od razu rozpocząć eksportowanie responsywnych plików SVG z programu Illustrator CC.
Jak zmienić szerokość i wysokość obrazu Svg?
Jak mogę zmienić rozmiar obrazu za pomocą SVG? Zanim będzie można wybrać plik do zapisania jako SVG, należy najpierw dodać plik obrazu SVG. Przeciągnij lub upuść plik obrazu do białego obszaru i wybierz plik. W tym kroku musisz dostosować ustawienia zmiany rozmiaru, a następnie kliknąć przycisk Zmień rozmiar. Dopiero po zakończeniu procesu będziesz mógł pobrać swoje wyniki.
Przekształcanie obrazu w dzieło sztuki to świetna zabawa. Nie było łatwo, ale było warto. Istnieją dwie opcje zmiany rozmiaru obrazu SVG. Jeśli chcesz zmienić rozmiar lub wysokość pliku XML, kliknij etykietę XML. Możesz uruchomić plik za pomocą edytora tekstu. Powinieneś zobaczyć linie kodu poniżej. CSS to inne rozwiązanie. Jednak określenie „szerokości” i „wysokości” nie zmienia sytuacji.
Czy SVG można rozciągnąć?
Gdy tworzony jest obraz SVG o stałej długości , jest on przetwarzany w taki sam sposób, jak obraz rastrowy o tym samym rozmiarze. Jeśli używasz CSS do rozciągania pliku SVG do innego współczynnika proporcji, upewnij się, że w pliku .svg uwzględniono parametr keepRatio=”none”.
Znaczenie skalowalnej grafiki wektorowej
Aby tworzyć zarówno małe, jak i duże grafiki, możesz użyć formatu grafiki wektorowej SVG . Innymi słowy, atrybuty wysokości i szerokości elementu SVG mogą nie określać pikseli; zamiast tego można użyć dowolnej z kilku jednostek. W ten sposób jakość SVG można zachować bez utraty jakiegokolwiek aspektu. Jeśli chodzi o rozmiar obrazu i typ wyświetlania, różnice między nimi są nieistotne w przypadku plików SVG.
Czy obrazy Svg można skalować?
Tak, obrazy SVG można skalować. Dzieje się tak, ponieważ obrazy SVG są obrazami wektorowymi, co oznacza, że składają się one z szeregu linii i krzywych, a nie z pikseli. Oznacza to, że można je skalować w górę lub w dół bez utraty jakości.
Obrazy można przycinać i skalować za pomocą oprogramowania Cropping. Podczas korzystania z dokumentów SVG jest to proste. Ten fragment CSS zostanie zastąpiony fragmentem SVG. W tym artykule użyjemy atrybutów viewBox i AspectRatio do przycinania, skalowania i pozycjonowania obrazów. Nie będziesz mieć problemów z używaniem tych atrybutów, więc nie bój się ich wypróbować. Chcesz, aby użytkownik mógł przesyłać obraz o dowolnym rozmiarze lub współczynniku proporcji. Przycinanie i skalowanie obrazów w dopasowanym pudełku jest łatwiejsze dzięki właściwościom dopasowanie do obiektu i położenie obiektu.
Wszystkie najnowsze przeglądarki, w tym Microsoft Edge 16 i Opera Mini, obsługują tę funkcję, chociaż ta ostatnia wymaga przedrostka -o-. PreserveAspectRatio może służyć do modyfikowania pozycji, rozmiaru i skali viewBox, podobnie jak dopasowanie obiektu i położenie obiektu. Załóżmy na przykład, że mamy kwadrat i widok, które mają różne proporcje (2:1). Z drugiej strony, skala służy do zachowania proporcji viewBox przy jednoczesnym zmniejszeniu jego rozmiaru, a część zawartości jest usuwana (stąd efekt krojenia). Zawiera 19 wartości, w tym żadną, która określa, ile miejsca zapewnia każdy element. Domyślnym zachowaniem przeglądarki jest ustawienie zarówno obrazu, jak i elementu viewBox tak, aby były całkowicie widoczne z rzutni podczas zastępowania elementu obrazem i dopasowywania proporcji tego obrazu do elementu viewBox. Zmiana wartości zachowaniaAspectRatio może pomóc określić, który aspekt obrazu zmienia się w zależności od jego położenia i skali w pliku SVG.
CSS dopasowywanie obiektów i pozycjonowanie obiektów mogą być używane do przycinania i skalowania obrazów . Możesz używać tych właściwości tylko w najnowszej wersji ME Edge, a także w dowolnej nowoczesnej przeglądarce. Dodanie pliku >svg do obrazu umożliwia obsługę przeglądarki Internet Explorer 9.
Grafika, która wymaga skalowania lub korekty bez utraty wyrazistości, jest idealna do używania SVG. Jest również stosunkowo prosty w użyciu, dzięki czemu nadaje się do mniejszych ekranów, co ma niewielki wpływ na czas ładowania. Ponadto grafika jest animowana, co nadaje jej bardziej dynamiczny charakter.
Transformacja Svg=skala
Transformacja skali umożliwia zmianę rozmiaru elementów SVG . Możesz zwiększyć lub zmniejszyć rozmiar swoich elementów, używając liczby dodatniej lub ujemnej. Transformacja skali przyjmuje dwa parametry: współrzędną x i współrzędną y.
Funkcji przekształcania można używać do manipulowania elementami SVG w taki sam sposób, w jaki przekształca się HTML. Niektóre rzeczy działają inaczej na elementach SVG niż na elementach HTML. Nie możemy na przykład tłumaczyć funkcji przy użyciu wartości % (wartości % nie będą również działać w przypadku przekształceń CSS), ani nie możemy obracać ani pochylać kątów za pomocą stopni. Punkt, w którym elementy HTML tworzą swoje współrzędne, stanowi 50% współrzędnych elementu. W przypadku SVG na płótnie znajduje się punkt 0 0. Gdy nastąpi obrót, skalowanie lub przekształcenie pochylenia, wyniki będą różne dla różnych źródeł. Gdy transformacja tłumacząca zostanie zastosowana do jednego z naszych elementów, transformacja przesunie się wraz z nim.
Dla elementów 2D dostępne są trzy funkcje translacji: translateX(tx), translateY(ty) i translate(tx[, ty). W każdym przypadku kierunki x i y są używane zgodnie ze współrzędnymi systemowymi elementu. Trzecia funkcja translacji przesuwa element o tx wzdłuż osi x i y. Obrót elementów i ich układów współrzędnych wiąże elementy z ich ustalonym początkiem. Wartość kąta można wyrazić w stopniach (stopniach), radianach (radianach), obrotach (obrotach) lub gradach (stopniach). Moglibyśmy również użyć wartości calc() (na przykład coś w rodzaju 25turn – 30deg), ale w tej chwili działa to tylko w Chrome 38/35. Funkcję obracania można wykonać za pomocą wartości kąta calc() w przeglądarce Firefox 59 i nowszych.
Jeśli ustawimy tę wartość w naszym CSS, możemy użyć parametrów x i y, aby naśladować ich użycie. Podczas korzystania z atrybutu transformacji SVG element i jego współrzędne systemowe są po prostu obracane wokół punktu określonego przez drugi i trzeci argument funkcjirotate(). Aby odwrócić obrót w tym przykładzie, obróć (-45 140 105), a nie obróć (-45). Po prostu określamy inny stały punkt dla każdego obrotu elementu o 90 stopni w prawym dolnym rogu io 90 stopni w prawym górnym rogu. Jak mogę uzyskać ten sam efekt za pomocą transformacji CSS? W pierwszym obrocie łatwo jest ustawić początek transformacji na prawy dolny róg, ale co z drugim obrotem? Jeśli połączymy go ponownie po tym, jak został już obrócony o 90 stopni, po prostu się powtórzy.
Transformacja skali jest określana przez położenie początku układu we współrzędnych. Współczynnik skalowania (-1, 1) powiększa element w miarę jego kurczenia się, podczas gdy współczynnik skalowania poza zakresem (-1, 1) powiększa go w miarę kurczenia się. Skalowanie kierunkowe definiuje się jako różnicę współczynników skalowania między 1 a 2. W rezultacie możemy zdefiniować źródła transformacji i łańcuchy transformacji w obu przypadkach. Błądzenie zniekształca element w taki sam sposób, jak translacja i obrót, przekształcając kwadraty w koła, a koła w równoległoboki. Kąt skośny jest definiowany jako kąt między pozycją końcową i początkową osi po zastosowaniu transformacji. W przedziale [0*, 90*] w wyniku dodatniego kąta skosu dodawana jest wartość tego samego znaku co niezmieniona współrzędna w wartości początkowej.
Gdy wykonujemy skos wzdłuż osi x, współrzędna x pozostaje stała dla dowolnego punktu naszego elementu, natomiast współrzędna y zmienia się o wartość d w zależności od kąta skosu. Gdy element jest pochylony, wynik zależy od jego położenia w punkcie początkowym jego układu współrzędnych. Dwie przekształcenia skośne wzdłuż tej samej osi dają różne wyniki w zależności od pochodzenia przekształcenia. Przypadek HTML (po lewej) i przypadek SVG (po prawej) pokazano na powyższym rysunku. Podczas gdy kąty w obu przypadkach wynoszą 60 stopni, wyróżnia je znak współrzędnej y w prawym górnym rogu. Kąt, który jest wartością jednostkową we właściwości CSS transform, jest używany do konwersji wartości na transformację. Stopnie (stopnie), radiany (rady), obroty (obroty) i gradiany (grady) mogą być wyrażone jako te, aw niektórych przypadkach mogą być nawet połączone z calc().
Transformacji można użyć do obracania, skalowania i pochylania elementu, tak jak element HTML. Na przykład możemy uzyskać wynik, gdy użyjemy łańcuchowych transformacji jako wartości atrybutu SVG w IE. Jest jednak brzydki. Dlaczego nie ma bardziej usprawnionego sposobu na zrobienie tego? W tym kodzie mamy trzy wielokątne kształty zwane gwiazdami. W poniższym demo możesz zobaczyć, jak są one ustawione względem początku płótna (0 0). W kodzie lub najeżdżając kursorem na pary x, y, możesz sprawdzić, które punkty odpowiadają którym parom. Innymi słowy, chcemy, aby każda gwiazda obracała się w inny sposób – powiedzmy, że mają losowy kąt, a ich indeks ma określony kąt.