Svg для сайта: 5,100+ бесплатных иконок в формате SVG и в виде иконочных шрифтов. Потрясающие иконки для любого проекта

Содержание

Практическое руководство о SVG в вебе

Подготовка SVG для использования в вебе это очень простой процесс, не сложнее экспорта JPEG или PNG. Используйте любой привычный для вас графический редактор (Illustrator, Sketch, Inkscape [бесплатен], и тому подобное [или даже Photoshop, если вы используете слои с формами]) с тем размером изображения, который вы планируете использовать. Обычно я работаю в Иллюстраторе, поэтому я объясню некоторые способы подготовки файлов в этой программе, но вообще они применимы и для любой другой программы. Вам, возможно, стоит перевести текст в кривые, поскольку шрифт, скорее всего, будет неправильно отображаться, если, конечно, вы не планируете стилизовать их с помощью веб-шрифта, используемого на странице (что возможно!). Не стоит также превращать все объекты в единые формы, особенно если у вас есть обводка, которой необходимо будет управлять на странице, тем более преобразование объектов зачастую не уменьшает размер файла. Любые имена, присвоенные группам или слоям, будут добавлены к SVG как ID элемента. Это довольно удобно для стилизации, но немного увеличит общий размер файла.

Перед тем как сделать экспорт, необходимо проверить, все ли изображения находятся в целочисленной пиксельной сетке (то есть, например не 23.3px × 86.8px). В противном случае скорее всего изображению не будет хватать чёткости и часть изображения обрежется. В Иллюстраторе это можно сделать следующим образом: Object > Artboards > Fit to Artwork Bounds. Затем жмём save as и выбираем SVG, и оставляем настройки по умолчанию. Здесь можно сделать небольшую оптимизацию, но на самом деле не стоит, так как далее мы будем применять разные улучшающие приёмы, поэтому сейчас мы не будем тратить впустую время на эти настройки.

Приёмы для уменьшения размеров файла.

(Смотрите ресурсы по оптимизации)

Существует множество статей по оптимизации SVG, предлагающих кладезь знаний в этой теме, но я хочу поделиться парой приёмов, которые считаю наиболее эффективными и полезными. Они не требуют много усилий и могут легко вписаться в рабочий процесс.

Чтобы добиться наименьшего размера SVG, логично будет удалить из него всё лишнее. Наиболее известная и полезная программа (по крайней мере я так думаю) для обработки SVG это SVGO. Она удаляет весь не нужный код. Но! Будьте внимательны используя эту программу, если планируете управлять SVG при помощи CSS / JS, так как она может слишком сильно почистить код, что затруднит дальнейшие изменения. Удобство SVGO ещё и в том, что её можно включить в процесс автоматической сборки проекта, но можно также использовать GUI если хочется.

Разбираясь подробнее с правильным удалением всего ненужного, мы можем сделать ещё кое-что в графическом редакторе. Сперва нужно убедиться, что используется настолько мало контуров/форм, насколько это возможно, так же как и точек на этих контурах. Можно объединять и упрощать всё, что поддаётся упрощению, и удалить все ненужные точки. В Иллюстраторе есть плагин VectorScribe с инструментом

Smart Remove Brush Tool, который поможет удалить точки и при этом оставить общую форму той же.

Предварительная оптимизация

Smart Remove Brush Tool удалил точки

Дальше будем увеличивать изображение. В Иллюстраторе удобно включить просмотр с пиксельной сеткой View > Pixel Preview и проверить, как располагаются контуры. Чтобы разместить контуры по сетке, потребуется немного времени, но эти усилия окупятся и позволят добиться более чёткого рендеринга (лучше обратить на это внимание заранее).

Точки вне сетки

Выравнивание по сетке

Если есть два и более объекта для выравнивания, то стоит удалить все ненужные перекрытия. Иногда даже если контуры тщательно выровнены, может быть видна тонкая белая линия. Чтобы предотвратить такое, можно немного наложить объекты друг на друга в местах перекрытия. Важно: в SVG z-index имеет определённый порядок, который зависит от объекта, находящегося снизу, поэтому стоит поместить верхний объект в нижнюю часть файла в коде.

И, наконец, последнее, но немаловажное, то, о чём обычно забывают — это активировать gzip сжатие SVG на вашем сайте в .htaccess файле.

AddType image/svg+xml svg svgz
<IfModule mod_deflate.c>
  <IfModule mod_filter.c>
      AddOutputFilterByType DEFLATE "image/svg+xml" \
                                    "text/css" \
                                    "text/html" \
                                    "text/javascript"
                                    ... etc
  </IfModule>
</IfModule>

В качестве примера того, насколько эффективна эта техника, я воспользуюсь оригинальным логотипом Breaking Borders и оптимизирую его таким образом: увеличиваю размер до того, каким он должен быть; приведу в порядок контуры; удалю максимально возможное количество точек; передвину точки на целочисленные пиксели; сдвину все области перекрытий и отправлю это всё в SVGO.

Оригинал: 1,413b
После оптимизации: 409b

В итоге размер файла стал меньше на ~71% (и на ~83% при сжатии)

Дополнение: Rob Sterlini заметил, поскольку «b» повторяется, можно использовать элемент <use>, для повторения, что ещё больше уменьшит размер файла — и был абсолютно прав.

После оптимизации с использованием <use>: 311b

Размер файла стал меньше на ~78%

Если применить эту технику ко всем файлам SVG, это значительно улучшит ваш сайт.

Описание и примеры стандартных функций SVG

Доминирующей причиной появления этого блога стало незаслуженное забвение на целых десять лет языка разметки масштабируемой векторной графики – SVG (Scalable Vector Graphics), входящего в подмножество расширяемого языка разметки XML.
Стандарт SVG 1.0 был принят в качестве спецификации Консорциумом Всемирной паутины (W3C) в сентябре 2001 г. Стандарт SVG 1.1 и его версии SVG mobile profiles (SVG Basic and SVG Tiny) были приняты консорциумом в качестве рекомендации в январе 2003 г.
Сейчас ведутся работы по созданию стандарта SVG 2.0

