昨天公司老大通知客户改需求了,原来的微信分享改成分享多张图片,然后屁颠屁颠跑到微信平台看了以后

心里千万只草泥马狂奔而过,微信平台没有提供分享多张的SDK有木有啊,我们只能自己调用系统自带的分享功能实现。

这儿我先讲下流程,后面会附上源码。

首先我们讲下调起微信分享的方法。其实方法都是一样的,没有太大的区别。

//com.tencent.mm.ui.tools.ShareImgUi   是分享到微信好友

//com.tencent.mm.ui.tools.ShareToTimeLineUI  是分享到微信朋友圈

//intent.put("kdescription","分享朋友圈的图片说明");

Intent intent = new Intent();

ComponentName comp = new ComponentName("com.tencent.mm","com.tencent.mm.ui.tools.ShareImgUi");

intent.setComponent(comp);

intent.setAction(Intent.ACTION_SEND_MULTIPLE);

intent.setType("image/*");

ArrayList(Uri) imageUris = new ArrayList<Uri>();

for(File f : files){

imageUris.add(Uri.fromFile(f));

}

intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM,imageUris);

startActivity(intent);

其实来说分享的代码很简单。但是实际操作中就跳了更多的坑,我一个一个的记录下来。

实际分享的时候因为是调用系统本地的分享功能,所以分享的图片也就必须要存到本地,不然就会提示获取资源失败,只支持分享到朋友圈等等的问题。

那就要把图片存到本地了,这个方法网上也有很多,我这儿就直接用了网上一个朋友的代码,然后稍微修改了一下,后面附上代码。

因为考虑到如果存的图片太多就太占内存了,所以最多设置分享9张,每次调起分享的时候都会从iv_share_1.jpg开始

这个是直接调用微信的分享,所以调起分享的时候一定要判断手机里面是否已经安装了微信,如果没有安装还要掉微信分享就是直接崩溃掉。

都到了这一步就已经能调起微信的多张图片分享了,但是其中还是会有一个坑,也是卡了我不少时间。那就是android N系统以后分享的链接用file://.....

的时候会出现一个异常android.os.FileUriExposedException。网上虽然很多朋友都给出了用 v4包中的FileProvider来解决,但是不知道为什么,反正我的

项目导入后就报错了,最后在网上找了另一个方法在项目的BaseApplication的onCreate中用VmPolicy的方法解决。

//解决android N(>=24)系统以上分享 路径为file://时的 android.os.FileUriExposedException异常
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
StrictMode.VmPolicy.Builder builder = new StrictMode.VmPolicy.Builder();
StrictMode.setVmPolicy(builder.build());
}

到这儿以后就搞定了微信的多张图片分享。下面就贴出我的代码,希望对大家有所帮助。

布局中就放入了两个按钮,通过按钮传递一个参数判断是分享朋友圈还是微信好友

MainActivity中的代码

/**
*
* @param flag 0分享给微信好友 1分享到朋友圈
*/
private void shareImage(final int flag) { //判断是否安装微信,如果没有安装微信 又没有判断就直达微信分享是会挂掉的
if (!Tools.isWeixinAvilible(mContext)){
Toast.makeText(MainActivity.this, "您还没有安装微信", Toast.LENGTH_SHORT).show(); }else{ new Thread(new Runnable() {
@Override
public void run() {
//这一步一定要clear,不然分享了朋友圈马上分享好友图片就会翻倍
files.clear(); try { for (int i = 0; i < stringItem.length; i++) {
File file = Tools.saveImageToSdCard(mContext, stringItem[i]);
files.add(file);
} Intent intent = new Intent();
ComponentName comp; if (flag == 0) {
comp = new ComponentName("com.tencent.mm", "com.tencent.mm.ui.tools.ShareImgUI");
} else {
comp = new ComponentName("com.tencent.mm", "com.tencent.mm.ui.tools.ShareToTimeLineUI");
intent.putExtra("Kdescription", "分享朋友圈的图片说明");
}
intent.setComponent(comp);
intent.setAction(Intent.ACTION_SEND_MULTIPLE);
intent.setType("image/*"); ArrayList<Uri> imageUris = new ArrayList<Uri>();
for (File f : files) {
imageUris.add(Uri.fromFile(f));
} intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, imageUris);
startActivity(intent);
}catch (Exception e){
e.printStackTrace();
}
}
}).start(); } }

然后就是调用Tools工具类中的或取临时保存的图片的地址。

public static String IMAGE_NAME = "iv_share_";
public static int i =0; //根据网络图片url路径保存到本地
public static final File saveImageToSdCard(Context context, String image) {
boolean success = false;
File file = null;
try {
file = createStableImageFile(context); Bitmap bitmap = null;
URL url = new URL(image);
HttpURLConnection conn = null;
conn = (HttpURLConnection) url.openConnection();
InputStream is = null;
is = conn.getInputStream();
bitmap = BitmapFactory.decodeStream(is); FileOutputStream outStream; outStream = new FileOutputStream(file);
bitmap.compress(Bitmap.CompressFormat.PNG, 100, outStream);
outStream.flush();
outStream.close();
success = true;
} catch (Exception e) {
e.printStackTrace();
} if (success) {
return file;
} else {
return null;
}
} //创建本地保存路径
public static File createStableImageFile(Context context) throws IOException {
i++;
String imageFileName =IMAGE_NAME + i+ ".jpg";
File storageDir = context.getExternalCacheDir();
File image = new File(storageDir, imageFileName);
return image;
}

