ChatGPT解决这个技术问题 Extra ChatGPT

CSS 显示调整大小和裁剪的图像

我想显示来自具有特定宽度和高度的 URL 的图像,即使它具有不同的大小比例。所以我想调整大小(保持比例),然后将图像剪切到我想要的大小。

我可以使用 html img 属性调整大小,也可以使用 background-image 进行剪切。
我怎样才能做到这两点?

例子:

这个图片:

https://i.stack.imgur.com/wPh0S.jpg


大小为 800x600 像素,我想显示为 200x100 像素的图像


使用 img 我可以调整图像 200x150px 的大小:

<img 
    style="width: 200px; height: 150px;" 
    src="http://i.stack.imgur.com/wPh0S.jpg">

这给了我这个:

使用 background-image,我可以剪切图像 200x100 像素。

<div 
    style="background-image:
           url('https://i.stack.imgur.com/wPh0S.jpg'); 
    width:200px; 
    height:100px; 
    background-position:center;">&nbsp;</div>

给我:

 

我怎样才能做到这两点?调整图像大小,然后将其剪切成我想要的大小?


L
LWC

您可以结合使用这两种方法,例如。

.crop { 宽度:200px;高度:150px;溢出:隐藏; } .crop img { 宽度:400px;高度:300px;边距:-75px 0 0 -100px; }

Donald Duck

您可以使用否定 margin<div/> 内移动图像。


请注意,如果在包含的图像上设置 position:relative,则需要在包含的 div 上设置 position:relative。如果你不这样做,我发现 IE 实际上不会剪辑图像。
还从 .crop img 类中删除高度
@waqar-alamgir 如果您删除了高度声明,它将无法正常工作
另请注意,当使用 css 裁剪图像时,用户仍然需要下载图像。在将图像发送给用户之前,最好使用 php 和 GD 或其他图像编辑库来调整图像大小和裁剪图像。这完全取决于您想要什么,加载服务器或用户带宽。
只是给其他人的注释:.crop 高度和宽度定义了在哪里切片图像的最底部和最右侧部分。 .crop img 高度和宽度将缩放图像。 .crop img 边距将平移图像
J
Joel Purra

使用 CSS3,可以使用 background-size 更改 background-image 的大小,同时实现这两个目标。

css3.info 上有 a bunch of examples

Implemented based on your example,使用 donald_duck_4.jpg。在这种情况下,background-size: cover; 正是您想要的 - 它适合 background-image 以覆盖包含 <div> 的整个区域并剪掉多余的部分(取决于比率)。

.with-bg-size { background-image: url('https://i.stack.imgur.com/wPh0S.jpg');宽度:200px;高度:100px;背景位置:中心; /* 使背景图片覆盖

的区域,并将多余的部分剪掉 */ background-size: cover; }
唐老鸭!


很好的解决方案,但需要注意的是它与 IE <9 不兼容(如果这对任何人都重要的话)。另外,我想提一下,如果您将封面替换为包含背景尺寸,它将缩放,但不会裁剪图像。
对于 <img /> 标记,请查看 object-fit: coverCSS Image Values and Replaced Content Module Level 3 specification 中的相关值。
R
Roman Cherepanov

你试过用这个吗?

.centered-and-cropped { object-fit: cover }

我需要调整图像大小、居中(垂直和水平)然后裁剪它。

我很高兴地发现,它可以在一条 css 行中完成。在此处查看示例:http://codepen.io/chrisnager/pen/azWWgr/?editors=110

以下是该示例中的 CSSHTML 代码:

.centered-and-cropped { object-fit:cover }

original

Bear

object-fit: cover

熊


谢谢,我认为这是最简单和最通用的方法 - 但它似乎不适用于 IE:/ 在此处查找文档:developer.mozilla.org/de/docs/Web/CSS/object-fit
IE11 或 EDGE(14) 不支持 CSS3 object-fit caniuse.com/#feat=object-fit
@eye-wonder Edge 16 支持它,即将推出。如果它的非关键性和谨慎使用,它可以在今天使用
在 CSS3 中,我们可以尝试使用 img+object-fit 或 div+background-image 的任何一种方式。到目前为止,根据我的经验,背景图像可用于适应更多条件。
到目前为止,Edge 也支持这一点(不知道从什么时候开始)。
I
Igor Ivancha
.imgContainer {
  overflow: hidden;
  width: 200px;
  height: 100px;
}
.imgContainer img {
  width: 200px;
  height: 120px;
}
<div class="imgContainer">
  <img src="imageSrc" />
