Mob之社會化分享集成ShareSDK

接着上篇順便分享一篇本身使用 ShareSDK 的筆記,上篇咱們集成了 SMSSDK 完成了短信接收驗證碼的功能,請參考Mob 之 短信驗證集成 SMSSDK,如何在項目已經集成 SMSSDK 的狀況下集成 ShareSDk 到項目中,上一篇中咱們集成 SMSSDK 使用的是導入 jar 包的形式,這裏咱們使用建立 module 的方式引入 ShareSDk,主要內容以下:java

  1. 下載ShareSDK
  2. 引入 ShareSDK
  3. 建立 MainLibs Module
  4. 建立 OneKeyShare Module
  5. 在項目中引入 Module
  6. 配置權限
  7. 配置 Application
  8. 啓用 ShareSDK

下載 ShareSDk

官網下載地址:ShareSDK,下載的時候選中要分享的平臺,以下圖所示:android

image

下載的 ShareSDk 解壓縮以下,這裏下載的版本是 ShareSDK-Android-3.0.0 ,以下圖所示:api

image

引入 ShareSDK

首先,複製 ShareSDk 中的 ShareSDK.xml 文件到項目中的 assets 目錄下, 這裏使用引入 module 的方式引入 ShareSDk,ShareSDK 裏面主要引入以下兩個 Libs,以下圖所示:bash

image
下面演示一下 Module的建立過程:

建立 MainLibs Module

  1. 在新建的項目中建立一個 Android Library,以下圖所示: 微信

    image

  2. 刪除新建立的 Library 中 main 下面的全部文件,及 java、res兩個文件夾和 AndroidManifest.xml 文件,以下圖所示: 網絡

    image

  3. 複製要引入的 MainLibs 中的 res 、 AndroidMainfest.xml 、 libs(裏面的jar) 到對應的文件夾,以下圖所示: app

    image
    導入 mainLibs 中結構以下:

image
此時,這個 module 就建立好了,這裏使用 ShareSDK 提供的分享頁面,故還需引入 OneKeyShare。

建立 OneKeyShare Module

建立 Module 的過程和上述同樣,注意的是多了一個 src ,裏面是要使用的 java 文件,因此必須也得引用,以下圖所示:學習

image

將 src 文件夾複製到 main下面便可,build 以後若是不出錯,說明 Module 建立成功了,下面根據依賴關係一如對應的 Module 便可。測試

在項目中引入 Module

這裏面 OnKeyShareLibs 依賴 MainLibs ,只需 app 依賴 OnkeyShareLibs 便可,這裏演示 OnKeyShareLibs 如何依賴 MainLibs,以下圖所示:網站

image

而後,一樣的方式 app 依賴 OnKeyShareLibs 便可。

配置權限

這裏以前配置過 SMSSDK ,只需補充缺乏的權限便可,下面是同時集成了 SMSSDK 和 ShareSDK 所需的所有權限,以下:

<!-- 添加必要的權限 -->
<!--SMS SDK-->
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.RECEIVE_SMS" />
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <!--ShareSDK-->
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
複製代碼

配置 Application

若是以前配置過 SMSSDK ,那麼 MobUIShell 是配置過的,只需添加缺乏的 IntentFilter ,集成 SMSSDK 和 ShareSDK 可共用 MobUIShell ,以下:

<activity
    android:name="com.mob.tools.MobUIShell"
    android:theme="@android:style/Theme.Translucent.NoTitleBar"
    android:configChanges="keyboardHidden|orientation|screenSize"
    android:windowSoftInputMode="stateHidden|adjustResize">
    <intent-filter>
        <data android:scheme="tencent100371282" />
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.BROWSABLE" />
        <category android:name="android.intent.category.DEFAULT" />
    </intent-filter>

    <!-- 調用新浪原生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>
    
</activity>
複製代碼

若是您的項目集微信或者微信朋友圈,請查看AndroidManifest.xml配置文件裏的package路徑,須要在package目錄下建立wxapi目錄再放置WXEntryActivity。 沒有此activity在微信分享後回調會檢查是否有此activity,沒有將會報錯:

<activity     
    android:name=".yxapi.YXEntryActivity"     
    android:theme="@android:style/Theme.Translucent.NoTitleBar"
    android:configChanges="keyboardHidden|orientation|screenSize" 
    android:exported="true"     
    android:screenOrientation="portrait" />
複製代碼

具體請參考:Android ShareSDK完整的集成文檔

啓用 SDK

經過 AndroidManifest.xml
  1. 在 Application 節點下添加如下屬性:
android:name="com.mob.MobApplication"
複製代碼
  1. 在 Application 標籤下添加 meta 參數:
<!-- 經過AndroidManifest配置AppKey和AppSecret,若是你選擇經過代碼配置,則不須要配置如下meta-data -->
<meta-data android:name="Mob-AppKey" android:value="你的AppKey"/>
<meta-data android:name="Mob-AppSecret" android:value="你的AppSecret"/>
複製代碼
代碼配置
// 經過代碼註冊你的AppKey和AppSecret
MobSDK.init(context, "你的AppKey", "你的AppSecret");
複製代碼

上述兩種方式,只使用其中一種便可初始化 ShareSDK 了。

調用分享界面

private void showShare() {
     OnekeyShare oks = new OnekeyShare();
     //關閉sso受權
     oks.disableSSOWhenAuthorize(); 
     // 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);
}
複製代碼

本文主要記錄瞭如何以 module 的方式引入 第三方 SDK 以及頁面的分享調用。

能夠選擇關注微信公衆號:jzman-blog 獲取最新更新,一塊兒交流學習!

零點小築
相關文章
相關標籤/搜索