Основные преимущества формата SVG.

Я не буду долго распространяться о преимуществах векторной графики перед растровой в вебдизайне, замечу лишь, что, однажды созданный, файл в формате SVG одинаково хорошо выглядит без потери качества и на мобильном устройстве и на станционарном мониторе домашнего ПК.
Шапка данного сайта выполнена в формате SVG, попробуйте уменьшить окно браузера до минимальных размеров, картинка на “лету” будет также пропорционально уменьшаться.
SVG – это двухмерная графика и тем не менее это текстовый формат, который можно легко править в блокноте или просто рисовать в векторных редакторах: Incscape , Adobe illustrator, CorelDRAW

Бесконечное полотно документа svg.

Итак, как происходит формирование векторного изображения.
Документ формата SVG – это двухмерный объект, который может иметь бесконечные координаты, как в положительном, так и в отрицательном направлении по осям X и Y. Также документ SVG имеет две области просмотра:

viewport – системная область просмотра и viewBox – пользовательская область просмотра, положение которой относительно начала системных координат viewport, может задаваться собственной, пользовательской системой координат. Другими словами окно просмотра viewBox, может быть перемещёно в любое место документа SVG, при этом берется фрагмент изображения под ним, который после процесса согласования между viewBox и viewport, возвращается обратно в системную область просмотра viewport, которую видит пользователь. Используя это свойство можно организовать вертикальную или горизонтальную прокрутку изображения, меняя параметры координат viewBox.

При уменьшении размера пользовательского окна просмотра viewbox можно пропорционально увеличивать фрагмент изображения в системной области просмотра или уменьшать его при увеличении размера viewbox.
Таким образом реализуется эффект лупы. Более подробно эти процессы разобраны в статье: Трансформация изображений SVG при изменении параметров Viewbox.

 

Взаимодействие SVG, XML с HTML, CSS, Jscript

В SVG, как и в HTML можно добавлять ссылки на внешние ресурсы. Но если в HTML одна картинка может служить только для одной внешней ссылки, то в SVG документ можно добавлять сколько угодно внешних ссылок . Картинка кликабельна.
Внутрь HTML страницы легко встраивается код SVG документа или целиком подключается внешний SVG файл. Можно наоборот, внутри SVG файла разместить код HTML внутри тегов foreignObject. Получаются интересные эффекты: Внутри SVG файла находится работающий внешний HTML сайт. К SVG формату можно подключать внешние таблицы стилей CSS 2.0, что позволяет управлять сразу несколькими файлами *.svg. Также вполне допустимо подключение стилей внутри файла *.svg внутри тегов style или использовать внутренние стили непосредственно внутри командных строк фигур и путей.
SVG, как любой основанный на XML формат, позволяет использовать для его обработки таблицы трансформации (XSLT).

Преобразуя XML-данные в SVG с помощью простого XSL, можно получить графическое представление текстовых данных, например визуализировать графики, круговые диаграммы, гистограммы и т.д.

Анимация и интерактивность SVG.

Анимация в SVG осуществляется при помощи языка SMIL (Synchronized Multimedia Integration Language). Также поддерживаются скриптовые языки на основе спецификации ECMAScript — это встраиваемый расширяемый язык программирования.
То есть всё находится в одном месте, внутри документа SVG, поэтому нет необходимости для подключения внешних библиотек.
На каждую отдельную фигуру или на целое изображение можно установить обработчик событий (клик, наведение мышки, нажатие клавиши и т.д), таким образом, пользователь может управлять рисунком. Наведите курсор мышки на кнопку“Start” на примере слева.
По событию mouseover на этой кнопке начнется анимация по команде begin=”startButton.mouseover” – движение цветных шариков по криволинейному пути. Закончится анимация либо через заданные в коде 16 секунд, либо в любой момент по наведению курсора мышки на цветные радиокнопки “Stop”. При этом каждая радиокнопка управляет своим объектом совпадающим по цвету. На рисунке ниже анимация начинается и заканчивается при нажатии клавиши мышки на кнопки GO и STOP. В этом случае работает событие click. Команда на запуск анимации – begin=”gO.click” и соответственно остановка – end=”stop.click”

Следующий пример анимации – плавная отрисовка картинки с нуля до полного изображения.

Уже встроенные в SVG языки программирования позволяют реализовать довольно сложные сценарии анимации. Но, в дополнение к этому есть еще более мощные средства для реализации интерактивности графики и ее анимации – это внешние библиотеки сторонних разработчиков: D3.js, BonsaiJS, Svg.js, Snapsvg.js

Еще примеры анимации ⇛

Недостатки SVG формата

  • С увеличением количества мелких деталей в изображении, быстрее растёт размер файла SVG-данных. Предельный случай — когда изображение представляет собой белый шум. В этом случае SVG не только не даёт никаких преимуществ в размере файла, но даже имеет проигрыш по отношению к растровому формату. На практике, SVG становится невыгоден уже задолго до того, как изображение дойдёт до стадии белого шума.
  • Трудность использования в крупных картографических приложениях из-за того, что для правильного отображения маленькой части изображения документ необходимо прочитать целиком.
  • В настоящее время SVG формат применяется в Интернете сравнительно мало, из-за недостаточной кроссбраузерности. Лучше всего обстоят дела у Mozilla Firefox со встроенным просмотрщиком SVG, так как ее разработчики находятся в рабочей группе Консорциума Всемирной паутины (W3C) по разработке и внедрению стандарта SVG. Хуже всего дела по поддержке формата SVG у Microsoft, которая покинула группу 2003 г. Для Internet Explorer – необходим Adobe SVG Viewer (ASV). С 9 версии IE частично поддерживает функции SVG.
    Браузеры Apple Safari, Google Chrome намного лучше поддерживают SVG, но не полностью, так как SVG – это большая спецификация (вдвое больше HTML 4.01), именно поэтому разработчики браузеров внедряют функции постепенно, от версии к версии. Но абсолютно все разработчики современных браузеров заявляют, что за форматом SVG будущее в области графики вебдизайна.


 

 