至于判断是否安装了微信这个大家在网上随便搜搜都能找到。

这样就大功告成了。分享都不用去等待微信平台的审核了。但是因为是调用系统的分享,所以也有不足的地方,那就是没有回调。

地址:https://github.com/XW837156540/ShareMoreImage

https://blog.csdn.net/XuWei1213/article/details/78547684

android 实现微信分享多张图片的功能的更多相关文章

  1. Android集成微信分享功能应用签名生成方法及分享不生效的问题

    通过友盟sdk集成微博.微信.qq等分享功能时,微博和qq很顺利,但在做微信集成时一直不成功.主要问题还是之前在微信开放平台申请创建移动应用时,对应用签名没有填写对,走了很多弯路现总结出来,加深记忆避 ...

  2. Android实现微信分享及注意事项

    一.获取帮助文档并下载相关资料 首先打开微信开放平台:https://open.weixin.qq.com/ 如果没有注册,请先注册并上传开发者资料等待审核. 资源中心----移动应用开发----分享 ...

  3. Android 仿微信朋友圈发动态功能(相册图片多选)

    代码分享 代码名称: 仿微信朋友圈发动态功能(相册图片多选) 代码描述: 仿微信朋友圈发动态功能(相册图片多选) 代码托管地址: http://www.apkbus.com/android-15276 ...

  4. Android 开发 微信分享,登陆,获取信息

    1 获取appid和appsecret.        https://open.weixin.qq.com/cgi-bin/index?t=home/index&lang=zh_CN     ...

  5. android接入微信分享(朋友、朋友圈)、QQ分享(好友、空间)

    1.申请注册你的appid 2.下载sdk QQ: http://wiki.open.qq.com/wiki/mobile/SDK%E4%B8%8B%E8%BD%BD 微信:https://open. ...

  6. Android 接入微信分享错误码-6

    官方的常见错误表示签名出错登录以后,需要重装微信(也就是清除微信本地数据)

  7. Android 微信分享解疑

    from:http://blog.csdn.net/freesonhp/article/details/10756663 1.建立自己的应用 TestShareWX (1)应用包名是com.frees ...

  8. Android开发 对接微信分享SDK总结

    原文:Android开发 对接微信分享SDK总结 - Stars-One的杂货小窝 公司项目需要对接微信分享,本来之前准备对接友盟分享的,但友盟的分享实际参数太多,而我又只需要对接一个微信分享,于是便 ...

  9. Android 微信分享图文资料

    上个项目做Android的微信分享,需要分享的内容有图片有文字,看了微信分享的SDK,貌似没有这个API,在网上搜了好久,总算找到解决方法了,直接上代码: public void sendReq(Co ...

随机推荐

  1. net与树莓派的情缘-安装与卸载MySql(五)

    安装MySql sudo apt-get install mysql-server 删除 mysql sudo apt-get autoremove --purge mysql-server-5.0s ...

  2. nuxt.js引入客户端脚本和第三方库出现window/document/ navigator未定义问题

    官方文档中已经给出解决方案: 实际操作也比较简单,比如我之前在项目中引入的wangeditor,这个插件里包含了navigator内容 解决:现在nuxt.config.js的webpack扩展配置中 ...

  3. javac之向前引用

    可以参考JLS7:https://docs.oracle.com/javase/specs/jls/se7/html/jls-8.html#jls-8.3.2.3 public class Test5 ...

  4. web开发之缓存

    以数据为驱动的web站点,当访问量增大后,由于频繁的从DB中读取数据,使得DB服务器的压力大增,从而影响系统的性能.为了缓解这种来自于大访问量的频繁读取DB的压力,我们可以把一些数据缓存起来,当请求过 ...

  5. 1-2 Mobx 入门实践之TodoList(官方Demo)

    第一步:导入模块 import React, { Component } from 'react'; import { observable, autorun,computed } from 'mob ...

  6. window.location和document.location的区别分析

    用户不能改变document.location(因为这是当前显示文档的位置).但是,可以改变window.location (用其它文档取代当前文档)window.location本身也是一个对象,而 ...

  7. Nginx教程(6) 动静分离架构

    一.原理 Nginx 动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx 处理静态页面,To ...

  8. [PY3]——时间处理——datetime | calendar

    Python3的日期/时间处理模块 datetime的格式化符号 格式化符号 表示 %y 两位数的年份表示(00-99) %Y 四位数的年份表示(000-9999) %m 月份(01-12) %d 日 ...

  9. vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据

    在vue项目中组件间相互传值或者后台获取的数据需要供多个组件使用的情况很多的话,有必要考虑引入vuex来管理这些凌乱的状态,今天这边博文用来记录这一整个的过程,后台api接口是使用webpack-se ...

  10. c#删除list中的元素

    public static void TestRemove() { string[] str = { "1", "2", "d", &quo ...