在 HTML5 中是否有使用“最近邻”重采样调整图像大小的方法?


调整图像大小是一项繁琐的任务,因为它会影响网站的性能。对于在线照片来说,大小非常重要。通常,用户更喜欢小尺寸的图像,因为即使在中等互联网连接的情况下,加载时间也更短。如果图像太大,您的页面可能会在一段时间内无响应。具有统一大小图像的网页更具吸引力和美观性。因此,将适当大小的图像上传到您的网站至关重要。

调整大小 VS 重采样

在不更改图像像素尺寸的情况下,更改要打印的图像的大小(即高度和宽度)称为调整大小。换句话说,您重新分配原始像素的数量以适应图像中较小或较大的空间。

示例

<img src= “example.jpg” height= “250” width = “400”> In CSS, img { width: 500px, height: 360px }

注意 - 为了获得响应式图像,width 的值应设置为100%,而height 的值应设置为auto

通过在图像中添加或删除像素来物理更改图像文件大小称为图像重采样。可以通过更改图像分辨率以与输出媒体类型(即屏幕或打印)对齐来实现。

添加图像的像素数量称为上采样,而删除图像的像素数量称为下采样

示例

假设一个图像的大小为 640* 785 像素。如果您将其更改为 700 * 785 像素,则称为上采样。

图像重采样的类型

在本节中,让我们看一下图像重采样的类型

  • 最近邻 - 它使用最接近的输入像素来分配像素值。例如:模糊的上采样。

  • 双线性插值 - 它使用四个最近像素的灰度值,使用双线性函数找出图像的新像素值。

  • 三次卷积 - 它基于围绕图像每个新像素的 4*4 或 8*8 矩阵的算法。

最近邻重采样

它是用于图像重采样的最简单且常用的技术。

示例

上图显示了图像的 3*3 矩阵可以插值到 6*6 矩阵。所有新值都与输入值最接近。

方法 1:使用 HTML5

您可以使用 HTML5 canvas 以最近邻重采样调整图像大小。

示例

<img src= “example.jpg” height= “250” width = “400”> const x = document.createElement (‘canvas’).getContext(‘ 2d’); x.drawImage (img, 0,0 ) ; var pic = x.getImageData( 0, 0, img.height, img.width) .data; for (let i = 0; i < img.width; ++i ){ for (let j = 0; j< img.height; ++j){ let a = (j*img.width + i)*4; let r = pic [i]; let g = pic[i+1]; let b = pic[i+2]; let a = pic[i+3]; ctx2.fillStyle ="rgba("+r+","+g+","+b+","+(a/255) +”)"; ctx2.fillRect(i*zoom,j*zoom,zoom,zoom); } }

这里,

x 是一个用于创建离屏画布的变量。

.drawImage 方法用于在当前画布上绘制图像或画布。

语法

drawImage (cropping image, X- coordinate of source, Y- coordinate of source, source width, source height, X- coordinate of destination image, Y coordinate of destination image, destion image’s width, destination image’s height).  

示例

demo.drawImage ( img, 12, 10, 300, 250, 0, 0, 100, 200)

.getImageData() 用于返回画布一部分的数据。在我们的代码中,它用于获取图像的原始像素尺寸。

语法

getImageData(x, y, w, h)  

参数

  • x - 需要获取数据的框左上角的 x 坐标

  • y - 需要获取数据的框左上角的 y 坐标。

  • w - 框的宽度

  • h - 框的高度

示例

demo.getImageData( 0, 23, 100, 200)

for 循环 - 用于遍历图像的高度和宽度,然后将放大后的像素网格绘制到不同的画布上下文中。

ij 变量 - 用于为每个像素生成唯一的 RGB 颜色。

.fillstyle - 用于设置画布中一部分的颜色。

a - 指的是 alpha,它指定颜色的不透明度。

语法

object.fillStyle= rgba() 

示例

demo.fillStyle = rgba (255, 164, 0, 1);

.fillRect() - 这是一个用于绘制矩形或框的方法,该方法根据指定的 fillstyle 填充。

语法

fillRect(x, y, w, h)

参数

  • x - 框起始点的 x 坐标

  • y - 框起始点的 y 坐标。

  • w - 框的宽度

  • h - 框的高度

方法 2:图像渲染

渲染图像是一个用于生成用于图像缩放的算法类型的过程。它是一个应用于元素本身的 CSS 属性。

语法

image-rendering: value;

auto、pixelated、inherit、initial、revert、unset、revert-layer、crisp-edges。

示例

.demoImage{ -ms-interpolation-mode: nearest neighbour; image- rendering: pixelated; }

ms-interpolation-mode 属性允许您设置用于图像缩放的插值算法类型。

Pixelated - 如果使用最近邻算法放大图像,则它使图像能够由更大的像素尺寸组成。

结论

在您的网站中拥有轻量级且加载速度快的图像可以增强用户体验。它吸引用户访问您的网站。此外,搜索引擎(如 Google、Microsoft Edge 等)也青睐此类网站,从而提高您网站的排名。因此,拥有具有适当分辨率的图像非常重要。

更新于: 2022年10月13日

2K+ 次浏览

开启您的 职业生涯

通过完成课程获得认证

开始学习
广告