位置: 编程技术 - 正文

基于Vue的移动端图片裁剪组件功能(vue做移动端)

编辑:rootadmin

推荐整理分享基于Vue的移动端图片裁剪组件功能(vue做移动端),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue移动端案例,vue如何做移动端适配,vue做移动端适配最佳解决方案,亲测有效,vue3移动端,vue做移动端,vue移动端项目实例,基于vue的移动端ui框架,基于vue的移动端框架,内容如对您有帮助,希望把文章链接给更多的朋友!

最近项目上要做一个车牌识别的功能。本来以为很简单,只需要将图片扔给后台就可以了,但是经测试后识别率只有-%。因此产品建议拍摄图片后,可以对图片进行拖拽和缩放,然后裁剪车牌部分上传给后台来提高识别率。刚开始的话还是百度了一下看看有没有现成的组件,但是找来找去都没有找到一个合适的,还好这个功能不是很着急,因此自己周末就在家里研究一下。

  Demo地址:  下载地址:  因为移动端是用vue,所以就写成了一个vue组件,下面就说说自己的一些实现思路(本人技术有限,各位大神请体谅。另外展示的代码不一定是某个功能的完整代码),先看看效果: 

 

  一、组件的初始化参数

  1、图片img(url或者base data-url)

  2、截图的宽clipperImgWidth

  3、截图的高clipperImgHeight

  二、布局

  在Z轴方向看主要是由4层组成。第1层是一个占满整个容器的canvas(称cCanvas);第2层是一个有透明度的遮罩层;第3层是裁剪的区域(示例图中的白色方框),里面包含一个与裁剪区域大小相等的canvas(称pCanvas);第4层是一个透明层gesture-mask,用作绑定touchstart,touchmove,touchend事件。其中两个canvas都会加载同一张图片,只是起始坐标不一样。为什么需要两个canvas?因为想做出当手指离开屏幕时,裁剪区域外的部分表面会有一个遮罩层的效果,这样能突出裁剪区域的内容。

  三、初始化canvas

  canvas绘制的图片在hdpi显示屏上会出现模糊,具体原因这里不作分析,可以参考下这里。我这里的做法是让canvas的width与height为其css width/height的devicePixelRatio倍,以及调用canvas api时所传入的参数都要乘以window.devicePixelRatio。最后还要记录一下两个canvas坐标原点的x, y差值(originXDiff与originYDiff)。如下

  四、加载图片

  加载图片比较简单,首先是创建一个Image对象并监听器onload事件(因为加载的图片有可能是跨域的,因此要设置其crossOrigin属性为Anonymous,然后服务器上要设置Access-Control-Allow-Origin响应头)。加载的图片如果宽高大于容器的宽高,要对其进行缩小处理。最后垂直水平居中显示()(这里注意的是要保存图片绘制前的宽高值,因为日后缩放图片是以该值为基础再乘以缩放倍率,这里取imgStartWidth,imgStartHeight)如下

   五、绘制图片

  下面的_drawImage有四个参数,分别是图片对应cCanvas的x,y坐标以及图片目前的宽高w,h。函数首先会清空两个canvas的内容,方法是重新设置canvas的宽高。然后更新组件实例中对应的值,最后再调用两个canvas的drawImage去绘制图片。对于pCanvas来说,其绘制的图片坐标值为x,y减去对应的originXDiff与originYDiff(其实相当于切换坐标系显示而已,因此只需要减去两个坐标系原点的x,y差值即可)。看看代码

   六、移动图片

  移动图片实现非常简单,首先给gesture-mask绑定touchstart,touchmove,touchend事件,下面分别介绍这三个事件的内容

  首先定义四个变量scx, scy(手指的起始坐标),iX,iY(图片目前的坐标,相对于cCanvas)。

基于Vue的移动端图片裁剪组件功能(vue做移动端)

  1、touchstart

    方法很简单,就是获取touches[0]的pageX,pageY来更新scx与scy以及更新iX与iY

  2、touchmove

    获取touches[0]的pageX,声明变量f1x存放,移动后的x坐标等于iX + f1x - scx,y坐标同理,最后调用_drawImage来更新图片。

  看看代码吧

   七、缩放图片(这里不作特别说明的坐标都是相对于cCanvas坐标系)

  绘制缩放后的图片无非需要4个参数,缩放后图片左上角的坐标以及宽高。求宽高相对好办,宽高等于imgStartWidth * 缩放比率与imgstartHeight * 缩放倍率(imgStartWidth ,imgstartHeight 上文第四节有提到)。接下来就是求缩放倍率的问题了,首先在touchstart事件上求取两手指间的距离d1;然后在touchmove事件上继续求取两手指间的距离d2,当前缩放倍率= 初始缩放倍率 + (d2-d1) / 步长(例如每px算0.1),touchend事件上让初始缩放倍率=当前缩放倍率。

  至于如何求取缩放后图片左上角的坐标值,在草稿纸上画来画去,画了很久......终于有点眉目。首先要找到一个缩放中心(这里做法是取双指的中点坐标,但是这个坐标必须要位于图片上,如果不在图片上,则取图片上离该中点坐标最近的点),然后存在下面这个等式

  (缩放中心x坐标 - 缩放后图片左上角x坐标)/ 缩放后图片的宽度 = (缩放中心x坐标 - 缩放前图片左上角x坐标)/ 缩放前图片的宽度;(y坐标同理)

  接下来看看下面这个例子(在visio找了很久都没有画坐标系的功能,所以只能手工画了)

  

  绿色框是一张*5的图片,蓝色框是宽高放大两倍后的图片*,根据上面的公式推算的x2 = sx - w2(sx - x1) / w1,y2 = sy - h2(sy - y1) / h1。

  坚持...继续看看代码吧

  说明一下fingers是干嘛的,是用来记录当前有多少只手指在屏幕上触摸。可能会出现这种情况,双指缩放后,其中一只手指移出显示屏,而另外一个手指在显示屏上移动。针对这种情况,要在touchend事件上根据e.changedTouches来移除fingers里已经离开显示屏的finger,如果此时fingers里只剩下一个finger,则更新scx,scy,iX,iY为移动图片做初始化准备。

  八、裁剪图片

  这里很简单,就调用pCanvas的toDataURL方法就可以了

  总结

  上面只是列出了一些自己认为比较关键的点, 如果有兴趣的,可以到我的github上下载源码看看。

