如何在HTML / CSS中仅显示图像的一部分?

时间:2008-09-11 21:35:45

标签: html css image

假设我想要一种方法来显示HTML中250x250px图像的中心50x50px。我怎样才能做到这一点。另外,有没有办法为css:url()引用执行此操作?

我知道CSS中的 clip ,但这似乎只适用于绝对定位。

4 个答案:

答案 0 :(得分:151)

虽然你已经接受了答案,但我只想补充一点(有些鲜为人知的)clip css属性,虽然确实要求元素为剪辑是position: absolute;(这是一种耻辱):

.container {
  position: relative;
}
#clip {
  position: absolute;
  clip: rect(0, 100px, 200px, 0);
  /* clip: shape(top, right, bottom, left); NB 'rect' is the only available option */
}
<div class="container">
  <img src="http://lorempixel.com/200/200/nightlife/3" />
</div>
<div class="container">
  <img id="clip" src="http://lorempixel.com/200/200/nightlife/3" />
</div>

JS Fiddle demo,用于实验。

为了补充原始答案 - 有点迟了 - 我正在编辑以显示clip-path的使用,它已取代现已弃用的clip属性。

clip-path属性允许一系列选项(比原始clip更多):

  • inset - 矩形/长方体形状,定义为四个值为'距离'(top right bottom left)
  • circle - circle(diameter at x-coordinate y-coordinate)
  • ellipse - ellipse(x-axis-length y-axis-length at x-coordinate y-coordinate)
  • polygon - 由与左上角元素原点相关的一系列x / y坐标定义。当路径自动关闭时,多边形的实际最小点数应为3,任意少(两个)为一行或(一)为点:polygon(x-coordinate1 y-coordinate1, x-coordinate2 y-coordinate2, x-coordinate3 y-coordinate3, [etc...])
  • url - 这可以是本地URL(使用CSS id-selector)或外部文件的URL(使用文件路径)来识别SVG,尽管我没有尝试过要么(至今),所以我不能提供有关他们的利益或警告的见解。

div.container {
  display: inline-block;
}
#rectangular {
  -webkit-clip-path: inset(30px 10px 30px 10px);
  clip-path: inset(30px 10px 30px 10px);
}
#circle {
  -webkit-clip-path: circle(75px at 50% 50%);
  clip-path: circle(75px at 50% 50%)
}
#ellipse {
  -webkit-clip-path: ellipse(75px 50px at 50% 50%);
  clip-path: ellipse(75px 50px at 50% 50%);
}
#polygon {
  -webkit-clip-path: polygon(50% 0, 100% 38%, 81% 100%, 19% 100%, 0 38%);
  clip-path: polygon(50% 0, 100% 38%, 81% 100%, 19% 100%, 0 38%);
}
<div class="container">
  <img id="control" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="rectangular" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="circle" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="ellipse" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="polygon" src="http://lorempixel.com/150/150/people/1" />
</div>

JS Fiddle demo,用于实验。

参考文献:

答案 1 :(得分:100)

一种方法是将要显示的图像设置为容器中的背景(td,div,span等),然后调整背景位置以获得所需的精灵。

答案 2 :(得分:27)

另一个替代方案如下,虽然不是最干净的,因为它假设图像是容器中唯一的元素,例如在这种情况下:

<header class="siteHeader">
  <img src="img" class="siteLogo" />
</header>

然后,您可以将容器用作具有所需大小的遮罩,并使用负边距围绕图像以将其移动到正确的位置:

.siteHeader{
    width: 50px;
    height: 50px;
    overflow: hidden;
}

.siteHeader .siteLogo{
    margin: -100px;
}

可以在this JSFiddle中看到演示。

似乎仅适用于IE&gt; 9,可能是所有其他浏览器的所有重要版本。

答案 3 :(得分:2)

调整背景位置以将背景图像移动到div的不同位置

div { 
       backgroud-image: url('image url')
       background-position: 0 -250px; 
    }