css svg
Продвинутый CSS

Магия CSS: Методы обрезки изображений при помощи CSS и SVG

Всем привет, меня зовут Анна Блок и сегодня мы поговорим о том, как обрезать изображения, не используя графических программ.

Где это может пригодиться?

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

Яркий пример: блог на WordPress.

Предположим, вы хотите, чтобы обложка вашей статьи имела пропорции 1:1 (квадрат). Ваши действия:

  1. Скачаете подходящую картинку из интернета;
  2. Обрежете ее в фотошопе до нужных пропорции;
  3. Опубликуете статью.

Зайдя на сайт, вы увидите тот результат, который ожидали.

Но, предположим вы забыли обрезать картинку в фотошопе и выгрузили рандомное изображение в качестве обложки из интернета, что будет тогда?! Правильно, верстка сломается. А если вы совсем не использовали CSS, то картинка HD разрешения и вовсе может перекрыть весь обзор на текст. Поэтому важно уметь делать обрезку изображений при помощи CSS стилей.

Давайте разберем разные ситуации того, как это можно реализовать не только при помощи CSS, но и SVG.
 

Пример 1


 
Попробуем обрезать изображение которое размещено при помощи background-image. Создадим небольшую HTML-разметку

<div class="box"></div>

Переходим к стилизации CSS. Через background-image добавляем изображение, указываем рамки для нашего изображения, центрируем изображение при помощи background-position и задаем background-size:

.box {
   background-image:url(http://tpverstak.ru/wp-content/uploads/2017/05/kitty.jpg);
   background-position:center center;
   background-size:cover;
   width:300px;
   height:300px;
}

 
Ознакомиться подробнее с HTML и CSS можно тут:

Это был первый и самый простой метод по обрезке изображения. Теперь давайте рассмотрим второй пример.
 

Пример 2


 
Предположим, у нас есть всё тот же контейнер box внутри которого находится тег img с изображением, которое мы сейчас будем стилизовать.

<div class="box">
   <img src="http://tpverstak.ru/wp-content/uploads/2017/05/kitty.jpg" alt="">
</div>

Далее мы будем стилизовать два элемента: класс box и тег img.
Начнем работу со связкой свойств position: relative для box и для position: absolute для img.

Также разместим наше изображение по центру относительно того объекта, который мы создадим. И используем свойство, которое довольно редко используются: object-fit.

.box {
   position: relative;
   overflow:hidden;
   width:300px;
   height:300px;
}

.box img {
   position: absolute;
   top:50%;
   left:50%;
   transform:translate(-50%,-50%);
   width:300px;
   height:300px;
   object-fit:cover;
}

На мой взгляд, это лучший метод. Он идеально подойдет для блогов, если вы используете изображения для постов совершенно разных пропорций.
 
Ознакомиться подробнее с HTML и CSS можно тут:

 

Пример 3


 
Также создавать обрезку для изображений мы можем в момент, если мы вставляем их в SVG элементы. Для примера возьмем круг. SVG мы можем создать при помощи тегов. Создаем обрамляющий тег svg внутри которого будет находится тег circle и тег pattern. В теге pattern пишем тег image. В нем мы указываем атрибут xlink:href и добавляем изображение. Также добавим атрибуты ширины и высоты. Но на этом не все. Нам потребуется добавить значение fill. Чтобы наша работа считала законченной мы добавим вспомогательный атрибут preserveAspectRatio в тег image, который позволит заполнить наше изображение «от и до» по всему кругу.

<svg width="250" height="250">
   <pattern id="pattern" width="100%" height="100%">
      <image xlink:href="https://omiliya.org/sites/default/files/img_articles/5_2.jpeg" width="250" height="250" preserveAspectRatio="xMidYMin slice"></image>
   </pattern>
   <circle cx="125" cy="125" r="100" fill="url(#pattern)"></circle>
</svg>

Я не могу назвать этот метод универсальным. Зато его можно использовать в исключительных случаях. Например, если мы затронули тему блога, то идеально такой метод мог бы вписаться для аватарки автора который пишет статью.
 
Ознакомиться подробнее с HTML и CSS можно тут:

 
Итоги:
Мы разобрали 3 метода обрезки изображения на сайтах: при помощи background-image, используя тег img и связанный с паттерном svg со встраиванием растровых изображений при помощи тега image. Если вы знаете ещё какие-то методы по обрезке изображения при помощи SVG, то делитесь ими в комментариях. Не только мне, но и другим будет полезно узнать о них.
 

Не забывай задавать свои вопросы по вёрстке или фронтенд-разработке у профессионалов на FrontendHelp в режиме онлайн.

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

Предыдущий пост

Магия CSS: Glitch для любого background

Следующий пост

Магия CSS: Glitch для любого текста на сайте

Комментарии

  • root

    В третьем примере есть проблема. Если уменьшать размер сайта по ширине (например использование мобильных версий сайта) изображение уменьшается по wight, а по height такого не происходит. Таким образом, изображение обрезается по ширине, а не масштабируется

    Reply to root
  • Роман

    Спасибо! Помогло!

    Reply to Роман

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *