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

Posted

技术标签:

【中文标题】如何在 HTML/CSS 中只显示图像的一部分?【英文标题】:How can I display just a portion of an image in HTML/CSS? 【发布时间】:2010-09-08 15:13:25 【问题描述】:

假设我想要一种仅在 html 中显示 250x250 像素图像的中心 50x50 像素的方法。我怎样才能做到这一点。另外,有没有办法为 css:url() 引用做到这一点?

我知道 CSS 中有 clip,但这似乎只在与绝对定位一起使用时才有效。

【问题讨论】:

A List Apart 应该出现在任何有 HTML/CSS/JS 问题的网站列表中:Here's one way of doing sprites、and here's another using JS。 使用精灵 - 见这里w3schools.com/css/css_image_sprites.asp 【参考方案1】:

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

【讨论】:

澄清一下,您可以将容器 td、div、span 或其他任何内容的宽度和高度设置为 50px 以使其正常工作。 @Espo,这似乎是一种相当标准的方法,但是如果您有一个包含多个大小为 32x32 的单独图像的精灵图像,并且您想在一个 div 上显示其中的一个,跨度等大于 32x32...设置背景位置不再有效。 @series0ne 你可以和background-size结合使用【参考方案2】:

正如问题中提到的,有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)circlecircle(diameter at x-coordinate y-coordinate)ellipseellipse(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 demo,用于实验。

参考资料:

clip — 注意:已弃用clip-path (MDN)。 clip-path (W3C)。

【讨论】:

惊人的发现,非常感谢 :) 仅供参考,它并不像人们想象的那样有限。如果您在 img 标签周围有一个图像容器 div (id="img_container"),只需使 img_container 位置相对,并使 img 绝对,您可以这样剪辑图像 "位置:绝对;(这是耻辱)" 我不知道,没有。​​ clip 是deprecated。较新的clip-path 不需要定位 虽然不推荐使用剪辑,但许多现代浏览器尚不支持剪辑路径。 developer.mozilla.org/en-US/docs/Web/CSS/clip-path【参考方案3】:

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

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

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

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


.siteHeader .siteLogo
    margin: -100px;

演示可以在this JSFiddle看到。

似乎只适用于 IE>9,可能所有其他浏览器的所有重要版本。

【讨论】:

虽然它是一个 bitc hacky,但它的优点是它适用于所有浏览器(clip 已弃用,clip-path 在 IE 中不起作用)并且当您尝试打印网页(默认跳过背景图片) 这是唯一真正跨浏览器的方法。所有其他方式都有问题。 “剪辑”已被贬低,所有浏览器都无法准确读取背景位置。【参考方案4】:

调整background-position,将背景图片移动到div的不同位置:

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

【讨论】:

类型:backgroud-image -> background-image。我想知道为什么我的浏览器不知道这样的 CSS 属性,最后我意识到这是由于类型。

以上是关于如何在 HTML/CSS 中只显示图像的一部分?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 laravel 5.2 中只显示字符串的一部分?

如何从 Python 中的 HTML / CSS(包括图像)源生成 PDF? [关闭]

HTML,CSS 悬停在图像上

如何使用 html/css 进行图像翻转?

如何在android中只显示状态栏

如何在 Django 中只显示表单中的一个字段