博客
关于我
canvas剪裁图片并上传,前端一步到位,无需用到后端
阅读量:400 次
发布时间:2019-03-05

本文共 826 字,大约阅读时间需要 2 分钟。

背景:

当前主流的图片剪裁实现方式主要有两种:一种是通过Flash操作,另一种是利用JavaScript和DOM操作。但现行的剪裁流程仍存在一些问题,例如需要先将图片上传到服务器,前后端需要多次交互,数据传输繁冗。

传统的剪裁实现方式显得有些低级了。我尝试利用Canvas技术来实现剪裁功能。通过对网上资源的研究,我发现虽然有Jcrop等类似插件存在,但它们的本质仍然是需要将图片上传到后台,最后由后端处理,与传统方式并无本质区别。

自主实现前端剪裁:

后来,我灵感一现,意识到Canvas可以存储Base64数据。基于此,我设计了一种新的剪裁流程。具体步骤如下:

  • 用户选择图片
  • 通过FileReader读取图片并转换为Base64编码
  • 创建一个包含原图的下层Canvas和一个用于显示剪裁区域的上层Canvas
  • 用户在上层Canvas中进行剪裁操作,包括拖动和缩放
  • 在保存剪裁时,生成对应比例的Base64数据,直接上传至后台
  • 实现细节:

  • 自定义剪裁比例和最小尺寸
    this._option.crop_min_width = 640;  this._option.crop_min_height = 640;
  • 自定义剪裁容器大小
    this._option.crop_box_width = 300;  this._option.crop_box_height = 200;
  • 实现拖动和区域大小调整
  • 为剪裁容器及其内部元素添加CSS属性
    -webkit-user-select:none;-moz-user-select:none;-o-user-select:none;user-select:none
  • 代码实现虽然不够规范,但已实现了基本需求。点击保存按钮,系统会生成按照原图比例的剪裁图片,并通过Base64编码直接上传至后台。

    默认要求用户选取640x640以上的图片,以确保剪裁后的图片质量。以下是该方案的Git地址,您可以拉取代码进行测试。

    转载地址:http://zhxzz.baihongyu.com/

    你可能感兴趣的文章
    NS3 IP首部校验和
    查看>>
    NSDateFormatter的替代方法
    查看>>
    NSError 的使用方法
    查看>>
    NSGA-Ⅲ源代码
    查看>>
    nsis 安装脚本示例(转)
    查看>>
    NSJSON的用法(oc系统自带的解析方法)
    查看>>
    nslookup 的基本知识与命令详解
    查看>>
    NSNumber与NSInteger的区别 -bei
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NSURLSession下载和断点续传
    查看>>
    NSUserdefault读书笔记
    查看>>
    NS图绘制工具推荐
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    NT symbols are incorrect, please fix symbols
    查看>>
    ntelliJ IDEA 报错:找不到包或者找不到符号
    查看>>
    NTFS文件权限管理实战
    查看>>
    ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>