假设我想要一种仅在 HTML 中显示 250x250 像素的图像的中心 50x50 像素的方法。我怎样才能做到这一点。另外,有没有办法为 css:url() 引用做到这一点?
我知道 CSS 中的剪辑,但这似乎只在与绝对定位一起使用时才有效。
正如问题中提到的,有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 演示,用于实验。
为了补充最初的答案——有点晚了——我正在编辑以显示 的用法clip-path
,它已经取代了现在已弃用的clip
属性。
该clip-path
属性允许一系列选项(比原来的更多clip
),包括:
inset
— 矩形/长方体形状,用四个值定义为 'distance-from' (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
由于路径自动关闭,多边形的实际最小点数应该是三个,任何更少(两个)是一条线或(一个)是一个点: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 演示,用于实验。
参考:
clip
clip-path
(MDN)。clip-path
(W3C)。一种方法是将要显示的图像设置为容器(td、div、span 等)中的背景,然后调整背景位置以获得所需的精灵。
另一种选择如下,虽然不是最干净的,因为它假设图像是容器中的唯一元素,例如在这种情况下:
<header class="siteHeader">
<img src="img" class="siteLogo" />
</header>
然后,您可以将容器用作具有所需大小的蒙版,并用负边距包围图像以将其移动到正确的位置:
.siteHeader{
width: 50px;
height: 50px;
overflow: hidden;
}
.siteHeader .siteLogo{
margin: -100px;
}
演示可以在这个 JSFiddle中看到。
似乎只在 IE>9 中工作,并且可能在所有其他浏览器的所有重要版本中工作。
调整 background-position 以将背景图像移动到 的不同位置div
:
div {
background-image: url('image url');
background-position: 0 -250px;
}