UPD. Добавлен новый раздел онлайн генераторы SVG кода path.
следующая: Структура SVG документа ⇛

Оптимизация ресурсов SVG на примере

От автора: оптимизация SVG (масштабируемой векторной графики) для веб-проектов имеет два преимущества: уменьшение размера файла и упрощение работы с ним. Но много раз я открывала веб-проект и обнаруживала, что ресурсы SVG можно сделать значительно меньше с помощью простых оптимизаций. В этой статье я расскажу о своем процессе оптимизации ресурсов SVG. Это может помочь вам, если вы дизайнер или разработчик, не знакомый с работой с SVG в Веб.

Многие библиотеки иконок предоставляют ресурсы SVG, которые уже хорошо оптимизированы. Но если вы создаете собственную графику или она предоставлена другим дизайнером, вы можете сделать это с помощью нескольких шагов. В основном я использую для создания и редактирования SVG Adobe Illustrator. Вот довольно простая иконка, созданная в Illustrator:

Мы можем сохранить ее, перейдя «Файл»> «Сохранить как» и выбрав опцию «SVG». Однако, если мы посмотрим на код сохраненного SVG, то увидим, что он довольно раздутый. Код содержит много ненужных данных — группы, которые можно свернуть, пути, которые можно объединить, метаданные, созданные самой программой, и многое другое:

JavaScript. Быстрый старт

Изучите основы JavaScript на практическом примере по созданию веб-приложения

Узнать подробнее

<?xml version=»1.0″ encoding=»utf-8″?> <!— Generator: Adobe Illustrator 22.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) —> <svg version=»1.1″ xmlns=»//www.w3.org/2000/svg» xmlns:xlink=»//www.w3.org/1999/xlink» x=»0px» y=»0px» viewBox=»0 0 800 800″ enable-background=»new 0 0 800 800″ xml:space=»preserve» > <g> <path d=»M90,675.6L424,97.1l48.5,28l-334,578.5L90,675.6z» /> <path d=»M547.6,279.3h70.2l-10.1,88.2l80.7-37l21.8,66.7l-87.3,17.6l59.9,65.8l-56.4,40.7l-43.8-76.8l-43.8,76.8l-56.4-40.7 l59.9-65.8L455,397.2l21.8-66.7l80.7,37L547.6,279.3L547.6,279.3z» /> </g> </svg>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

<?xml version=»1.0″ encoding=»utf-8″?>

<!— Generator: Adobe Illustrator 22.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0)  —>

<svg

  version=»1.1″

  id=»Layer_1″

  xmlns=»//www.w3.org/2000/svg»

  xmlns:xlink=»//www.w3.org/1999/xlink»

  x=»0px»

  y=»0px»

  viewBox=»0 0 800 800″

  enable-background=»new 0 0 800 800″

  xml:space=»preserve»

>

  <g>

    <path d=»M90,675.6L424,97.1l48.5,28l-334,578.5L90,675.6z» />

    <path

      d=»M547.6,279.3h70.2l-10.1,88.2l80.7-37l21.8,66.7l-87.3,17.6l59.9,65.8l-56.4,40.7l-43.8-76.8l-43.8,76.8l-56.4-40.7

l59.9-65.8L455,397.2l21.8-66.7l80.7,37L547.6,279.3L547.6,279.3z»

    />

  </g>

</svg>

У каждой графической программы свой собственный способ сохранения SVG, но независимо от того, которую из них вы используете, код все равно может содержать много дополнительных данных, если их не оптимизировать. Давайте рассмотрим некоторые способы решения этой проблемы.

Запуск пакета

SVGO — это пакет NPM, который запускает процесс оптимизации SVG-ресурсов во время сборки, и это хорошая идея использовать что-то подобное в рабочем процессе. Но визуальный инструмент часто лучше удаляет лишние пути и группы и позволяет нам настраивать (и просматривать) параметры оптимизации в зависимости от того, какой результат мы хотим получить.

Быстрое решение с помощью SVGOMG

Один из способов быстро удалить большую часть этих ненужных данных — инструмент Джейка Арчибальда SVGOMG. Вы можете либо загрузить файл SVG, либо напрямую вставить код, и, в зависимости от выбранных параметров, SVG будет значительно уменьшен. Возможно, вам придется поэкспериментировать с различными опциями, чтобы получить желаемый результат, особенно если ваш SVG довольно сложный, но я обычно нахожу, что для простых иконок я могу включить большинство опций, и это не окажет негативного влияния на результат.

Пропустив код через SVGOMG, мы получим следующее:

<svg xmlns=»//www.w3.org/2000/svg» viewBox=»0 0 620.2 606.5″> <defs/> <path d=»M0 578.5L334 0l48.5 28-334 578.5-48.5-28zM457.6 182.2h70.2l-10.1 88.2 80.7-37 21.8 66.7-87.3 17.6 59.9 65.8-56.4 40.7-43.8-76.8-43.8 76.8-56.4-40.7 59.9-65.8-87.3-17.6 21.8-66.7 80.7 37-9.9-88.2z»/> </svg>

<svg xmlns=»//www.w3.org/2000/svg» viewBox=»0 0 620.2 606.5″>

  <defs/>

  <path d=»M0 578.5L334 0l48.5 28-334 578.5-48.5-28zM457.6 182.2h70.2l-10.1 88.2 80.7-37 21.8 66.7-87.3 17.6 59.9 65.8-56.4 40.7-43.8-76.8-43.8 76.8-56.4-40.7 59.9-65.8-87.3-17.6 21.8-66.7 80.7 37-9.9-88.2z»/>

</svg>

Это гораздо лучше, чем оставлять графику неоптимизированной, но она содержит посторонний элемент <defs/>. И если оригинальный SVG содержит группы, слои и эффекты, то существует предел того, насколько инструмент, наподобие SVGOMG, сможет его оптимизировать. Намного лучше, если мы вернемся к графической программе и внесем некоторые изменения, прежде чем пропускать ее через инструмент оптимизации.

Редактирование SVG

