Android(安卓)Studio中ShareSDK分享的使用.
简介
如今的app中,几乎都包含了分享这个功能,十分的常用,如
我们经常使用的网易云音乐
一般我们都会采用市面上用的最广泛的ShareSDK
来完成类似的功能.
www.mob.com
集成 步骤
注册获取
App Key
和App Secret
如果没有ShareSDK账号的话,需要先注册一个.进入后台,并创建应用
进入到后台后,我们就可以创建自己的应用,并拿到App Key
和App Secret
,应用名称可以随意,后面可以更改
SDK下载
选择我们需要分享到的平台 ,或者直接下载官方Demo.
导入SDK
在刚才下载的SDK中,会有一个快速集成程序,QuickIntegrater.jar
,按照相应操作,即可生成相关集成所需文件
点击确定后,会生成一个Sample
目录.将目录中的文件拷贝到项目中,在Android Studio中我们可以选中我们的module,并新建一个assets目录.将ShareSDK.xml
拷贝到目录下
配置SDK’
我们在最开始创建应用的时候获取的
APPKey
这时候派上用场了,修改相应参数即可,注释很详细.
这种方式的弊端就是在应用发出去后不可动态更改在官网上配置.
上面那一种方式最简单,方便,但是也有很多的局限性,因此ShareSDK还提供了其他两种配置方式.
和上面的xml配置类似,需要我们在相应的平台中创建应用,获取APPkey
等信息.
可修改,比较灵活.但是这种方式,需要在分享 前有网络的支持.- 通过代码设置
setPlatformDevInfo(String, HashMap<String, Object>)
HashMap<String,Object> hashMap = new HashMap<String, Object>(); hashMap.put("Id","1"); hashMap.put("SortId","1"); hashMap.put("AppKey","568898243"); hashMap.put("AppSecret","38a4f8204cc784f81f9f0daaf31e02e3"); hashMap.put("RedirectUrl","http://www.sharesdk.cn"); hashMap.put("ShareByAppClient","true"); hashMap.put("Enable","true"); ShareSDK.setPlatformDevInfo(SinaWeibo.NAME,hashMap);
使用此方法需要调用ShareSDK.init(context,你的应用在sharesdk注册时返回的AppKey)方法进行初始化。
此种方法比较复杂,不推荐!
- 清单文件配置,
参考官网,几个回调类比较重要
uses-permission
权限配置
<uses-permission android:name="android.permission.GET_TASKS" /> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_PHONE_STATE" /> <uses-permission android:name="android.permission.MANAGE_ACCOUNTS"/> <uses-permission android:name="android.permission.GET_ACCOUNTS"/> <!-- 蓝牙分享所需的权限 --> <uses-permission android:name="android.permission.BLUETOOTH" /> <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
Activity
及回调配置
<activity android:name="com.mob.tools.MobUIShell" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:configChanges="keyboardHidden|orientation|screenSize" android:screenOrientation="portrait" android:windowSoftInputMode="stateHidden|adjustResize" > <!-- 调用新浪原生SDK,需要注册的回调activity --> <intent-filter> <action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> <!-- 如果集成QQ分享,或者使用QQ客户端来进行QQ空间的分享,须要在此处添加一个对ACTION_VIEW 事件的过滤器,其中的scheme是“tencent”前缀再开发者应用的加上appId。如果此过滤器不设置, 则分享结束以后不能得到正确的回调 --> <intent-filter android:priority="1000" > <data android:scheme="tencent100371282" /> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.BROWSABLE" /> </intent-filter> </activity> <!--微信分享回调 --> <activity android:name=".wxapi.WXEntryActivity" android:theme="@android:style/Theme.Translucent.NoTitleBar" android:configChanges="keyboardHidden|orientation|screenSize" android:exported="true" android:screenOrientation="portrait" />
注意: MobUIShell的路径是固定的,一定要在cn.sharesdk.framework
下,因为它在Share-Core
中。
<data android:scheme="tencent100371282" />//中的数字改成在腾讯开放平台申请到的AppId
分享代码
SDK集成后,我们需要来测试一下,看看是否能够成功分享.
1. 打开您项目的入口Activity
,在其onCreate
中插入下面的代码:
//使用ShareSDK.xml方式配置 ShareSDK.initSDK(this); // 使用代码或者应用后台配置 ShareSDK.initSDK(this,”androidv1101″); //androidv1101:是你的应用在ShareSDK注册应用信息时返回的AppKey
如果不在所有的ShareSDK的操作之前调用这行代码,就会抛出空指针异常
2. 在项目出口Activity
的onDestroy
方法中第一行插入下面的代码
ShareSDK.stopSDK(this); //结束ShareSDK的统计功能并释放资源
3. 调用分享,参考官网
private void showShare() { ShareSDK.initSDK(this); OnekeyShare oks = new OnekeyShare(); //关闭sso授权 oks.disableSSOWhenAuthorize(); // 分享时Notification的图标和文字 2.5.9以后的版本不调用此方法 //oks.setNotification(R.drawable.ic_launcher, getString(R.string.app_name)); // title标题,印象笔记、邮箱、信息、微信、人人网和QQ空间使用 oks.setTitle(getString(R.string.share)); // titleUrl是标题的网络链接,仅在人人网和QQ空间使用 oks.setTitleUrl("http://sharesdk.cn"); // text是分享文本,所有平台都需要这个字段 oks.setText("我是分享文本"); // imagePath是图片的本地路径,Linked-In以外的平台都支持此参数 oks.setImagePath("/sdcard/test.jpg");//确保SDcard下面存在此张图片 // url仅在微信(包括好友和朋友圈)中使用 oks.setUrl("http://sharesdk.cn"); // comment是我对这条分享的评论,仅在人人网和QQ空间使用 oks.setComment("我是测试评论文本"); // site是分享此内容的网站名称,仅在QQ空间使用 oks.setSite(getString(R.string.app_name)); // siteUrl是分享此内容的网站地址,仅在QQ空间使用 oks.setSiteUrl("http://sharesdk.cn");// 启动分享GUI oks.show(this); }
新浪微博分享
<SinaWeibo AppKey="858316951" AppSecret="52685221be9572d0fb99e35a7ba25364" Enable="true" Id="1" // 此处配置需要和新浪开放平台设置一致 RedirectUrl="http://www.baidu.com" // true,调用新浪微博app,如果没有安装,可能分享失败 // false,调用网页版分享. ShareByAppClient="true" SortId="1"/>
分享回调
OnekeyShare oks = new OnekeyShare();oks.setCallback(PlatformActionListener listener);
// 分享成功的回调 public void onComplete(Platform platform, int i, HashMap<String, Object> hashMap){} // 分享失败的回调 public void onError(Platform platform, int i, Throwable throwable){} // 取消分享的回调 public void onCancel(Platform platform, int i) {}// 可以设置listener来对分享进行监听,以进行后续操作.
新浪微博error:redirect_uri_mismatch
的解决方法:
到新浪微博注册应用的地方填上回调地址,然后将代码中的回调地址修改成和新浪微博开放平台里一样即可
参考:在Android Studio中使用shareSDK进行社会化分享(图文教程)
【ShareSDK For Android】微信分享(对比及配置)
更多相关文章
- 没有一行代码,「2020 新冠肺炎记忆」这个项目却登上了 GitHub 中
- Android培训---支持不同的平台版本
- Android:SqliteDatabase 数据库的简单使用
- Android(安卓)中自定义View的应用(二)
- WindowManager与窗口管理机制
- Android模仿微信加号菜单模式
- Android中如何通过程序打开或关闭GPS
- Android中实现一键分享功能
- Android(OPhone) 学习笔记 - 记事本实例