canvas 的宽高你是知道的,对吧? image 的宽高你可以获取到,对吧? aspectFill 就是保持纵横比、完全显示出来,那就说明 image 要缩小或拉伸到和 canvas 一样的宽或高,且缩放比例相同。 运用小学数学知识,问:两个长方形 A 和 B 重叠放置,在什么条件下 B 能完全在 A 内部?答:B 的宽、高两者最大值,要小于 A 的宽、高两者最小值。 那么 image 实际要绘制时的缩放比例就是 r = Math.min(canvas.width, canvas.height) / Math.max(image.width, image.height),实际要绘制的图像宽就是 w = r * image.width、高就是 h = r * image.height。 剩下的不用教了吧?
canvas 的宽高你是知道的,对吧?
image 的宽高你可以获取到,对吧?
aspectFill
就是保持纵横比、完全显示出来,那就说明 image 要缩小或拉伸到和 canvas 一样的宽或高,且缩放比例相同。运用小学数学知识,问:两个长方形 A 和 B 重叠放置,在什么条件下 B 能完全在 A 内部?答:B 的宽、高两者最大值,要小于 A 的宽、高两者最小值。
那么 image 实际要绘制时的缩放比例就是
r = Math.min(canvas.width, canvas.height) / Math.max(image.width, image.height)
,实际要绘制的图像宽就是w = r * image.width
、高就是h = r * image.height
。剩下的不用教了吧?