Если вы знаете, как писать SVG-код, то это поможет получить самый чистый и минимизированный результат. Посмотрите документацию MDN с руководством по рисованию контуров SVG и это видео от Хейдона Пикеринга, если вы хотите получить дополнительную информацию.

Но для подавляющего большинства из нас редактирование SVG возможно только с помощью визуального инструмента. Для этого примера я использую Adobe Illustrator, но другие инструменты, такие как Sketch, имеют схожие функции редактирования.

Сколько кода вы можете удалить, отредактировав SVG, зависит от его сложности и варианта использования. Следующие советы обычно относятся к иконкам и простой графике. Сложные иллюстрации часто не могут быть отредактированы до такой степени без влияния на конечный результат — и, в некоторых случаях, возможно, лучше использовать PNG или JPG.

Разверните группы

Первое, что я делаю при оптимизации SVG, это удаляю все скрытые слои и разворачиваю группы, где это возможно. Это удаляет все группы контуров в тегах <g> кода SVG. Возможно, вы захотите сохранить некоторые группы, если планируете стилизовать или анимировать их. Вы можете развернуть группу в Illustrator с помощью сочетания клавиш Shift+CMD+G.

Преобразование в контуры

Затем я конвертирую все штрихи в контуры, где это возможно (Рис 04). В Illustrator мы можем сделать это, используя Объект> Расширить. Могут быть некоторые исключения: если вы стилизуете или анимируете stroke-dasharray или stroke-dashoffset, вам нужно оставить их нетронутыми, а также, если вы хотите сохранить ширину обводки при масштабировании SVG.

Вы также можете использовать параметр «Развернуть» в Illustrator для преобразования областей изображения, например простых рисунков, в индивидуально выбираемые контуры. Для сложных или детализированных узоров, возможно, лучше этого не делать.

Преобразование текста в контуры

Иногда полезно преобразовать текст в контуры, если текст носит чисто декоративный характер, или содержимое будет передаваться другим способом, например с заголовком, текстом кнопки или aria-label. Несмотря на то, что использовать элемент SVG <text> полезно, это не всегда имеет смысл, особенно если вам нужно загрузить другой веб-шрифт для отображения текста SVG. Мы можем преобразовать текст в контуры в Illustrator, выбрав его и нажав «Текст»> «Преобразовать в контуры».

Объединение контуров

Теперь, когда все в нашем SVG — это контуры, мы можем объединить их, чтобы уменьшить их количество. Возьмем для примера иконку «поиск»: два пересекающихся контура могут быть объединены в один, что даст единый контур.

JavaScript. Быстрый старт

Изучите основы JavaScript на практическом примере по созданию веб-приложения

Узнать подробнее

Чтобы объединить контуры в Illustrator, мы выбираем их и используем параметр объединения в меню «Навигатор».

Исключением является сценарий, когда мы хотим стилизовать или анимировать контуры по отдельности — в этом случае их объединять не следует.

Удалите дополнительные контуры или группы

Когда контуры объединены, я выполняю последнюю проверку слоев и удаляю все пустые слои или дубликаты контуров, которые могли быть созданы в процессе.

Подгонка артборда

Когда я использую в HTML SVG-иконки, я не хочу, чтобы вокруг них оставалось дополнительное пространство, от которого я не могу избавиться. Это может произойти в случае, если SVG viewBox больше, чем содержимое. В Illustrator я выбираю «Объект»> «Артборды»> «Подогнать к границам графического объекта», чтобы размеры viewBox соответствовали графическому объекту.

Экспорт

Теперь мы готовы сохранить SVG. В Illustrator мы можем выбрать «Файл»> «Сохранить как» и выбрать в качестве формата SVG. В появившемся окне нам будет предложено несколько параметров SVG. Я обычно выбираю «Атрибуты представления», чтобы настроить параметры стиля.

SVG теперь готов к запуску через инструмент оптимизации. Для иконок я обычно в SVGOMG могу настроить большинство параметров. Вы заметите, что код стал намного чище! Но даже это не всегда удаляет все, что можно удалить. В приведенном ниже коде у меня все еще остается пустой элемент <defs>, поэтому стоит выполнить еще одну окончательную ручную очистку и удалить его в редакторе кода. Теперь SVG готов к использованию!

Использование SVG

SVG можно использовать в Интернете различными способами, в том числе:

В теге img

В свойстве CSS background-image

Встроенным в HTML

Спрайты

В частности, встроенные SVG-иконки обеспечивают наибольшую производительность и гибкость, и лучший способ их использования — создание спрайта. Если вы не хотите делать это вручную, доступны пакеты NPM, которые автоматически генерируют SVG-спрайты. Icomoon — это приложение, которое предлагает аналогичный сервис.

Затем, когда дело доходит до их использования, вместо вставки всего SVG, мы можем ссылаться на них с помощью элемента <use>:

<svg xmlns=»//www.w3.org/2000/svg»> <use href=»#myIcon» /> </svg>

<svg xmlns=»//www.w3.org/2000/svg»>

  <use href=»#myIcon» />

</svg>

Поскольку мы используем контуры, то можем применить следующий CSS-код, чтобы дать указание всем файлам наследовать текущий цвет, а не использовать свойство fill: SVG-иконка, используемая в кнопке, будет просто наследовать цвет текста кнопки.

svg { fill: currentColor; }

svg {

  fill: currentColor;

}

Нам нужно удалить атрибут fill самого SVG во время процесса оптимизации, чтобы стилизовать его таким образом с помощью CSS.

Заключение

Это выглядит, как много действий, но на самом деле весь процесс занимает удивительно мало времени, если вы хорошо ориентируетесь в графической программе. После нескольких повторений это закрепляется в мышечной памяти. Мне нравится оптимизировать большинство SVG-значков пакетно в начале проекта. Стоит потратить немного времени заранее, чтобы облегчить работу с графикой в будущем.

Автор: Michelle Barker

Источник: //css-irl.info

Редакция: Команда webformyself.

JavaScript. Быстрый старт

Изучите основы JavaScript на практическом примере по созданию веб-приложения

Узнать подробнее

Веб-дизайн. Быстрый старт

