Клип / Обрезать фоновое изображение с CSS - PullRequest
67 голосов
/ 15 октября 2011

У меня есть этот HTML:

<div id="graphic">lorem ipsum</div>

с этим CSS:

#graphic { background-image: url(image.jpg); width: 200px; height: 100px;}

Фоновое изображение, которое я применяю, имеет размер 200x100 пикселей, но я хочу отображать только обрезанную частьфонового изображения размером 200x50 пикселей.

background-clip не является подходящим свойством CSS для этого.Что я могу использовать вместо этого?

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

Ответы [ 3 ]

91 голосов
/ 15 октября 2011

Вы можете поместить изображение в псевдоэлемент с его собственным контекстом измерения:

#graphic {
  position: relative;
  width: 200px;
  height: 100px;
}
#graphic::before {
  position: absolute;
  content: '';
  z-index: -1;
  width: 200px;
  height: 50px;
  background-image: url(image.jpg);
}

#graphic {
    width: 200px;
    height: 100px;
    position: relative;
}
#graphic::before {
    content: '';
    
    position: absolute;
    width: 200px;
    height: 50px;
    z-index: -1;
    
    background-image: url(http://placehold.it/500x500/); /* Image is 500px by 500px, but only 200px by 50px is showing. */
}
<div id="graphic">lorem ipsum</div>

Поддержка браузера хороша, но , если вам нужна поддержка IE8, используйте двоеточие :before. IE не поддерживаетлюбой синтаксис в версиях до этого.

7 голосов
/ 15 октября 2011

может быть, вы можете написать так:

#graphic { 
 background-image: url(image.jpg); 
 background-position: 0 -50px; 
 width: 200px; 
 height: 100px;
}
3 голосов
/ 05 августа 2016

Другой вариант - использовать linear-gradient(), чтобы скрыть края вашего изображения. Обратите внимание, что это глупое решение, поэтому я не буду прилагать больших усилий, чтобы объяснить это ...

.flair {
  min-width: 50px; /* width larger than sprite */
  text-indent: 60px;
  height: 25px;
  display: inline-block;
  background:
    linear-gradient(#F00, #F00) 50px 0/999px 1px repeat-y,
    url('https://championmains.github.io/dynamicflairs/riven/spritesheet.png') #F00;
}

.flair-classic {
  background-position: 50px 0, 0 -25px;
}

.flair-r2 {
  background-position: 50px 0, -50px -175px;
}

.flair-smite {
  text-indent: 35px;
  background-position: 25px 0, -50px -25px;
}
<img src="https://championmains.github.io/dynamicflairs/riven/spritesheet.png" alt="spritesheet" /><br />
<br />
<span class="flair flair-classic">classic sprite</span><br /><br />
<span class="flair flair-r2">r2 sprite</span><br /><br />
<span class="flair flair-smite">smite sprite</span><br /><br />

Я использую этот метод на этой странице: https://championmains.github.io/dynamicflairs/riven/ и не могу использовать элементы ::before или ::after, потому что я уже использую их для другого взлома.

...