广告
返回顶部
首页 > 资讯 > 精选 >图片上传及canvas压缩的示例分析
  • 352
分享到

图片上传及canvas压缩的示例分析

2023-06-09 10:06:21 352人浏览 薄情痞子
摘要

小编给大家分享一下图片上传及canvas压缩的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!我们通常在做图片上传的时候都会遇上这样的情况,一是后端接口限制

小编给大家分享一下图片上传及canvas压缩的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

我们通常在做图片上传的时候都会遇上这样的情况,一是后端接口限制上传图片的大小,或者是即使后端没有限制大小,因为图片太大在前端渲染时太慢,造成页面加载体验较差。因此我们很有必要对上传的图片进行压缩。

本文主要包括以下流程:

  • 用户通过input框选择图片

  • 使用FileReader进行图片预览

  • 将图片绘制到canvas画布上

  • 使用canvas画布的能力进行图片压缩

  • 将压缩后的Base64(DataURL)格式的数据转换成Blob对象进行上传

Input 标签来获取图片

通过设置input标签的type属性为file,来让用户可以选择文件,设置accept限制选择的文件类型,绑定onchange事件,来获取确认选择后的文件

<input type="file" accept="image/*" onchange="loadFile(event)"

FileReader

FileReader是什么,我们先来看看官方文档的介绍

FileReader 对象允许 WEB 应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 File 或 Blob 对象指定要读取的文件或数据。

FileReader常用的两个方法如下:

  • FileReader.onload:处理load事件。即该钩子在读取操作完成时触发,通过该钩子函数可以完成例如读取完图片后进行预览的操作,或读取完图片后对图片内容进行二次处理等操作。

  • FileReader.readAsDataURL:读取方法,并且读取完成后,result属性将返回Data URL格式(Base64 编码)的字符串,代表图片内容。

在图片上传中,我们可以通过readAsDataURL()方法进行了文件的读取,并且通过result属性拿到了图片的Base64(DataURL)格式的数据,然后通过该数据实现了图片预览的功能

<div class="container">  <input type="file" accept="image/*" onchange="loadFile(event)" /></div><script>  const loadFile = function (event) {    let file =  event.target.files[0]    const reader = new FileReader()    reader.onload = function () {      console.log(reader.result)      ...    }    reader.readAsDataURL(file)  }</script>

canvas 压缩图片

这是图片上传压缩的核心所在,我们先使用CanvasRenderinGContext2D.drawImage()方法将上传的图片文件在画布上绘制出来,再使用Canvas.toDataURL()将画布上的图片信息转换成base64(DataURL)格式的数据。

drawImage()

drawImage()方法在画布上绘制图像、画布或视频。drawImage()方法也能够绘制图像的某些部分,以及/或者增加或减少图像的尺寸。参数如下

  • img 规定要使用的图像、画布或视频。

  • sx 可选。开始剪切的 x 坐标位置。

  • sy 可选。开始剪切的 y 坐标位置。

  • swidth 可选。被剪切图像的宽度。

  • sheight 可选。被剪切图像的高度。

  • x 在画布上放置图像的 x 坐标位置。

  • y 在画布上放置图像的 y 坐标位置。

  • width 可选。要使用的图像的宽度。(伸展或缩小图像)

  • height 可选。要使用的图像的高度。(伸展或缩小图像)

var cas = document.querySelector('canvas')var ctx = cas.getContext('2d')// 先创建图片对象var img = new Image()img.src = './images/1.jpg'// 图片加载完之后img.onload = function () {  ctx.drawImage(img, 206, 111, 32, 38, 100, 100, 32, 38)}

Canvas.toDataURl()

Canvas.toDataURl()方法可以将canvas画布上的信息转换为base64(DataURL)格式的图像信息,纯字符的图片表示形式。该方法接收 2 个参数:

  • mimeType(可选): 表示需要转换的图像的mimeType类型。默认值是image/png,还可以是image/jpegimage/webp等。

  • quailty(可选):quality 表示转换的图片质量。范围是 0 到 1。图片的mimeType需要是image/jpeg或者image/webp,其他mimeType值无效。默认压缩质量是 0.92。

var canvas = document.createElement('canvas')canvas.toDataURL("image/jpeg" 0.8)

到这里,我们先来上 canvas 压缩图片的代码