</div>

包含 div 基本上通过隐藏溢出来裁剪图像。


I
Igor Ivancha
img {
  position: absolute;
  clip: rect(0px, 140px, 140px, 0px);
}
<img src="w3css.gif" width="100" height="140" />

K
Kirby

谢谢sanchothefat。

我对你的回答有改进。由于裁剪是为每个图像量身定制的,因此此定义应位于 HTML 而不是 CSS。

<div style="overflow:hidden;">
   <img src="img.jpg" alt="" style="margin:-30% 0px -10% 0px;" />
</div>

H
Hidayt Rahman

如果您正在使用 标签,object-fit 可能会对您有所帮助

下面的代码将为您裁剪图像。你可以玩object-fit

img {
  object-fit: cover;
  width: 300px;
  height: 337px;
}

这让我很开心——我可以轻松地将它附加到我光滑的滑块轮播实现中的幻灯片上——普通的 IMG 对象解决方案,而不涉及“滑块插件的代码库”
这就是 CSS 的优势 :)
M
Mahmoud Khaled

对包括 object-fit: cover 的先前答案的一个小补充:

object-position

您可以使用 object-position 属性更改被替换元素的内容对象在元素框内的对齐方式。

.trimmed-cover { 对象适合:封面;宽度:100%;高度:177px;对象位置:中心 40%; }

https://i.stack.imgur.com/7uRBR.gif


1
151291
img {
    position: absolute;
    clip: rect(0px,60px,200px,0px);
} 

M
Md Rafee

实时示例:https://jsfiddle.net/de4Lt57z/

HTML:

<div class="crop">
  <img src="example.jpg" alt="..." />
</div>

CSS:

    .crop img{
      width:400px;
      height:300px;
      position: absolute;
      clip: rect(0px,200px, 150px, 0px);
      }

说明:这里的图像根据图像的宽度和高度值调整大小。裁剪是由剪辑属性完成的。

有关剪辑属性的详细信息,请遵循:http://tympanus.net/codrops/2013/01/16/understanding-the-css-clip-property/


E
Emeric

尝试使用 clip-path 属性:

clip-path 属性允许您将元素剪辑为基本形状或 SVG 源。注意:clip-path 属性将替换已弃用的 clip 属性。

img { 宽度:150px;剪辑路径:插入(30px 35px); }

更多示例 here


D
Deivide

在裁剪类中,放置要显示的图像大小:

.crop {
    width: 282px;
    height: 282px;
    overflow: hidden;
}
.crop span.img {
    background-position: center;
    background-size: cover;
    height: 282px;
    display: block;
}

html 将如下所示:

<div class="crop">
    <span class="img" style="background-image:url('http://url.to.image/image.jpg');"></span>
</div>

L
Linus Caldwell
<p class="crop"><a href="http://templatica.com" title="Css Templates">
    <img src="img.jpg" alt="css template" /></a></p> 

.crop {
    float: left;
    margin: .5em 10px .5em 0;
    overflow: hidden; /* this is important */
    position: relative; /* this is important too */
    border: 1px solid #ccc;
    width: 150px;
    height: 90px;
}
.crop img {
    position: absolute;
    top: -20px;
    left: -55px;
}

f
ferrantim

services 之类的 Filestack 可以为您执行此操作。

他们获取您的图像 url 并允许您使用 url 参数调整它的大小。这很容易。

调整为 200x100 但保持纵横比后,您的图像将如下所示

整个网址看起来像这样

https://process.filestackapi.com/AhTgLagciQByzXpFGRI0Az/resize=width:200/crop=d:[0,25,200,100]/https://i.stack.imgur.com/wPh0S.jpg

但重要的部分只是

resize=width:200/crop=d:[0,25,200,100]

https://i.stack.imgur.com/yefj6.jpg


不错的插件也许 - 但同样 - 一个很棒的服务(不,我没有报酬说这个;-)) - 我刚刚注册,这很酷
D
Dave Markle

您可以将 img 标签放在 div 标签中并同时执行这两种操作,但我建议您不要在浏览器中缩放图像。大多数时候它做得很糟糕,因为浏览器有非常简单的缩放算法。最好先在 Photoshop 或 ImageMagick 中进行缩放,然后将其漂亮漂亮地提供给客户。


R
Rob

我所做的是创建一个服务器端脚本,该脚本将在服务器端调整和裁剪图片的大小,以便通过互联网发送更少的数据。

这相当琐碎,但如果有人有兴趣,我可以挖掘并发布代码(asp.net)


