if (移动后的距离fw小于或等于1的话) { 移动后的cropOffsertX = 1; } else if ((移动后的距离 + 裁剪区域的宽度) > 图片的宽度的话) { // 说明移动的裁剪区域越界了,那么就让裁剪区处于中间的位置 移动后的cropOffsertX = 图片的宽度 - 裁剪区的宽度 - 1; }
如下图所示:
else { 移动后的cropOffsertX = fw; } 同理 if (移动后的距离fh小于或等于1的话) { 移动后的cropOffsertY = 1; } else if ((移动后的距离 + 裁剪区域的高度) > 图片的高度的话) { // 说明移动的裁剪区域越界了,那么就让裁剪区处于中间的位置 移动后的cropOffsertY = 图片的高度 - 裁剪区的高度 - 1; } else { 移动后的cropOffsertY = fh; }
8. 自动截图操作
代码的基本原理是:看组件是否传递了 autoCropWidth 和 autoCropHeight, 如果传递了该参数的宽度和高度的话,那么使用该参数的值,
如果没有传递的话,或者说该宽度和高度的值都为0的话,那么截取的宽度和高度就是图片的宽度和高度的80%;如果传递的宽度w和高度h大于图片的
本身的宽度或高度的话,那么宽度或高度的值就是图片的本身的宽度和高度的值。
如果传递了固定比例的话,那么高度的计算是根据宽度的比例来计算出来的。计算方式还是之前一样的:如下:
w fixedNumber[0] ------------- = --------------- h fixedNumber[1]
因此 h = w / this.fixedNumber[0] * this.fixedNumber[1]
如果高度大于图片的高度的话,那么高度就是等于图片的高度,然后根据现在的高度重新计算宽度;
代码如下:
// 如果比例之后 高度大于h if (h > this.h) { h = this.h w = h / this.fixedNumber[1] * this.fixedNumber[0] }
自动截图的主要代码如下:
var w = this.autoCropWidth var h = this.autoCropHeight if (w === 0 || h === 0) { w = this.w * 0.8 h = this.h * 0.8 } w = w > this.w ? this.w : w h = h > this.h ? this.h : h if (this.fixed) { h = w / this.fixedNumber[0] * this.fixedNumber[1] } // 如果比例之后 高度大于h if (h > this.h) { h = this.h w = h / this.fixedNumber[1] * this.fixedNumber[0] }
github的源码--PC端
总结
以上所述是小编给大家介绍的Vue-cropper 图片裁剪的基本原理及思路讲解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对黑区网络网站的支持!