博客
关于我
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/

    你可能感兴趣的文章
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>
    OAuth2.0四种模式的详解
    查看>>
    OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
    查看>>
    oauth2登录认证之SpringSecurity源码分析
    查看>>
    OAuth2:项目演示-模拟微信授权登录京东
    查看>>
    OA系统多少钱?OA办公系统中的价格选型
    查看>>
    OA系统选型:选择好的工作流引擎
    查看>>
    OA让企业业务流程管理科学有“据”
    查看>>
    OA项目之会议通知(查询&是否参会&反馈详情)
    查看>>
    Vue.js 学习总结(13)—— Vue3 version 计数介绍
    查看>>
    OA项目之我的会议(会议排座&送审)
    查看>>
    OA项目之我的会议(查询)
    查看>>
    OA项目之我的审批(会议查询&会议签字)
    查看>>