本文关键:阻止冒泡、canvas压缩、canvas裁剪、生成黑色图片。

最近项目需要在添加图片时实现裁剪功能,虽然 github 上开源的裁剪插件不少,试了好几个插件,在移动端体验好的寥寥无几。躺了几个坑,分别说一下。

好像是腾讯团队做的一个插件,网上推荐度还挺高的,但是我在上手测试的时候发现,一些问题:

不适配 pc 端滚轮缩放。

裁剪时无法缩小图片,只能放大。(这也是我放弃它的原因)

它依赖 transfrom.js 和 AlloyFinger ,源码看起来我比较难懂,所以就没继续深入研究。

本文着重讲的是这个,也是现在正在使用的,因为初步尝试来说样式操作等各方面体验都挺不错,就决定要把这个坑趟平。首先说说填了哪些坑:

修复触摸冒泡和滚动冒泡。

修复添加图片后,某些比例下图片小于裁剪框的问题。

优化添加图片后,根据裁剪框调整图片缩放。

修复iOS端有透明部分变黑图的问题。

未解决:旋转图片后,不会贴合裁剪框的问题。

下面来逐个解析

touch 冒泡、wheel 冒泡

这是最先发现的问题,裁剪图片过程中拖动图片,touch 事件冒泡使遮罩后的页面滚动并且阻塞了图片的移动。而在 pc 端测试时发现,同样问题发生在使用滚轮缩放图片的操作下。

其实解决办法也很简单,就是添加 e.stopPropagation() ,但实际上,查看源码发现在事件绑定上作者使用的 addEvent() 方法,所以没有办法使阻止冒泡生效(原因在 我另一篇文章 的开头有提到)。把该方法改成:

$(document).addEventListener( 'scroll', fun, {passive: false} )

必须传入 false 选项后 ,就可以正常阻止事件冒泡了。

图片放置后小于裁剪框

这是个小问题,但会导致下一个大问题。出现原因是,放置图片时,插件首先会计算图片宽高比与窗口宽高比的关系,决定以宽或高为标准缩放放置图片,设定图片宽高值,随后会进一步与裁剪框比较,而在这一步作者获取错误的宽高导致不能根据裁剪框调整图片,最终的效果就是图片只适应了窗口,而宽或高小于裁剪框的情况,把获取值修正即可。

其实如果图片完全贴着裁剪框挺丑的(特别是方形图配方形裁剪框),优化一些判断条件,使得图片可以比裁剪框大一圈,整个感觉好多了,也更好的表达了裁剪的意图。

iOS 端最终只获得了黑图

这个就是最大的坑了,有时候裁剪完之后,输出展示的是一张纯黑无内容的图片(其实就是一张透明图),坑就坑在一直找不到原因,只有 iOS 上会有概率出现,pc 端及 Android 则完全不会。后来发现规律后马上就解决了,现在尝试简单的解释一下原因:

裁剪原理:根据坐标及宽高截取当前 canvas 的图像然后生成一个新的 canvas 然后再输出成 base64 得到图片。

本质原因:在截取当前 canvas 时,某一个坐标 点在了 canvas 外,导致无法获取图像。

问题原因:图片的分辨率并不是整数(压缩,比例缩放等原因、甚至图片本身原因),比如 500 x 499.5,在 iOS 上识别的 500 x 500,当截取 canvas 时(500,500)这个点并不在 canvas 内导致获取不到。而其他设备上获取到图片的分辨率为 500 x 499 所以不存在这个问题。

解决办法:在源码截取当前 canvas 的方法中,定义起点和截取范围的参数中,向内补偿 1 个像素(+-1)来补偿 iOS 上可能出现的问题。

旋转后与裁剪框产生了距离

因为旋转时以图片中心为原点的,放大拉到一边后旋转,就会偏了。出现这个问题原因很简单,就是旋转后没有执行贴合边框的方法。但是由于执行这个方法所需的参数计算起来比较复杂,我就展示先放一放了。

摘要

base64 转文件

function dataURLtoFile(dataurl, filename) { //将base64转换为文件

var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],

bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);

while(n--){

u8arr[n] = bstr.charCodeAt(n);

}

return new File([u8arr], filename, {type:mime});

}

