Android Studio中ShareSDK分享的使用.

简介

如今的app中,几乎都包含了分享这个功能,十分的常用,如
我们经常使用的网易云音乐
Android Studio中ShareSDK分享的使用._第1张图片

一般我们都会采用市面上用的最广泛的ShareSDK来完成类似的功能.
www.mob.com

集成 步骤

  • 注册获取App KeyApp Secret
    如果没有ShareSDK账号的话,需要先注册一个.进入后台,并创建应用
    Android Studio中ShareSDK分享的使用._第2张图片
    进入到后台后,我们就可以创建自己的应用,并拿到App KeyApp Secret,应用名称可以随意,后面可以更改

  • SDK下载

ShareSDK下载
Android Studio中ShareSDK分享的使用._第3张图片
选择我们需要分享到的平台 ,或者直接下载官方Demo.

  • 导入SDK
    在刚才下载的SDK中,会有一个快速集成程序,QuickIntegrater.jar,按照相应操作,即可生成相关集成所需文件
    Android Studio中ShareSDK分享的使用._第4张图片
    点击确定后,会生成一个Sample目录.将目录中的文件拷贝到项目中,在Android Studio中我们可以选中我们的module,并新建一个assets目录.将ShareSDK.xml拷贝到目录下
    Android Studio中ShareSDK分享的使用._第5张图片

  • 配置SDK’

    1. 我们在最开始创建应用的时候获取的APPKey这时候派上用场了,修改相应参数即可,注释很详细.

      这种方式的弊端就是在应用发出去后不可动态更改

    2. 在官网上配置.
      上面那一种方式最简单,方便,但是也有很多的局限性,因此ShareSDK还提供了其他两种配置方式.
      Android Studio中ShareSDK分享的使用._第6张图片
      Android Studio中ShareSDK分享的使用._第7张图片
      和上面的xml配置类似,需要我们在相应的平台中创建应用,获取APPkey等信息.
      可修改,比较灵活.但是这种方式,需要在分享 前有网络的支持.

    3. 通过代码设置
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. 在项目出口ActivityonDestroy方法中第一行插入下面的代码

 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】微信分享(对比及配置)

你可能感兴趣的:(android,android,Studio,ShareSDK)