CGI 可能是最便携的方法(和带宽效率),除非 OP 打算允许用户通过 Javascript 执行他们自己的调整大小和裁剪。
I
Igor Ivancha
<div class="crop">
    <img src="image.jpg"/>
</div>
.crop {
  width: 200px;
  height: 150px;
  overflow: hidden;
}
.crop img {
  width: 100%;
  /*Here you can use margins for accurate positioning of cropped image*/
}

s
stacksonstacksonstacks

如果您使用的是 Bootstrap,请尝试使用 { background-size: cover; } 作为 <div> 可能给 div 一个类说 <div class="example" style=url('../your_image.jpeg');> 所以它变成 div.example{ background-size: cover}


D
Dave Burton

我最近需要这样做。我想制作一个指向 NOAA 图表的缩略图链接。由于他们的图表可能随时更改,我希望我的缩略图随之更改。但是他们的图表有一个问题:它的顶部有一个巨大的白色边框,所以如果你只是缩放它来制作缩略图,你最终会在文档中出现多余的空白。

这是我解决它的方法:

http://sealevel.info/example_css_scale_and_crop.html

首先我需要做一点算术。来自 NOAA 的原始图像为 960 × 720 像素,但前 70 个像素是多余的白色边框区域。我需要一个 348 × 172 的缩略图,顶部没有额外的边框区域。这意味着原始图像的所需部分是 720 - 70 = 650 像素高。我需要将其缩小到 172 像素,即 172 / 650 = 26.5%。这意味着需要从缩放图像的顶部删除 70 = 19 行像素中的 26.5%。

所以…

设置高度 = 172 + 19 = 191 像素:高度 = 191 设置底部边距为 -19 像素(将图像缩短为 172 像素高): 边距底部:-19px 设置顶部位置为 -19 像素(移动图像向上,以便顶部 19 像素行溢出 & 被隐藏而不是底部):顶部:-19px

生成的 HTML 如下所示:

<a href="…" style="display:inline-block;overflow:hidden">
<img width=348 height=191 alt=""
style="border:0;position:relative;margin-bottom:-19px;top:-19px"
src="…"></a>

如您所见,我选择设置包含 标记的样式,但您也可以设置

T
Thellimist

您可以使用 Kodem 的 Image Resize Service。只需一个 http 调用,您就可以调整任何图像的大小。可以在浏览器中随意使用,也可以在您的生产应用程序中使用。

将图像上传到您喜欢的地方(S3、imgur 等)

将其插入您的专用 API url(来自我们的仪表板)


M
MrAni

您还可以使用名为 Croppie 的工具来裁剪图像...

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<link href="https://foliotek.github.io/Croppie/croppie.css" rel="stylesheet" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"> </script>
<script src="https://foliotek.github.io/Croppie/croppie.js"> </script>
<script src="https://foliotek.github.io/Croppie/bower_components/exif-js/exif.js"> </script>

<style>
    #page {
        background: #ffffff;
        padding: 20px;
        margin: 20px;
    }

    #demo-basic {
        width: 600px;
        height: 600px;
    }
</style>
</head>
<body>
<h1>Crop Image Demo</h1>
<input id="upload" type="file" />
<br />
<div id="page">
<div id="demo-basic"></div>
</div>

<input id="upload-result" type="button" value="Crop Image"/>
<br />
<img id="cropped-result" src=""/>

<script>
    var $uploadCrop;       

    $("#upload").on("change", function () { readFile(this); show(); });

    $("#upload-result").on("click", function (ev) {
        $uploadCrop.croppie("result", {
            type: "canvas",
            size: "viewport"
        }).then(function (resp) {
            $("#cropped-result").attr("src", resp);
        });
    });

    function show() {
        $uploadCrop = $("#demo-basic").croppie({
            viewport: { width: 100, height: 100 },
            boundary: { width: 300, height: 300 },
            enableResize: true,
            enableOrientation: true,
            mouseWheelZoom: 'ctrl',
            enableExif: true
        });
    }

    function readFile(input) {
        if (input.files && input.files[0]) {
            var reader = new FileReader();
        
            reader.onload = function (e) {
                $("#demo-basic").addClass("ready");
                $uploadCrop.croppie("bind", {
                    url: e.target.result
                }).then(function () {
                    console.log("jQuery bind complete");
                });
            
            }
        
            reader.readAsDataURL(input.files[0]);
        }
        else {
            alert("Sorry - you're browser doesn't support the FileReader API");
        }
    }
</script>
</body>
</html>