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

Haf*_*hor 126 html css image

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

我知道CSS中的剪辑,但这似乎只适用于绝对定位.

Dav*_*mas 157

虽然你已经接受了答案,但我只是补充说有(有点鲜为人知的)clipcss属性,虽然它确实要求被剪裁的元素是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 */
}
Run Code Online (Sandbox Code Playgroud)
<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>
Run Code Online (Sandbox Code Playgroud)

JS Fiddle演示,用于实验.

为了补充原来的答案 - 有些姗姗来迟 - 我正在编辑以显示使用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%);
}
Run Code Online (Sandbox Code Playgroud)
<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>
Run Code Online (Sandbox Code Playgroud)

JS Fiddle演示,用于实验.

参考文献:

  • 惊人的发现,非常感谢:)仅供参考,它不像人们想象的那样有限.如果你有一个图像容器div(id ="img_container")围绕img标签,只需使img_container位置相对,并使img绝对,你可以剪切图像的方式 (14认同)
  • `clip`是[已弃用](https://developer.mozilla.org/en-US/docs/Web/CSS/clip).较新的[`clip-path`](http://css-tricks.com/almanac/properties/c/clip/)不需要定位 (6认同)
  • 虽然不推荐使用剪辑,但许多现代浏览器还不支持剪辑路径.https://developer.mozilla.org/en-US/docs/Web/CSS/clip-path (3认同)

Esp*_*spo 105

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

  • @Espo,这似乎是一个相当标准的方法,但是,如果你有一个精灵图像包含几个大小为32x32的单个图像,并且你想在div,span等大于32x32上显示其中1个,那该怎么办? .设置背景位置不再有效. (7认同)
  • 为了澄清起见,您需要将容器 td、div、span 或其他任何内容的宽度和高度设置为 50px 以使其工作。 (2认同)
  • @ series0ne你可以和[`background-size`]结合使用(https://developer.mozilla.org/en-US/docs/Web/CSS/background-size) (2认同)

Vin*_*ent 32

另一种选择是以下,虽然不是最干净的,因为它假定图像是容器中的唯一元素,例如在这种情况下:

<header class="siteHeader">
  <img src="img" class="siteLogo" />
</header>
Run Code Online (Sandbox Code Playgroud)

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

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

.siteHeader .siteLogo{
    margin: -100px;
}
Run Code Online (Sandbox Code Playgroud)

演示可以在这个JSFiddle中看到.

似乎只能在IE> 9中工作,并且可能是所有其他浏览器的所有重要版本.

  • 虽然它是一个 bitc hacky,但它的优点是它适用于所有浏览器(不推荐使用剪辑并且剪辑路径在 IE 中不起作用)并且当您尝试打印网页时它可以工作(默认情况下跳过背景图像) (2认同)