欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

发布时间:2021-01-12  

SimpleCrop 目前是 全网唯一 支持裁剪图片任意角度旋转、交互体验 媲美原生客户端 的 全平台 图片裁剪组件。

项目地址: github.com/newbieYoung… 。

特性及优势

和目前流行的图片裁剪组件相比,其优势在于以下几点:

裁剪图片支持任意角度旋转;

支持 Script 标签、微信小程序、React、Vue 等多种开发模式;

支持移动和 PC 设备;

支持边界判断、当裁剪框里出现空白时,图片自动吸附至完全填满裁剪框;

移动端缩放以双指中心为基准点;

交互体验媲美原生客户端。

示例 微信小程序示例

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

移动端示例

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

左侧是 IOS 系统相册中原生的图片裁剪功能,右侧为 SimpleCrop 移动端示例。

可以扫描二维码体验:

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

或者访问以下链接:

newbieyoung.github.io/Simple-Crop…

PC 示例

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

链接如下:

newbieyoung.github.io/Simple-Crop…

关键实现

要实现 任意角度旋转 、 双指中心缩放 、 边界判断 、 自动吸附 等功能,关键点如下:

1、屏幕坐标系和变换基准点

在裁剪图片场景中,存在两个坐标系,其一是裁剪图片所代表的实际尺寸坐标系,其二是裁剪框显示到屏幕上所代表的屏幕坐标系;后续进行 transform 变换计算和位置判断时,为了计算方便,需要把裁剪图片的尺寸以及位置从实际坐标系转换为屏幕坐标系。另外当对裁剪图片进行 transform 变换时,变换基准点默认为其中心点,对应 CSS 的 transform-origin 为 50% 50%。

2、获取实时坐标

首先需要实时获取裁剪图片进行 CSS Transform 变换后的新坐标,只有在实时获取变换后的新坐标的前提下才能结合裁剪框坐标进行越界、吸附等判断;

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

在计算 CSS Transform 变换后的新坐标时需要注意选取的屏幕坐标系和 CSS Transform 坐标系的差别,比如示例中以黑色边框中心为坐标原点,水平向左为 X 轴正方向,垂直向上为 Y 轴正方向;但是 CSS Transform 的坐标系垂直向下为 Y 轴正方向和上述规定的坐标系 Y 轴正方向是相反的,因此在获取 CSS Transform 变换矩阵之后求实时坐标时还需要进行镜像变换。

详细计算过程可以查看 CSS3 2D Transform Matrix 。

3、旋转适配缩放

裁剪图片任意角度旋转时需要进行适当的放大才能保证裁剪框不超出,因此就需要先计算裁剪框哪些点超出,然后根据超出的点计算刚好包含的放大倍数。

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

当两个矩形位置关系任意变换时计算相互之间有哪些点超出有两种方案:

其一:

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

图中左侧红色矩形代表裁剪图片,黑色矩形代表裁剪框,如图所示裁剪框顶点 A 超出了裁剪图片。

连接矩形四个顶点和判断点,然后计算四条连线之间的夹角,如果夹角之和小于 360 度,那么该判断点在矩形外;反之如果夹角之和等于 360 度,那么该判断点在矩形内。

a1 + a2 + a3 + a4 < 360 b1 + b2 + b3 + b4 = 360 复制代码

其二:

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

图中黑色矩形表示裁剪图片,点 A 表示裁剪框中超出裁剪图片的某个顶点。

连接矩形中心点和判断点,然后计算中心点和判断点向量在矩形边框向量上的投影长度(L1、L2),只要两个投影长度中有任意投影长度大于其投影边框长度(H1、H2)的一半即说明该点在矩形外。

另外还可以根据投影长度和其投影边框长度的比例计算出矩形恰好包含该点的放大系数,也就是示例图中的 S 变量。

最后旋转图片时除了要进行适当的放大,保证裁剪框不超出以外,还可以在裁剪图片中心点没有变动时进行适当的缩小,去掉多余间隙,进一步提升交互体验。

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

缩小系数的计算原理和放大系数的计算原理类似,均是连接判断点和中心点,然后根据边框投影长度计算。

全平台(Vue、React、微信小程序)任意角度旋转 图片裁剪组件 ...

大矩形为裁剪图片,小矩形表示裁剪框,O 表示裁剪图片中心点。

4、双指中心位移