一、概述
1、需求:将一个镜头的左视图/右视图/俯视图进行3合1,并且将所有3合1图片进行横向拼接
2、需求条件与要求
1)原图拼接
2)一张图片分辨率 8000 * 2048
3、要求效果
1)可以预览完整大图
2)可以查看拼接的每张图
二、解决思路
1、先3合1
2、然后再横向拼接
3、使用hutool工具ImgUtil.pressImage
三、遇到问题
1、问题1: Java heap space
2、问题2: Maximum supported image dimension is 65500 pixels
四、问题说明
1、底层拼接,用的是BufferedImage,而底层创建数据像素存储用的是int[],数组最大长度为21亿的长度,也就是2^32-1(2147483647)
2、21亿只是理论值,实际上跟JVM堆内存配置,实际硬件环境有关联,达不到这个值
3、8000 * 6144 * 42 = 2088960000,小于21亿,也不行
4、测试通过的, 8000 * 6144 * 8 = 393,216,000,4亿,是可以的;也就是8张3合1是没问题的,再多就不行了
5、用chatgpt搜索了一些方案
尝试后发现,底层用的都是用int[]数据存值,所以理论上底层就已经限制了
6、65000pixels即65000像素,65000 / 8000 = 8.125 ≈ 8,再次验证了最多也就8张拼接
~~
五、调整思路
1、3合1没问题,保留
2、整图拼接调整,不再拼接,再预览上做调整;
1)3合1打序号,并存储到minio
2)自定义vue组件,预览多张图片,可查看子图
六、最终结果
1、满足需求,方案可行