Android 社會化分享專案總結

Mr_dsw的部落格發表於2015-10-10

隨著現在社交網路的日益繁多,眾多的社交客戶端已佔據了人們的大量時間,所以在我們的應用中具有一鍵分享的功能對提高我們產品的知名度有很大的幫助。新浪微博、騰訊微博、騰訊QQ、微信、QQ空間、豆瓣等眾多知名社交站點,都是我們可以分享的去處,當然,分享功能涉及到別人第三方的權益,肯定是由他們提供SDK等支援,我們才能進行分享使用。既然分享如何重要,那麼我們就該學習下Android系統如何實現分享功能。

現在在Android系統中進行分享,主要有兩種手段,一種是通過系統自帶的來啟動分享功能;第二種是通過第三方的SDK外掛進行分享;下面我們來簡要介紹下兩種手段:

一、Android系統啟動分享功能

毫無疑問,通過系統來啟動的分享功能很簡單,也非常容易實現,我們直接來寫個demo演示下。

1、還是先看一個佈局檔案,佈局檔案很簡單,僅僅一個button按鈕來觸發分享功能即可。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/btn_share"
        android:text="@string/hello_world"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="10dp"/>

    </RelativeLayout>

2、直接看實現的程式碼:

public class MainActivity extends ActionBarActivity {
    private Button btn_share;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn_share = (Button) findViewById(R.id.btn_share);
        btn_share.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                shareBySystem();
            }
        });
    }

    /**
     * 通過系統的元件進行分享
     */
    private void shareBySystem(){
        Intent intent = new Intent(Intent.ACTION_SEND);
        intent.setType("image/*");
        intent.putExtra(Intent.EXTRA_SUBJECT,"Share");
        //設定分享的內容
        intent.putExtra(Intent.EXTRA_TEXT, "I have successfully)");
        intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        startActivity(Intent.createChooser(intent, getTitle()));
    }

僅僅通過系統的Intent元件來指定我們分享的內容即可,下面來看下效果圖。

intent

我們看到上面有了我們的分享功能,效果還不錯,但是我們憂愁的發現,沒有我們常見的QQ、新浪微博、豆瓣啊!確實,這就是它的侷限性,簡單,但是不一定能達到我們的特殊需求,此時,第三方的SDK火速前來救駕,用到它的時候出現了。

二、第三方元件ShareSDK的使用

我們知道,當我們分享到騰訊、新浪這些主流社交平臺時,肯定需要他們提供的不同SDK來進行支援,如果我們支援十幾種平臺,豈不是很麻煩,怎搞?既然有需求,肯定有商機,所以這個問題早被人家給解決了,即我們即將學習的ShareSDK的使用。下面我們分步驟介紹下它的使用。

1、在mob官網進行註冊一個開發者賬號,然後填寫相關的認證資訊即可。

2、下載官方提供的SDK。我已經下載好了,最新版本v2.6.3,下載地址sdk下載地址

3、進入ShareSDK解壓目錄,開啟“Share SDK for Android”目錄,可以找到“QuickIntegrater.jar”,這個就是快速整合ShareSDK的工具,我們雙擊該工具,選擇我們要分享的平臺,填寫好事例名稱和包名,點選【確定】,然後系統自動給我們生成一個我們需要的demo。

sdk

4、我們賦值資料夾下的對應檔案,拷貝到我們工程目錄即可。

project

5、至此,所有需要的檔案都已經拷貝到我們工程中,我們接下來就是修改Manifest檔案的配置。

(1)、新增許可權:

<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" />

(2)、配置我們分享的主流平臺的Activity檔案,例如:

<!-- QQ客戶端回撥 -->
        <activity 
            android:name="cn.sharesdk.tencent.qq.ResultReceiver"
            android:launchMode="singleTask"
            android:noHistory="true">
            <!--
                如果整合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" />
        <!-- 易信分享回撥 -->
        <activity
            android:name=".yxapi.YXEntryActivity"
            android:theme="@android:style/Theme.Translucent.NoTitleBar"
            android:configChanges="keyboardHidden|orientation|screenSize"
            android:excludeFromRecents="true"
            android:exported="true"
            android:launchMode="singleTop" />        
        <!-- 支付寶分享回撥 -->
        <activity
            android:name=".apshare.ShareEntryActivity"
            android:theme="@android:style/Theme.Translucent.NoTitleBar"
            android:configChanges="keyboardHidden|orientation|screenSize"
            android:exported="true"/>

        <!-- 呼叫新浪原生SDK,需要註冊的activity -->
        <activity
            android:name="com.sina.weibo.sdk.component.WeiboSdkBrowser"
            android:configChanges="keyboardHidden|orientation"
            android:windowSoftInputMode="adjustResize"
            android:exported="false" >
        </activity>

        <!-- 呼叫新浪原生SDK,需要註冊的回撥activity -->
        <activity
            android:name="cn.sharesdk.sina.weibo.SinaActivity"
            android:theme="@android:style/Theme.Translucent.NoTitleBar">
            <intent-filter>
                <action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY" />
                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>

6、我們知道我們使用第三方的SDK,他們都會要求我們提供應用的App_key進行識別,所以ShareSDK也不例外,在做第4步時,我們需要將assets資料夾下的一個xml檔案進行拷貝,這個檔案裡面包含了我們分享的各個平臺的App_key資訊,例如:

sharesdk

7、至此,所有配置基本完成,我們只需要在程式碼中呼叫分享功能即可。

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);
         }

然後我們在Button的onClick事件中進行響應即可。

btn_share.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                showShare();
            }
        });

至此,我們使用ShareSDK的快速整合已經完成了。注意,ShareSDK僅僅是一個將個平臺的分享整合的一個工具,我們還是要去各個社交平臺去註冊賬戶,然後註冊應用資訊,才能獲取對應的App_key進行使用。看看效果圖吧!

sharesdkpic

這個就是一個簡單的快速整合介紹,更多高階功能肯定不會這麼簡單,比如這裡的方向,彈出的對話方塊的樣式,都是固定死的,不夠靈活,我們可以自己定製,在下篇部落格中在來學習下高階的用法。原始碼地址

相關文章