当前位置: 首页 > 建站教程

怎么使用Canvas drawImage方法实现图片压缩

时间:2026-01-28 13:49:18

使用Canvas的drawImage方法可以实现图片的压缩。下面是一个简单的示例代码:

// 获取原始的图片对象var img = new Image();img.src = '原始图片路径';// 创建一个Canvas元素var canvas = document.createElement('canvas');var ctx = canvas.getContext('2d');// 设置Canvas的大小为压缩后的尺寸var maxWidth = 200;var maxHeight = 200;var ratio = 1;if (img.width > maxWidth || img.height > maxHeight) {ratio = Math.min(maxWidth / img.width, maxHeight / img.height);}canvas.width = img.width * ratio;canvas.height = img.height * ratio;// 在Canvas上绘制压缩后的图片ctx.drawImage(img, 0, 0, img.width, img.height, 0, 0, canvas.width, canvas.height);// 将Canvas转换为压缩后的图片数据var compressedImage = canvas.toDataURL('image/jpeg', 0.7);// 将压缩后的图片显示在页面上var compressedImgElement = document.createElement('img');compressedImgElement.src = compressedImage;document.body.appendChild(compressedImgElement);

在上面的代码中,首先创建一个原始的图片对象,然后创建一个Canvas元素,并设置Canvas的大小为压缩后的尺寸。接着使用drawImage方法在Canvas上绘制压缩后的图片,最后将Canvas转换为压缩后的图片数据,并将其显示在页面上。


上一篇:java collections.sort的用法是什么
下一篇:laravel分库分表怎么实现
Canvas
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素