Изучите курс и узнайте, как создать дизайн и протопип сайта в Figma!

Смотреть видео

Какой формат лучше подходит для сохранения изображений, предназначенных для веб-сайтов; PNG или SVG?

Простой ответ здесь — использовать оба.

Тот факт, что вы назвали SVG в качестве опции, означает, что мы можем исключить фотографию в качестве предполагаемого варианта использования — потому что SVG полезны только для линейной графики, такой как логотипы, значки и иллюстрации, похожие на картинки.

Если вы рассматриваете этот выбор для фото графики, выбора нет; PNG, вероятно, всегда будет лучше. Для графики, где SVG является жизнеспособным вариантом, SVG — лучший вариант с резервным вариантом PNG / JPEG. PNG имеет много преимуществ, но по масштабируемости и размеру файла он часто не будет соответствовать SVG.

Использование только одного или другого означает, что вам придется пожертвовать либо обратной совместимостью, либо прогрессивным улучшением.

Взвешивая их друг против друга, PNG, безусловно, будет поддерживаться большим количеством браузеров, чем SVG, на данный момент, но разрешения вновь выпущенных устройств постоянно растут, а это значит, что PNG придется обслуживать на основе большого разнообразия разрешений. (через Media Queries, JavaScript или User Agent Sniffing) или масштабируется браузерами, что может привести к некоторым несовершенным результатам.

Глядя на то, что мы знаем, будущее держит; всегда более высокие разрешения, более широкая поддержка и более широкое использование SVG в Интернете; имеет смысл строить для того, что будет.

В общем, веб-сайты должны быть построены так, чтобы работать в течение многих лет; через 5 лет ваш прекрасно обратно совместимый веб-сайт может выглядеть потрясающе для 2% интернет-пользователей, все еще использующих старые браузеры, но довольно скудных в современных браузерах с сумасшедшими разрешениями — так что это очень большой набор трудных решений о том, какой путь компромисс.


Ваши варианты в ноябре 2014

  1. Только PNG

    • Ради качества вам нужно будет обслуживать как минимум пять разных версий в зависимости от размеров экрана и разрешения — и это очень консервативное предположение, вы можете получить 10-15 версий одного и того же изображения, если хотите быть предельно тщательным , Это также занимает некоторое время для реализации.

    • Если вы решили обслуживать один графический объект и масштабировать его в браузере, результаты, вероятно, будут менее чем идеальными и даже могут быть некрасивыми в зависимости от степени масштабирования.

    • Большое количество медиа-запросов может излишне раздуть CSS и негативно повлиять на скорость загрузки страниц.

    • Отлично будет смотреться на старых браузерах и устройствах, но не так здорово на новых.

  2. SVG с одним резервным PNG / JPEG / GIF

    • Вы можете использовать SVG везде, а затем использовать его в другом формате для браузеров, которые не поддерживают SVG. Главное преимущество — вам нужен только один файл для всех разных разрешений.

    • Если вы пойдете на компромисс и согласитесь с тем, что пользователи устаревших браузеров могут жить с несовершенно масштабированной графикой, вам потребуется только одна другая версия каждого файла в формате PNG, JPEG или GIF.

    • Это займет примерно столько же времени, что и в случае с медиа-запросами только в формате PNG — возможно, даже меньше, а это, вероятно, будет примерно такой же ценой.

    • Будет отлично смотреться на всех новых устройствах, с жертвами, сделанными на старых технологиях.

  3. SVG с несколькими запасными вариантами PNG / JPEG / GIF в зависимости от разрешения и размера экрана

    • Сначала вы могли бы обслуживать SVG, а затем зависящие от разрешения PNG для браузеров, которые не поддерживают SVG. Это будет наиболее тщательный, наиболее совместимый в обратном и прямом направлениях, наиболее последовательный и самый дорогой по времени вариант.

    • Это, вероятно, займет столько же времени, сколько 1 и 2 вместе, плюс немного больше для проработки изломов.

    • Будет выглядеть потрясающе практически на каждом устройстве.


В целом, я думаю , это зависит от того , что вы ищете более обратную совместимость или более прогрессивное улучшение, и сколько

денег времени вам придется потратить.

Великолепная десятка библиотек SVG иконок — Разработка на vc.ru

{«id»:152567,»type»:»num»,»link»:»https:\/\/vc.ru\/dev\/152567-velikolepnaya-desyatka-bibliotek-svg-ikonok»,»gtm»:»»,»prevCount»:null,»count»:1,»isAuthorized»:false}

{«id»:152567,»type»:1,»typeStr»:»content»,»showTitle»:false,»initialState»:{«isActive»:false},»gtm»:»»}

{«id»:152567,»gtm»:null}

3671 просмотров

Перед началом статьи хотелось бы сказать, что переводчик не несёт ответственности за содержание статьи, а также еще больше полезной и нужной информации вы найдете в нашем Телеграм-канале по ссылке: https://t.me/metsolution

Перевёл: Лебедев Даниил

Как-то раз я провел опрос на Reddit и обратился к коллегам-разработчикам с простой просьбой: поделиться названиями любимых библиотек иконок. Идея нашла живой отклик у сообщества, и вскоре я открыл для себя много отличных библиотек с открытым исходным кодом, о которых раньше и понятия не имел. И вот я решил написать статью о 10 лучших из них на основе результатов проведенного опроса.

Предварительно были проверены условия лицензирования всех упомянутых в статье библиотек, так что можете быть уверены, что все они общедоступны. Стоит также отметить, что перечисленные ниже библиотеки должны иметь современный и актуальный дизайн. Итак, наша великолепная 10-ка:

Font Awesome

Более чем уверен, что большинство из вас хотя бы раз использовали иконки Font Awesome, одной из самых первых популярных библиотек с открытым кодом. В настоящее время ее галерея содержит в целом 1588 бесплатных и 7 842 платных иконок.

Font Awesome предлагает огромную коллекцию разнообразных иконок, что является одной из главных причин большой востребованности этой библиотеки. На нашем веб-сайте используются двухцветные иконки Font Awesome Pro, и мы уверены, что благодаря им он выгодно выделяется на фоне аналогичных сайтов.

