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

标签 html css image

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

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

最佳答案

如问题中所述,有 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 — 矩形/长方体形状,用四个值定义为“distance-from”(右上左下)
  • 圆(x 坐标 y 坐标处的直径)
  • 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 , 用于实验。

引用资料:

关于html - 如何在 HTML/CSS 中只显示图像的一部分?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57725/

相关文章:

html - (Bootstrap) 在bootstrap card后添加margin

javascript - 将隐藏图像加载到 HTML

html - 输入元素后的未知空间

html - 计算出的列宽与 css 声明的列宽不同。浏览器如何决定宽度?

javascript - 链接回以前访问过的页面时设置默认值吗?

javascript - 选中复选框时如何向上移动一个部分?

javascript - 淡出图像,新图像在图像缩略图库顶部淡出

html - 使用 CSS 缩放 img

javascript - 使用对 Canvas 的外部引用渲染 SVG

html - HTML 中的一个 LI 中的多个图像