Android社會化分享功能的實現步驟

衆所周知,互聯網是一個資源共享的地方,在網絡上,咱們能夠分享咱們全部認爲好的資源。而隨着互聯網信息爆發式的增加,咱們習慣了一鍵分享功能,好比:微博分享、微信分享、QQ空間分享、人人網分享等等。因而可知分享是很重要的一個客戶體驗功能,那在移動端,咱們怎樣實現分享功能呢?android

從Android系統的社會分享功能來看,實現手段主要有兩種:一種是經過系統自帶的來啓動分享功能;第二種是經過第三方的SDK插件進行分享;具體實現方式以下。api

 

1、Android系統啓動分享功能微信

系統啓動分享功能很簡單,實現也很容易,下面經過一個demo爲你們展現一下:網絡

一、仍是先看一個佈局文件,佈局文件很簡單,僅僅一個button按鈕來觸發分享功能便可:app

 

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"ide

  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>

 

二、直接看實現的代碼:

 

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組件來指定咱們分享的內容便可,效果圖以下:

 

從圖片中,能夠看出分享功能已經實現,可是問題來了,這種方式實現的分享功能卻沒有你們經常使用的QQ、新浪微博、豆瓣等!這就是這種分享功能實現的侷限性,雖然實現簡單,可是不必定能達到咱們的特殊需求。爲解決這個問題,咱們就須要用到,第三方的SDK插件了。

 

2、第三方組件ShareSDK的使用

      要分享東西到騰訊、新浪這些主流社交平臺時,沒有他們提供的SDK支持是不可能實現的,那麼問題又來了,若是要分享到十幾種平臺豈不是須要十幾種SDK插件?其實咱們能夠直接用ShareSDK的解決,下面就一塊兒來看看他的具體實現步驟吧。

一、在 mob官網註冊一個開發者帳號,而後填寫相關的認證信息便可。

二、下載官方提供的SDK。

三、進入ShareSDK解壓目錄,打開「Share SDK for Android」目錄,能夠找到「QuickIntegrater.jar」,這個就是快速集成ShareSDK的工具,咱們雙擊該工具,選擇咱們要分享的平臺,填寫好事例名稱和包名,點擊【肯定】,而後系統自動給咱們生成一個咱們須要的demo,以下圖:

四、咱們賦值文件夾下的對應文件,拷貝到咱們工程目錄便可。

 

五、至此,全部須要的文件都已經拷貝到咱們工程中,咱們接下來就是修改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>

 

六、使用第三方的SDK,他們都會要求咱們提供應用的App_key進行識別,因此ShareSDK也不例外,在作第4步時,咱們須要將assets文件夾下的一個xml文件進行拷貝,這個文件裏面包含了咱們分享的各個平臺的App_key信息,例如:

 

七、至此,全部配置基本完成,咱們只須要在代碼中調用分享功能便可。

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進行使用。效果以下:

 

以上就是Android社會化分享最基本功能的簡單介紹,固然Android分享還有不少高級的功能,在之後的分享中小編將爲你們一一介紹。同時,也但願經過本文的分享,對Android初學者這塊功能的學習、使用有所幫助。

相關文章
相關標籤/搜索