android studio怎么使用sharesdk,Android Studio中ShareSDK分享的使用.
简介如今的app中,几乎都包含了分享这个功能,十分的常用,如我们经常使用的网易云音乐一般我们都会采用市面上用的最广泛的ShareSDK来完成类似的功能.www.mob.com集成 步骤注册获取App Key和App Secret如果没有ShareSDK账号的话,需要先注册一个.进入后台,并创建应用进入到后台后,我们就可以创建自己的应用,并拿到App Key和App Secret,应用名称可...
简介
如今的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)
HashMap hashMap = new HashMap();
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权限配置
Activity及回调配置
注意: MobUIShell的路径是固定的,一定要在cn.sharesdk.framework下,因为它在Share-Core中。
//中的数字改成在腾讯开放平台申请到的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);
}
新浪微博分享
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 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】微信分享(对比及配置)
更多推荐
所有评论(0)