第一步:url转换为bitmap
val imgPath = "https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1332951276,3206293713&fm=26&gp=0.jpg"
object : AsyncTask(){
override fun doInBackground(vararg params: Void?): Bitmap {
//调用下面的方法getBitmap,传入线上图片url路径
return ImageLoadUtils.getBitmap("上下文",imgPath)
}
override fun onPostExecute(result: Bitmap?) {
super.onPostExecute(result)
result?.let {
PublicTools.tools.shareToWxProudct("上下文","分享小程序页面路径及拼接参数",it)
}
}
}.execute()
//url转bitmap
public static Bitmap getBitmap(String urlpath) {
Bitmap bm = null;
try {
URL iconUrl = new URL(urlpath);
URLConnection conn = iconUrl.openConnection();
HttpURLConnection http = (HttpURLConnection) conn;
int length = http.getContentLength();
conn.connect();
// 获得图像的字符流
InputStream is = conn.getInputStream();
BufferedInputStream bis = new BufferedInputStream(is, length);
bm = BitmapFactory.decodeStream(bis);
bis.close();
is.close();// 关闭流
}
catch (Exception e) {
e.printStackTrace();
}
return bm;
}
第二步:判断得到的bitmap是否大于128k(isOverSize),
public static boolean isOverSize(Bitmap bitmap, int maxSize) {
// 将bitmap放至数组中,意在bitmap的大小(与实际读取的原文件要大)
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.PNG, 100, baos);
byte[] b = baos.toByteArray();
// 将字节换成KB
double mid = b.length / 1024;
// 判断bitmap占用空间是否大于允许最大空间 如果大于则压缩 小于则不压缩
return mid > maxSize;
}
/**
* Bitmap转换成byte[]并且进行压缩,压缩到不大于 128 maxkb
*
* @param bitmap
* @param maxKb
* @return
*/
public static Bitmap imageZoom(Bitmap bitMap) {
//图片允许最大空间 单位:KB
double maxSize = 128.00;
//将bitmap放至数组中,意在bitmap的大小(与实际读取的原文件要大)
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bitMap.compress(Bitmap.CompressFormat.JPEG, 100, baos);
byte[] b = baos.toByteArray();
//将字节换成KB
double mid = b.length/1024;
//获取bitmap大小 是允许最大大小的多少倍
double i = mid / maxSize;
//开始压缩 此处用到平方根 将宽带和高度压缩掉对应的平方根倍 (1.保持刻度和高度和原bitmap比率一致,压缩后也达到了最大大小占用空间的大小)
return zoomImage(bitMap, bitMap.getWidth() / Math.sqrt(i),bitMap.getHeight() / Math.sqrt(i) * 0.8);
}
public static Bitmap zoomImage(Bitmap bgimage, double newWidth,
double newHeight) {
// 获取这个图片的宽和高
float width = bgimage.getWidth();
float height = bgimage.getHeight();
// 创建操作图片用的matrix对象
Matrix matrix = new Matrix();
// 计算宽高缩放率
float scaleWidth = ((float) newWidth) / width;
float scaleHeight = ((float) newHeight) / height;
// 缩放图片动作
matrix.postScale(scaleWidth, scaleHeight);
Bitmap bitmap = Bitmap.createBitmap(bgimage, 0, 0, (int) width,
(int) height, matrix, true);
return bitmap;
}
第三步:申请配置微信开放平台的appid,再到微信公众平台拿小程序的原始id,最后拉起微信,并分享出去
val appId = MyParms.APP_ID // 填应用AppId
val api = WXAPIFactory.createWXAPI(this, appId)
val miniProgramObj = WXMiniProgramObject()
miniProgramObj.webpageUrl = " " // 兼容低版本的网页链接
// 正式版:0,测试版:1,体验版:2
miniProgramObj.miniprogramType = WXMiniProgramObject.MINIPTOGRAM_TYPE_RELEASE
miniProgramObj.userName = MyParms.WX_SMALL_PROGRAM // 小程序原始id
//小程序页面路径;对于小游戏,可以只传入 query 部分,来实现传参效果,如:传入 "?foo=bar"
miniProgramObj.path = "pages/cardDetail/cardDetail?pcid=$cardId"
val msg = WXMediaMessage(miniProgramObj)
msg.title = "您赞,就是赞" // 小程序消息title
msg.description = "您赞,就是赞" // 小程序消息desc
val bitmap = BitmapFactory.decodeResource(resources, R.mipmap.icon)
if (null == bitmap) {
toast("分享失败")
return
}
if (ImageLoadUtils.isOverSize(bitmap,128)){
val ysBitmap = ImageLoadUtils.imageZoom(bitmap)
msg.setThumbImage(ysBitmap)// 小程序消息封面图片,小于128k
}else{
msg.setThumbImage(bitmap) // 小程序消息封面图片,小于128k
}
val req = SendMessageToWX.Req()
req.transaction = "您赞,就是赞"//buildTransaction("miniProgram")
req.message = msg
req.scene = SendMessageToWX.Req.WXSceneSession // 目前只支持会话
api.sendReq(req)