发布于 2017-09-25 21:24:01 | 233 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的精品教程,程序狗速度看过来!

Android移动端操作系统

Android是一种基于Linux的自由及开放源代码的操作系统,主要使用于移动设备,如智能手机和平板电脑,由Google公司和开放手机联盟领导及开发。尚未有统一中文名称,中国大陆地区较多人使用“安卓”或“安致”。


最近做了一个web app的项目,要求分享web页还要带有图片功能,怎么实现呢?今天小编给大家分享android实现微信分享带有缩略图的网页功能,需要的朋友参考下

前言

最近做了一个web app 需要做微信分享。

需求是分享web页还要带有图片,并且图片还不是本地的,这就有点坑了,

也就是说图片还要从网络实时获取并且是同步的,如果是异步的还需要等待(用户体验就不好了)

代码如下


/** 
 * 微信分享 好友 
 */ 
 public void wxHyShare(String shareUrl, String title, String image, String desc) { 
   IWXAPI api = WXAPIFactory.createWXAPI(context, Constant.Wx_APP_ID); 
 
   WXWebpageObject webPage = new WXWebpageObject(); 
   webPage.webpageUrl = shareUrl; 
   WXMediaMessage msg = new WXMediaMessage(webPage); 
   //msg.title = context.getString(R.string.app_name); 
   msg.title = title; 
   msg.description = desc; 
   //图片加载是使用的ImageLoader.loadImageSync() 同步方法 
   //并且还要创建图片的缩略图,因为微信限制了图片的大小 
   Bitmap thumbBmp = Bitmap.createScaledBitmap(ImageLoaderUtil.getBitmap(image), 200, 200, true); 
   msg.setThumbImage(thumbBmp); 
   thumbBmp.recycle(); 
   SendMessageToWX.Req req = new SendMessageToWX.Req(); 
   req.transaction = String.valueOf(System.currentTimeMillis()); // transaction字段用于唯一标识一个请求 
   req.message = msg; 
   //好友 
   req.scene = SendMessageToWX.Req.WXSceneSession; 
   // 调用api接口发送数据到微信 
   boolean result = api.sendReq(req); 
   LogUtil.d(TAG, result + ""); 
 } 

代码分析

根据业务需求加载网络图片,并且还是要同步加载,所以我使用了ImageLoader。

加载图片代码如下:


/** 
 * 获取bitmap 
 * @param imageUrl 
 * @return 
 */ 
public static Bitmap getBitmap(String imageUrl) { 
  DisplayImageOptions options = new DisplayImageOptions.Builder() 
      .cacheInMemory(true) 
      .cacheOnDisk(true) 
      .build(); 
  return ImageLoader.getInstance().loadImageSync(imageUrl, options); 
} 

loadImageSync是同步加载方法,相应还有异步加载方法。

由于微信对分享图片的大小做了限制,所以我们还要创建缩略图,否则会报错(checkArgs fail, thumbData is invalid)

微信检查参数的源码如下


if(this.getType() == 8 && (this.thumbData == null || this.thumbData.length == 0)) { 
  Log.e("MicroMsg.SDK.WXMediaMessage", "checkArgs fail, thumbData should not be null when send emoji"); 
  return false; 
} else if(this.thumbData != null && this.thumbData.length > '耀') { 
  Log.e("MicroMsg.SDK.WXMediaMessage", "checkArgs fail, thumbData is invalid"); 
  return false; 

创建缩略图代码如下:


Bitmap thumbBmp = Bitmap.createScaledBitmap(ImageLoaderUtil.getBitmap(image), 200, 200, true); 

以上所述是小编给大家介绍的Android实现微信分享带有缩略图的网页,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对PHPERZ网站的支持!



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务