第一步:url轉(zhuǎn)換為bitmap
val imgPath = "https://ss1.bdstatic.com/70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=1332951276,3206293713&fm=26&gp=0.jpg"
object : AsyncTask<Void, Void, Bitmap>(){
override fun doInBackground(vararg params: Void?): Bitmap {
//調(diào)用下面的方法getBitmap,傳入線上圖片url路徑
return ImageLoadUtils.getBitmap("上下文",imgPath)
}
override fun onPostExecute(result: Bitmap?) {
super.onPostExecute(result)
result?.let {
PublicTools.tools.shareToWxProudct("上下文","分享小程序頁面路徑及拼接參數(shù)",it)
}
}
}.execute()
//url轉(zhuǎn)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();// 關(guān)閉流
}
catch (Exception e) {
e.printStackTrace();
}
return bm;
}
第二步:判斷得到的bitmap是否大于128k(isOverSize),
public static boolean isOverSize(Bitmap bitmap, int maxSize) {
// 將bitmap放至數(shù)組中嘹锁,意在bitmap的大小(與實際讀取的原文件要大)
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.PNG, 100, baos);
byte[] b = baos.toByteArray();
// 將字節(jié)換成KB
double mid = b.length / 1024;
// 判斷bitmap占用空間是否大于允許最大空間 如果大于則壓縮 小于則不壓縮
return mid > maxSize;
}
/**
* Bitmap轉(zhuǎn)換成byte[]并且進行壓縮,壓縮到不大于 128 maxkb
*
* @param bitmap
* @param maxKb
* @return
*/
public static Bitmap imageZoom(Bitmap bitMap) {
//圖片允許最大空間 單位:KB
double maxSize = 128.00;
//將bitmap放至數(shù)組中,意在bitmap的大芯伞(與實際讀取的原文件要大)
ByteArrayOutputStream baos = new ByteArrayOutputStream();
bitMap.compress(Bitmap.CompressFormat.JPEG, 100, baos);
byte[] b = baos.toByteArray();
//將字節(jié)換成KB
double mid = b.length/1024;
//獲取bitmap大小 是允許最大大小的多少倍
double i = mid / maxSize;
//開始壓縮 此處用到平方根 將寬帶和高度壓縮掉對應(yīng)的平方根倍 (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();
// 創(chuàng)建操作圖片用的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 // 填應(yīng)用AppId
val api = WXAPIFactory.createWXAPI(this, appId)
val miniProgramObj = WXMiniProgramObject()
miniProgramObj.webpageUrl = " " // 兼容低版本的網(wǎng)頁鏈接
// 正式版:0情连,測試版:1叽粹,體驗版:2
miniProgramObj.miniprogramType = WXMiniProgramObject.MINIPTOGRAM_TYPE_RELEASE
miniProgramObj.userName = MyParms.WX_SMALL_PROGRAM // 小程序原始id
//小程序頁面路徑;對于小游戲却舀,可以只傳入 query 部分虫几,來實現(xiàn)傳參效果,如:傳入 "?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 = "您贊啡氢,就是贊"http://buildTransaction("miniProgram")
req.message = msg
req.scene = SendMessageToWX.Req.WXSceneSession // 目前只支持會話
api.sendReq(req)