0

我正在尝试缩小 inage 以适应大于设置的最大宽度和高度的 div 容器。我有下面的代码,它获取图像的宽度和高度以及允许的最大尺寸。

这是我的深度,它在下面加载的图像是 662x599。宽度大于允许的最大值,所以我需要它正确缩小并放置到 div 的中心。

var max_width = 713;
var max_height = 550;

var img = new Image();
img.onload = function() {
    img.width = this.width;
    img.height = this.height;
}
img.src = 'files.jpg';

下面是一个我手动调整图像大小的示例,它看起来不错,可以为您提供一个粗略的示例,说明它应该是什么样子。我打算使用样式“顶部”和“左侧”将图像放置在 div 的中心。

<img style="width: 613px; height: 550px; top: 0px; left: 50px;" src="files.jpg">

任何帮助都会非常感谢。

4

2 回答 2

7

这是计算width, height, top,的代码left

// max_width  = 713
// max_height = 550
// img.width  = 662
// img.height = 599

scale_width = max_width / img.width;
scale_height = max_height / img.height;

scale = Math.min(scale_width, scale_height);

width = img.width * scale;  // 608
height = img.height * scale;  // 550

left = (max_width - width)/2; // 52
top = (max_height - height)/2;  // 0
于 2013-05-19T20:23:45.867 回答
0

为什么你甚至需要 JavaScript?只需将max-width图像上的 设置为与包含的匹配div(即 100%)。

http://jsfiddle.net/Pp7Rg/1/

<div>
    <img src="https://www.google.com/url?q=http://www.photoinpixel.com/mypicture/persian-cat-hd-wallpaper.jpg&ei=dTWZUYHKOoqkiQLto4GYAw&sa=X&oi=unauthorizedredirect&ct=targetlink&ust=1368996989961871&usg=AFQjCNHdsjijJ2oeKrUuvZRMFUuIRxydtg"/>
</div>

div {
    width: 500px;
}

img {
    max-width: 100%;
}
于 2013-05-19T20:28:24.743 回答