Font Awesome предлагает еще одну интересную возможность — создание персональной ссылки на CDN при наличии аккаунта (на соответствующем сервисе). Это позволит вам задать условие для исключения обычных иконок и использования только двухцветных.

Конечно, вы также можете включить только пару иконок, напрямую скопировав код SVG. Я бы настоятельно посоветовал это делать при условии, что вы не используете больше 20–30 значков на сайте.

Существует много способов использования возможностей Font Awesome: копирование источника SVG одной иконки, загрузка библиотеки или использование общего или их персонального CDN. У них есть прекрасная страница, которая поможет начать работу с Font Awesome.

Ionicons

Ionicons.io — еще одна библиотека SVG с открытым кодом, содержащая 457 иконок в трех разных стилях: контурные, заливные и заостренные. Здесь мне особенно нравится простой и понятный дизайн контуров и форм. Почему бы не использовать их в своем будущем проекте?

Использование Ionicons сопровождается хорошей документацией. Если вам нужна вся библиотека вместо отдельной SVG иконки, можете включить следующий скрипт в футер (нижний блок сайта):

<script src=»https://unpkg.com/[email protected]/dist/ionicons.js»> </script>

После этого просто добавьте следующий элемент в HTML-шаблон и измените атрибут name в соответствии с иконкой, которую хотите показать, вот таким образом:

<ion-icon name=»heart»></ion-icon>

CSS.gg

Если вы активно участвуете в жизни сообщества разработчиков на Reddit, то, конечно, не оставили без внимания факт появления новой библиотеки иконок, использующей для стиля только CSS. На данный момент она насчитывает свыше 704 отдельных иконок, распределенных по таким категориям, как уведомления, указатели (стрелки), код, дизайн и многое другое.

В свое время возникало много споров по поводу того, что лучше использовать с точки зрения производительности: CSS или SVG. Но позднее создатель библиотеки @astritmalsija запустил форматы SVG, SVG Sprite, Figma и Adobe XD для второй версии, предложив таким образом более широкий выбор реализаций.

Начать работу с CSS.gg очень просто: надо лишь выполнить команду npm -i css.gg и затем включить следующую таблицу стилей в тег head:

<link href=’https://css.gg/css’ rel=’stylesheet’>

Также существуют альтернативы CDN, а именно UNPKG или JSDelivr:

<!— UNPKG —> <link href=’https://unpkg.com/css.gg/icons/all.css’ rel=’stylesheet’> <!— JSDelivr —> <link href=’https://cdn.jsdelivr.net/npm/css.gg/icons/all.css’ rel=’stylesheet’>

Более подробная информация о том, как начать использование CSS.gg, содержится в инструкциях официального репозитория на Github.

Feathericons

Представляю вам Feathericons, внешне привлекательную и понятно устроенную библиотеку с 282 SVG иконками. По умолчанию ее основным форматом является SVG, так как на данный момент он является самым быстрым способом работы со значками.

Вы можете настраивать размер, толщину штриха и цвет иконок перед их загрузкой, а также переключать темный и светлый режимы нажатием на значок луны в правом верхнем углу веб-сайта.

Для начала работы с Feathericons необходимо загрузить файл SVG и включить его в вашу разметку либо с помощью src, либо используя его в качестве встроенного объекта SVG.

Eva Icons ❤

Eva Icons — это набор из 480 искусно выполненных иконок с открытым кодом в форматах SVG и PNG. Для создания значков используются два основных стиля: контурный и заливной. Радует тот факт, что изначально можно выбирать анимационные эффекты при наведении курсора мыши на значки, например изменение масштаба, пульсацию или вибрацию.

Работа с Eva Icons начинается с загрузки файла SVG/PNG после выбора иконки или загрузки целого набора. Вы можете также добавить Eva Icons, установив пакет npm следующим образом:

Heroicon

Heroicons, очередная библиотека с открытым кодом, является итогом работы создателей Tailwind CSS. Она содержит 165 отдельных иконок, включая контурные и заливные, и предлагает темную и светлую версии каждого элемента. Внешний вид значков качественно и искусно проработан.

Использование иконок начинается с нажатия на одну из них и копирования встроенного кода SVG, который сразу можно использовать в проектах. Примечательно еще и то, что библиотека предлагается в Figma. Если вам нужно включить все иконки, необходимо загрузить все файлы SVG с общедоступного репозитория.

Bootstrap icons

Данная библиотека включает свыше 600 пользовательских иконок с поддержкой SVG. На мой взгляд, она выгодно отличается от всех других с точки зрения дизайна. Если вам нравится использовать Bootstrap как CSS-фреймворк, то советую обратить внимание на Bootstrap 5 Icons и включить его в свой следующий проект.

Для работы с Bootstrap 5 Icons необходимо скопировать код SVG, а затем применить его по своему усмотрению: либо используя как встроенный код, либо включая в качестве источника для образа, либо создавая классы псевдокода в CSS. Какой бы способ вы не выбрали, на сайте есть информация по реализации каждого из них.

Remix Icon

Remix Icon — это большая коллекция из 2149 красивых иконок с открытым кодом под лицензией Apache. Они распределены по таким категориям, как бизнес, общение, финансы, карта и многие другие. Эта библиотека определенно заслуживает вашего внимания.

Начинаем работу с Remix Icon либо с загрузки версий SVG или PNG, либо с копирования встроенного кода SVG в буфер обмена. В качестве альтернативы можно также загрузить весь пакет как один файл .svg или SVG-спрайт.

Octicons

Octicons — набор из более 100 иконок с открытым кодом, которые Github использует на своем главном сайте. Насколько мне известно, они уже работают над второй версией библиотеки, улучшают дизайн и добиваются разнообразия иконок.

Огромное преимущество Octicons состоит в том, что его можно использовать как уже готовый пакет в React, Ruby, Rails, Jekyll и JavaScript. Здесь вы найдете список всех пакетов, необходимых для работы с Octicons.

Ikonate

Завершает наш список не менее интересная библиотека Ikonate, содержащая около 100 качественных иконок в плоском дизайне. Она находится под весьма лояльной и разрешительной лицензией MIT.