android 固定比例图片裁剪插件,移动端添加图片裁剪的坑相关推荐

  1. Android HorizontalScrollView 水平滑动 在listview上面动态添加图片

    Android HorizontalScrollView   水平滑动    listview 上动态添加图片 最近遇到了个 在listview展示广告的需要动态添加图片 如图: 使用了 horizo ...

  2. 批量下载图片的插件-免费自动下载图片的插件

    为什么需要批量下载图片的插件?现实生活中基本上每个人都会和图片照片打交道,当看到自己喜欢的图片都喜欢保存下来.而大多用户只知道通过鼠标右键的 "图片另存为" 将图片下载到本地.图片 ...

  3. PHP实现给视频加图片水印,怎么在视频画面上加图片?如何给视频添加自己的图片作为水印?视频添加图片水印的方法...

    今天就是周一啦,昨天周末大家有没有跟好友去玩呢~反正小编是跟同学聚会去了,聚会主题:胖.哈哈哈,不过小编可不跟他们一样只会长胖,小编可是瘦瘦瘦的呢,偷偷的告诉你们,小编减肥瘦了三十斤哦,嘻嘻.好啦,废 ...

  4. java web工程中如何添加图片_java web中如何添加图片

    java web中如何添加图片 对于java可视化界面插入背景图片只需要background-image:url(图片路径)就行,而对于web项目中,并非如此 效果如下: 我们就需要在jsp页面中写J ...

  5. Win11如何添加图片3D效果?Win11添加图片3D效果的方法

    ​Windows11系统为用户更新了很多丰富且有趣的功能,而为图片添加一个3D效果也是其中一个功能,该功能可以为用户的图片带来不一样的变化,但很多小伙伴不清楚要如何去添加,那么要如何操作呢?下面就和小 ...

  6. php 图片填充图片,PHP水印类,支持添加图片、文字、填充颜色区域的实现_php实例...

    下面小编就为大家带来一篇PHP水印类,支持添加图片.文字.填充颜色区域的实现.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧 *自己整理的一个水印类* 支持添加图片.文字 ...

  7. ios html富文本带图片,iOS 富文本文字添加图片

    如图:标题前面添加海外直邮和跨境保税,iOS最好使用富文本添加图片附件的方法 NSTextAttachment*textAttachment = [[NSTextAttachment alloc] i ...

  8. android 固定比例图片裁剪插件,如何在Android中裁剪不同比例的图像?

    匿名用户 将ImageView放置在ConstraintLayout中. 这将授予ImageView访问app:Layout_ConstraintDimensionRatiane的权限,您可以在其中指 ...

  9. android 固定底栏位置,电脑底端任务栏固定位置应该如何设置?在哪里设置?

    电脑底端任务栏固定位置应该如何设置?在哪里设置? 电脑下边的任务栏通常是固定在底端的,但是有很多小伙伴并不喜欢,今天我们就来教大家如何将其固定在电脑的其他位置~下面就是具体的过程啦~ 具体如下: 1. ...

最新文章

  1. exchange server 2003 错误处理
  2. docker运行mywebsql
  3. 日志 中文乱码、nacos 中文乱码、saltstack 中文乱码、docker中文乱码
  4. 服务器访问oracle数据库,Oracle数据库的访问——通过不同服务器名对数据库的访问...
  5. 应用在核电站DCS系统的代码自动生成工具ModelCoder
  6. Go中的三种排序方法
  7. 京东国际宣布国际超模刘雯担任品牌代言人
  8. 忠言多少有些逆耳,创业的九条真经
  9. 知道ip地址如何进入电脑_如何防止局域网电脑IP地址冲突
  10. Linux Shell变量
  11. 多台显示器图像拼接组成大屏幕是怎么实现的?
  12. 《会计学》简单的思维导图(第一版)
  13. 2018年第44周-scala入门-面向对象基础语法
  14. FastStone Capture——集截屏、滚动截图、录屏、图片编辑为一体轻量级截图软件
  15. 解决区块链三大问题的利器
  16. truncate()函数
  17. IT公司、软件公司资质(转)
  18. 0x41 数据结构进阶-并查集
  19. python表示三个数升序_编写程序,输入三个数,然后以升序显示_学小易找答案
  20. 程序员眼中的中国传统文化-王阳明《传习录》5

热门文章

  1. 网上预约挂号系统的设计与实现
  2. 如何评判一个企业是否需要实施erp系统?
  3. HoloLens原理分析和硬件拆解
  4. 《人月神话》,没有银弹
  5. java缓存框架zookepper_Zookeeper分布式开源框架
  6. android手机连接esp32视频
  7. Java计算10000天出生纪念日
  8. 用P、V操作解决进程同步问题的解题步骤
  9. 江苏工勤计算机高级工职称,事业单位专业技术职称与工勤岗高级工的区别
  10. 黑苹果 惠普笔记本电池补丁_笔记本的黑苹果之路