以上所述是小编给大家介绍的基于Vue的移动端图片裁剪组件功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

基于vue2实现上拉加载功能 本文实例为大家分享了vue2实现上拉加载展示的具体代码,供大家参考,具体内容如下因为我们项目中,还用了swiper。很多都是滑动切换的,但是又得上

Vue2仿淘宝实现省市区三级联动 三级联动,随着越来越多的审美,出现了很多种,好多公司都仿着淘宝的三级联动,好看时尚,so我们公司也一样……为了贴代码方便,我把写在data里

vue2实现数据请求显示loading图 一般项目中,有时候会要求,你在数据请求的时候显示一张gif图片,然后数据加载完后,消失。这个,一般只需要在封装的axios中写入js事件即可。当然

标签: vue做移动端

本文链接地址:https://www.jiuchutong.com/biancheng/378916.html 转载请保留说明!

上一篇:基于Vue框架vux组件库实现上拉刷新功能(基于vue的ui框架)

下一篇:基于vue2实现上拉加载功能(vue2.x)

  • 公司收到劳务发票怎么申报个税
  • 双定户经营所得用申报吗
  • 应付账款暂估款的会计分录
  • 一般纳税人必须开13个点吗
  • 盈余公积是否必要交税
  • 服务业按什么结算工资
  • 开的税票必须过期怎么办
  • 车险会计分录处理怎么写
  • 成品盘盈盘亏的会计分录
  • 海关废品回收
  • 将自产产品赠送他人
  • 在筹建期间的费用属于什么
  • 服务类收入
  • 纳税人取得不动产进项税额怎么抵扣
  • 开票资料电话可以查到吗
  • 小微企业所得税税率多少
  • 离职补偿金要交个税的例子
  • 设备定金计入哪个科目
  • 非金融企业向金融企业借款的利息
  • 委托代销售应确认什么
  • 自然人独资属于什么经济性质
  • 孕妇可以喝蜂蜜水吗?
  • 入账成本包括增值税税额吗
  • windows为什么从7开始
  • 以前年度多计提的附加税怎么冲回
  • 支付货款的流程
  • php7.3安装
  • PHP:zip_entry_compressionmethod()的用法_Zip函数
  • 纳税人跨县(市、区)提供建筑服务,应向建筑服务发生地
  • framework启动
  • Yii2超好用的日期和时间组件(值得收藏)
  • 拥有自我意识的动物有哪些
  • 广告费与业务宣传费不超过当年销售收入
  • 使用筷子就餐会不会传染乙肝病毒
  • 小微企业认定标准时间
  • 稿费支付方式怎么填
  • 外贸进出口企业注册资金
  • 延期缴纳税款的问题
  • 增值税一般纳税人可以开普票吗
  • 织梦如何使用
  • mysql5.7.23安装配置教程
  • 织梦模板首页logo修改
  • 企业投资股票收益怎么交税
  • 规模以上企业纳税要求
  • 银行存款如何做到4个点
  • 开一般户需要开户许可证吗
  • 运输费抵扣进项税怎么算
  • 专利权的入账价值包括资本化支出吗
  • 福州锦元房地产开发有限
  • 红冲凭证怎么做分录
  • 收到公众号消息提醒
  • 哪几种情况涉及到进项税额的转出
  • 经营性应付项目减少对经营活动现金
  • 管理会计的职能作用是
  • 年初建账考虑要点有哪些
  • 工业企业应收账款减少原因分析
  • win2016 ntp
  • 新买的苹果电脑没有电
  • 电脑系统安装流程
  • 重装系统的简写
  • 获取linuxip
  • 电脑win7在哪
  • fciv.exe
  • win8metro版桌面安卓下载
  • win8怎样恢复系统
  • win7系统每次关机都安装更新
  • webpack-loader
  • node.js动态网页
  • node.js加密
  • css滑动门技术的步骤
  • jquery开发
  • 安卓手机wifi界面
  • python3正则
  • python科学计算基础教程
  • jquery dom对象
  • staticlayout 换行
  • 河南商丘医疗保险在微信上怎么交
  • 拆迁户契税减免政策文件
  • 获得感幸福感还有什么
  • 在珠海可以做什么生意
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设