function compress(base64, quality, mimeType) {  let canvas = document.createElement('canvas')  let img = document.createElement('img')  img.crossOrigin = 'anonymous'  return new Promise((resolve, reject) => {    img.src = base64    img.onload = () => {      let targetWidth, targetHeight      if (img.width > MAX_WIDTH) {        targetWidth = MAX_WIDTH        targetHeight = (img.height * MAX_WIDTH) / img.width      } else {        targetWidth = img.width        targetHeight = img.height      }      canvas.width = targetWidth      canvas.height = targetHeight      let ctx = canvas.getContext('2d')      ctx.clearRect(0, 0, targetWidth, targetHeight) // 清除画布      ctx.drawImage(img, 0, 0, canvas.width, canvas.height)      let imageData = canvas.toDataURL(mimeType, quality / 100)      resolve(imageData)    }  })}

将 base64 转化为文件

  • 通过window.atobbase-64字符串解码为binaryString(二进制文本);

  • binaryString构造为multipart/fORM-data格式;

  • Uint8Arraymultipart格式的二进制文本转换为ArrayBuffer

function dataUrlToBlob(base64, mimeType) {  let bytes = window.atob(base64.split(',')[1])  let ab = new ArrayBuffer(bytes.length)  let ia = new Uint8Array(ab)  for (let i = 0; i < bytes.length; i++) {    ia[i] = bytes.charCodeAt(i)  }  return new Blob([ab], { type: mimeType })}

将图片上传到服务端

创建一个FormData,把blobappend 到FormData里面请求服务端接口,提交图片

function uploadFile(url, blob) {  let formData = new FormData()  let request = new XMLHttpRequest()  formData.append('image', blob)  request.open('POST', url, true)  request.send(formData)}

ps:在实际开发中,我们要不要把图片转化为FormData形式上传到服务端,这就看具体的业务需要了。我们可以上图片上传到腾讯云,直接返回一个'https.xxx.jgp'的图片 url 用于上传。

以上是“图片上传及canvas压缩的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 图片上传及canvas压缩的示例分析

本文链接: https://www.lsjlt.com/news/255684.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 图片上传及canvas压缩的示例分析
    小编给大家分享一下图片上传及canvas压缩的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!我们通常在做图片上传的时候都会遇上这样的情况,一是后端接口限制...
    99+
    2023-06-09
  • electron-vue图片压缩的示例分析
    这篇文章给大家分享的是有关electron-vue图片压缩的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 最近用electron-vue(E...
    99+
    2022-10-19
  • JS移动端/H5同时选择多张图片上传并使用canvas压缩图片的示例分析
    小编给大家分享一下JS移动端/H5同时选择多张图片上传并使用canvas压缩图片的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解...
    99+
    2022-10-19
  • Vue使用canvas实现图片压缩上传
    本文实例为大家分享了Vue使用canvas实现图片压缩上传的具体代码,供大家参考,具体内容如下 场景:如用户头像等 对于大尺寸图片的上传,在前端进行压缩除了省流量外,最大的意义是极大...
    99+
    2022-11-12
  • 使用canvas怎么对图片压缩上传
    使用canvas怎么对图片压缩上传?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。首先得有一个上传按钮。<input type="file"&...
    99+
    2023-06-09
  • ajax如何上传图片到PHP并压缩图片显示
    本篇内容主要讲解“ajax如何上传图片到PHP并压缩图片显示”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ajax如何上传图片到PHP并压缩图片显示”吧!HTML代码<div i...
    99+
    2023-06-08
  • PHP压缩与解压缩类的示例分析
    这篇文章给大家分享的是有关PHP压缩与解压缩类的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。PHP压缩与解压缩类PclZip是一个很强大的压缩与解压缩zip文件的PHP...
    99+
    2022-10-19
  • html5中canvas移动浏览器上如何实现图片压缩上传
    这篇文章主要介绍html5中canvas移动浏览器上如何实现图片压缩上传,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、<input type="file"...
    99+
    2022-10-19
  • 如何通过Canvas及File API缩放并上传图片
    这篇文章主要讲解了“如何通过Canvas及File API缩放并上传图片”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何通过Canvas及File API...
    99+
    2022-10-19
  • 怎么通过Canvas及File API缩放并上传图片
    本文小编为大家详细介绍“怎么通过Canvas及File API缩放并上传图片”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么通过Canvas及File API缩放并上传图片”文章能帮助大家解决疑惑,下面...
    99+
    2022-10-19
  • 怎么用html5的canvas移动浏览器实现图片压缩上传
    这篇文章主要介绍“怎么用html5的canvas移动浏览器实现图片压缩上传”,在日常操作中,相信很多人在怎么用html5的canvas移动浏览器实现图片压缩上传问题上存在疑惑,小编查阅了各式资料,整理出简单...
    99+
    2022-10-19
  • JS+HTML图片显示Canvas压缩功能的方法
    这篇文章主要介绍了JS+HTML图片显示Canvas压缩功能的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一.选择图片并显示<!...
    99+
    2022-10-19
  • canvas导出图片跨域的示例分析
    这篇文章将为大家详细讲解有关canvas导出图片跨域的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:Uncaught DOMException: Failed to execute &#...
    99+
    2023-06-09
  • Redis压缩列表的示例分析
    这篇文章主要介绍了Redis压缩列表的示例分析,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。此篇文章是主要介绍Redis在数据存储方面的其中一种...
    99+
    2022-10-18
  • android文件上传示例分享(android图片上传)
    主要思路是调用系统文件管理器或者其他媒体采集资源来获取要上传的文件,然后将文件的上传进度实时展示到进度条中。 主Activity 代码如下:package com.guoto...
    99+
    2022-06-06
    示例 Android
  • CSS压缩与CSS代码压缩还原的示例分析
    这篇文章将为大家详细讲解有关CSS压缩与CSS代码压缩还原的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 紧缩后的CSS代码如何快捷排版好以便于再编纂在批改。...
    99+
    2022-10-19
  • HTML5中Canvas实现图片缩放、翻转、颜色渐变的示例分析
    这篇文章将为大家详细讲解有关HTML5中Canvas实现图片缩放、翻转、颜色渐变的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。翻转、移动、平移、放大、缩小XML/HTML Code复制内容到剪贴...
    99+
    2023-06-09
  • Linux归档和压缩的示例分析
    这篇文章主要介绍了Linux归档和压缩的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在 Linux 中,学会对文件或目录进行打包(归档)和压缩,是每个初学者的基本技...
    99+
    2023-06-27
  • android递归压缩上传多张图片到七牛的实例代码
    最近遇到这样一个需求:要做一个仿微信朋友圈的功能,要求上传最多九张图到七牛。七牛有上传图片的接口,但是每次只能上传一张。如果是九张图片一齐上传,使用for循环的话肯定不行的,很容易出错。因为上传七牛的动作是在子线程完成的,for循环是在主线...
    99+
    2023-05-30
    android 七牛 上传
  • 基于Ajax中formData图片和数据上传的示例分析
    这篇文章主要为大家展示了“基于Ajax中formData图片和数据上传的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“基于Ajax中formData图片...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作