Вы можете легко настраивать размер, толщину и закругления границ, а также цвет иконок перед их экспортом. В экспортируемом файле ZIP вы получите HTML-файл со всеми выбранными встроенными значками, папку с отдельными файлами SVG и спрайт-листом.

В заключении прошу вас поддержать эти библиотеки, присудив им звезду на Github и тем самым отметив ту неоценимую работу, которую они выполняют. Поделитесь этим списком с вашими друзьями или коллегами, если вы сами еще не выбрали конкретную библиотеку иконок для вашего следующего проекта.

SVG картинка на сайте, почему не вставляется, почему опасно » Вебстудия 11

Если вы хотите использовать svg картинку у себя на WordPress, то он вам не даст ее загрузить, скажет что этот тип файла запрещен с целью безопасности.

Как оказывается если svg открыть в текстовом редакторе в него можно прописать любой JavaScript код и он будет потом выполнятся у вас на сайте, и это опасно.

Есть плагины для WordPress которые отключают безопасность и позволяют загружать svg. Плагины: SVG Support, Safe SVG, и др.

Safe SVG — чуть лучше, он перед загрузкой проверяет или svg картинка продезинфицирована (безопасна).

Но в любом случае, разрешая svg картинки даете инструменты для взлома, для вирусов и тп, поэтому лучше обойтись без svg.

Но преимущества svg в том что картинка идеально выглядит на любом разрешении экрана, это важно для логотипа, для кнопок соц сетей, иконок, и тп. Еще одно преимущество, тень в svg выглядит идеально на всех экранах, если использовать png картинку, то на мобильных тень на png будет выглядеть зубчиками, а это не солидно и не красиво.

Есть еще два варианта как вставить svg на сайт (не только на WordPress но и на обычный HTML сайт).

Пример сайта:

  • http://www.jekyllnow.com/
  • https://github.com/barryclark/jekyll-now/blob/master/_sass/_svg-icons.scss

Там снизу сайта есть svg иконки соц сетей, но они не подключены как svg файл. Там код svg картинок прописан как стили в файл css стилей.

&lt;a href="http://github.com/barryclark/jekyll-now"&gt;&lt;i&gt;&lt;/i&gt;&lt;/a&gt;
&lt;styl=e&gt;
.svg-icon.github {
background-image: url()
}
&lt;/styl=e&gt;

Ниже даю видеоурок на английском.

В уроке показаны два варианта. Первый, он вставляет svg код в сам HTML файл. А второй вариант более интересный, он вставляет base64 SVG код картинки в css файл. Можно сделать отдельный css файл и туда добавлять код со всех svg иконок, логотипа, и тп, это удобно и классно. В примере сайта http://www.jekyllnow.com/ как раз так и сделано, код всех svg картинок прописан в отдельном css файле, и потом вы нужную картинку легко выводите в HTML.

Сайт для конвертирования (Base64 encoder):
mobilefish.com/services/base64/base64.php

Еще один урок на английском про svg тут:
css-tricks.com/lodge/svg/09-svg-data-uris/

Лучшие сайты на основе изображений SVG

Лас- Изображения SVG заполняют сеть сетей так что через несколько лет мы сможем в целом улучшить работу в Интернете. И дело в том, что изображения этого типа, помимо возможности увеличения без потери качества четкости, обычно содержат почти килобайты данных.

SVG — это формат Векторное изображение на основе XML для 2D-графики. Этот тип графического формата может использоваться для всех видов эффектов, изображений, анимации и интерактивности, чтобы повысить удобство использования на веб-сайтах, в которые он интегрирован. Поскольку он мало весит, он позволяет вам поиграть с этими типами действий, поэтому мы собираемся показать лучшие веб-сайты с графикой SVG, чтобы служить в качестве вдохновения или в качестве наглядного примера того, как сделать следующее, которое мы собираемся сделать для клиента или на работу.

Агентство цифрового дизайна, которое зарекомендовало себя с очень ярким веб-сайтом, использующим изображения SVG и для особого прикосновения к визуальному. Тот, на который можно без сомнения вдохновиться. Указатель, превращенный в красную точку, которая адаптируется к каждому из элементов, составляющих сеть, поражает.

Веб-сайт с изысканным дизайном, на котором хэштеги появляются как «всплывающие окна» и это ни в коем случае не замедляет видение и опыт, предлагаемые этим сайтом. Некоторые хэштеги, которые «съедаются» самими изображениями, могут быть переданы на передний план.

Поскольку основной причиной является видео, это любопытно как объединить изображения PNG с текстом, который отображается при прокрутке вниз.

Сайт, вдохновляющий ваша отличная идея с анимацией которые перемещаются очень плавно по мере продвижения по их содержанию. Большой прогресс в веб-дизайне, с которым мы сталкиваемся сегодня, является значительным, и он составляет 10 × 17, с намерением показать 26 артистов, которые составляют свои любимые музыкальные альбомы 2017 года, тот, который это показывает.

Просто нажмите на значок с тремя горизонтальными полосами в правом верхнем углу, чтобы откройте для себя тонкую и плавную анимацию, отображающую меню заголовок этого веб-сайта. Окончательный пример того, как анимация должна подтверждаться на сайте.

Интернет-магазин без особой помпы в анимации, но это еще один пример работы с изображениями SVG.

Из Испании у нас есть Rocka, чтобы показать отличный цветовой переход это делается, когда мы исследуем содержимое этого веб-сайта с помощью колесика мыши. Прекрасный опыт работы со всеми видами анимации.

Веб-дизайн, в котором стремится к простоте своих элементов для удобства использования в целом, не упуская ни капли изобретательности в некоторых анимациях, которые показаны в этом замечательном веб-интерфейсе, который предлагает Paradiso. Мы еще раз подчеркиваем, что очень креативное меню заголовков завершено в анимации.

