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

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 微信分享图片压缩问题解决方案

推荐下载

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

微信分享图片压缩问题解决方案

发布时间:2020-11-13  

在进行微信分享时,遇到微信分享失败的情况,微信分享对于图片的大小有32k的限制,如果大于的话就会导致失败。所以对于图片的压缩进行了调研,最后得出如下解决方案:

1、统一了图片的质量参数为RGB_565;
2、先利用32*1024计算出图片采样率,进行一次长宽比压缩;
3、然后利用compress( CompressFormat format, int quality,OutputStream stream)压缩成PNG格式;
4、计算此时大小,如果超过32k,则换成JPEG格式进行压缩,通过循环修改quality参数来进行压缩,直到最后图片小于32k结束。

问题背景

在某些页面调起微信分享时会直接返回失败,但并不是所有的页面都会失败,所以排除是微信分享API的问题。

术语解释

A : 透明度

R : 红色

G : 绿色

B : 蓝色

Bitmap.Config ARGB_4444:每个像素占四位,即A=4,R=4,G=4,B=4,那么一个像素点占4+4+4+4=16位

Bitmap.Config ARGB_8888:每个像素占四位,即A=8,R=8,G=8,B=8,那么一个像素点占8+8+8+8=32位

Bitmap.Config RGB_565:每个像素占四位,即R=5,G=6,B=5,没有透明度,那么一个像素点占5+6+5=16位

问题分析

private void sendReq(IWXAPI iwxapi, BaseReq req) { boolean result = iwxapi.sendReq(req); if(!result) { this.mCallBack.onShareError(this.mActivity, ""); this.mActivity.finish(); } }

由分析可知以上result返回false,在这里是将分享的数据传入分享的API,所以猜测这里应该是参数传入有误,下面是在官网上查看的常见问题(虽然结果返回true,但还是具有参考价值的信息),我们可以看到第三条,检查发送时的缩略图大小是否超过32K,所以微信分享对于图片的大小是有限制的,重新换了一张小点的图,最后分享成功了。

目前的分享流程

微信分享图片压缩问题解决方案

从以上流程可以看出来,图片是经过了两次压缩,为什么最后还会有超出大小的情况呢?下面我们来分析一下具体的压缩过程是如何实现的。

/** * 图片压缩比例计算 * * @param options BitmapFactory.Options * @param minSideLength 小边长,单位为像素,如果为-1,则不按照边来压缩图片 * @param maxNumOfPixels 这张片图片最大像素值,单位为byte,如100*1024 * @return 压缩比例,必须为2的次幂 */ public static int computeSampleSize(BitmapFactory.Options options,int minSideLength, int maxNumOfPixels) { int initialSize = computeInitialSampleSize(options, minSideLength, maxNumOfPixels); int roundedSize; if (initialSize <= 8) { roundedSize = 1; while (roundedSize < initialSize) { roundedSize <<= 1; } } else { roundedSize = (initialSize + 7) / 8 * 8; } return roundedSize; } /** * 计算图片的压缩比例,用于图片压缩 * @param options BitmapFactory.Options * @param minSideLength 小边长,单位为像素,如果为-1,则不按照边来压缩图片 * @param maxNumOfPixels 这张片图片最大像素值,单位为byte,如100*1024 * @return 压缩比例 */ private static int computeInitialSampleSize(BitmapFactory.Options options,int minSideLength,int maxNumOfPixels) { double w = options.outWidth; double h = options.outHeight; int lowerBound = (maxNumOfPixels == -1) ? 1 : (int) Math.ceil(Math .sqrt(w * h / maxNumOfPixels)); int upperBound = (minSideLength == -1) ? 128 : (int) Math.min( Math.floor(w / minSideLength), Math.floor(h / minSideLength)); if (upperBound < lowerBound) { return lowerBound; } if ((maxNumOfPixels == -1) && (minSideLength == -1)) { return 1; } else if (minSideLength == -1) { return lowerBound; } else { return upperBound; } }

以上的方法是安卓源码中处理缩略图大小的计算方法,我们知道图片的inSampleSize必须为2的幂次,如果不是2的幂次,会以接近2的幂次这个数来进行压缩,所以最后计算出来的inSampleSize必然不能很精确的将图片压缩到我们期望的大小,所以当一张图片太大时,可能第一次压缩并没有达到效果,然后再经过第二次压缩之后还是可能会超过32k,这就导致了最终的微信分享失败。

在我们处理图片的时候发现,会给图片设置质量参数,如下

public static Bitmap makeNormalBitmap(String nativeImagePath,int minSideLength, int maxNumOfPixels){ return makeNormalBitmap(nativeImagePath, minSideLength, maxNumOfPixels,Bitmap.Config.ARGB_4444); }

目前这里设置成了ARGB_4444,那为什么要设置成这个格式呢?应该设置成什么格式呢?还有第二次压缩bmp.compress(CompressFormat.PNG, 100, output);这里为什么设置成PNG,换成JPEG可以吗?