Креативная студия из Нью-Йорка, которая демонстрирует все намерения боковое меню заголовка, которое открывается перед нами с серией анимаций и очень привлекательных изображений. Если вы ищете уникальное меню для своего веб-сайта, Zero’s уже может вдохновить вас. Когда вы наводите указатель мыши на каждую из опций, появляются эти красочные изображения и анимация.

Любопытен экран загрузки и изящная форма показать последние твиты, публикации в Facebook или изображения в Instagram. Веб-сайт, достойный веб-экспериментов.

Проект с идеей совмещения времени в китайских мегаполисах, который демонстрирует большое мастерство в демонстрации того же благодаря его затуханиям и градиентам с умом в использовании цветовой гаммы. Большие изображения, которые появляются и исчезают, с высококачественной анимацией и обработкой. Это завидно.

Французская компания по производству фильмов и телесериалов, демонстрирующая большая мощность в видео благодаря мгновенному изменению удерживая указатель мыши в каждой из категорий. Откройте каждый из них, чтобы узнать, каково экспериментировать с веб-дизайном.

На этом веб-сайте используются два основных цвета, чтобы создать правильный контраст идентифицировать себя. Он также отличается анимацией фона, который постоянно находится в движении.

Zen Studio предоставляет нам этот веб-сайт из признанный художник во всем мире и это максимальный пример того, чем может быть сеть: интерактивный видеоклип, в котором наш указатель является тем, который управляет эксклюзивной анимацией. Существенный.

Консалтинговая фирма из Бразилии, которая использует анимации как занавески показать каждую из ваших услуг. Просто, но эффективно использовать зеленый и синий цвета для пустого фона.

Еще один визуальный опыт, основанный на желтый и черный, и что это имеет большой эффект, чтобы показать катастрофы.

Портфолио веб-интерфейса, показывающее серия веб-навыков это не оставляет никого равнодушным.

 Цифровое агентство, которое демонстрирует большую ценность в веб-дизайне, помогая вам забавная анимация, которую можно увидеть когда вы наводите указатель мыши на его букву «К».

Еще один повседневный веб-сайт, подчеркивающий вид коллажа который открывается перед нами, когда мы прокручиваем вниз.

Известный словацкий бренд молока, использующий исследование с помощью прокрутки чтобы показать достойный и привлекательный веб-опыт. По крайней мере, любопытно.

Испанская Herokid Studio предлагает дизайн этого веб-сайта, который выделяется черным, желтым и серией видеороликов Они демонстрируют большую элегантность в чаевых.


Что это такое и как его создать

В процессе разработки удобного веб-сайта вы можете столкнуться с некоторыми трудностями при работе с изображениями, особенно с их разрешением. Важно правильно подобрать качество изображения — меньше всего на странице вещей выглядят менее профессионально, чем искаженный, плохо масштабированный логотип, значок или фотография.

Эта проблема усугубляется адаптивным дизайном. Посетители просматривают ваш контент как на настольных компьютерах, так и на смартфонах, поэтому, наряду с остальным контентом, ваши изображения должны быть оптимизированы независимо от устройства.Было бы неплохо, если бы существовал цифровой формат, в котором изображения выглядели бы великолепно, независимо от их размера?

Как оказалось, есть. Он называется форматом SVG и идеально подходит для нефотографических изображений на веб-сайтах.

SVG — это что-то вроде волшебного трюка в дизайне веб-сайтов — они не только создают четкую графику в любом масштабе, но также оптимизированы для поисковых систем, программируются, часто меньше других форматов и способны к динамической анимации. Есть много вещей, которые нужно распаковать и узнать о SVG.

В этом руководстве я расскажу обо всех основах, которые вам необходимо знать, чтобы начать работу с SVG. Я объясню, что это за файлы, когда их использовать и как начать создавать файлы SVG самостоятельно.

Что такое файл SVG?

Файл SVG, сокращение от масштабируемого векторного графического файла, представляет собой стандартный тип графического файла, используемый для рендеринга двумерных изображений в Интернете.

Файл SVG, сокращение от масштабируемого векторного графического файла, представляет собой стандартный тип графического файла, используемый для рендеринга двумерных изображений в Интернете.В отличие от других популярных форматов файлов изображений, формат SVG хранит изображения в виде векторов, представляющих собой тип графики, состоящей из точек, линий, кривых и фигур, основанных на математических формулах.

Возникает вопрос: что такое векторная графика?

Растр против вектора

В настоящее время в Интернете используется несколько форматов файлов изображений, которые можно разделить на две категории: растровая графика и векторная графика.

Вы, вероятно, знакомы с распространенными форматами PNG и JPEG.Это форматы растровой графики, что означает, что они хранят информацию об изображении в сетке цветных квадратов, также называемой растровым изображением. Квадраты в этом растровом изображении объединяются, образуя связное изображение, очень похожее на пиксели на экране компьютера.

Растровая графика хорошо подходит для высокодетализированных изображений, таких как фотографии, в которых необходимо указать точный цвет каждого пикселя. Растровые изображения имеют фиксированное разрешение, поэтому увеличение их размера снижает качество изображения.

Векторные графические форматы, такие как SVG и PDF, работают по-разному.Эти форматы хранят изображения в виде набора точек и линий между точками. Математические формулы определяют размещение и форму этих точек и линий, а также сохраняют их пространственные отношения при увеличении или уменьшении масштаба изображения. Файлы векторной графики также хранят информацию о цвете и даже могут отображать текст.

Как работают файлы SVG

Файлы

SVG написаны на XML, языке разметки, используемом для хранения и передачи цифровой информации. Код XML в файле SVG определяет все формы, цвета и текст, из которых состоит изображение.

Давайте рассмотрим несколько примеров. Я начну с рисования простого круга SVG:

.

Когда я открываю файл для этого круга в текстовом редакторе, появляется следующий код XML:

Как видите, здесь не так много кода. Нам нужна только одна строка кода, чтобы нарисовать круг. Это потому, что XML делает за нас большую часть работы с тегами . В приведенном выше коде теги показаны розовым цветом в угловых скобках.

Чтобы нарисовать круг, код XML указывает форму с помощью тега , ее положение с атрибутами и cx и cy , радиус с помощью атрибута r и цвет внутри тег