編輯:Android資訊
隨著現在社交網絡的日益繁多,眾多的社交客戶端已占據了人們的大量時間,所以在我們的應用中具有一鍵分享的功能對提高我們產品的知名度有很大的幫助。新浪微博、騰訊微博、騰訊QQ、微信、QQ空間、豆瓣等眾多知名社交站點,都是我們可以分享的去處,當然,分享功能涉及到別人第三方的權益,肯定是由他們提供SDK等支持,我們才能進行分享使用。既然分享如何重要,那麼我們就該學習下Android系統如何實現分享功能。
現在在Android系統中進行分享,主要有兩種手段,一種是通過系統自帶的來啟動分享功能;第二種是通過第三方的SDK插件進行分享;下面我們來簡要介紹下兩種手段:
毫無疑問,通過系統來啟動的分享功能很簡單,也非常容易實現,我們直接來寫個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組件來指定我們分享的內容即可,下面來看下效果圖。

我們看到上面有了我們的分享功能,效果還不錯,但是我們憂愁的發現,沒有我們常見的QQ、新浪微博、豆瓣啊!確實,這就是它的局限性,簡單,但是不一定能達到我們的特殊需求,此時,第三方的SDK火速前來救駕,用到它的時候出現了。
我們知道,當我們分享到騰訊、新浪這些主流社交平台時,肯定需要他們提供的不同SDK來進行支持,如果我們支持十幾種平台,豈不是很麻煩,怎搞?既然有需求,肯定有商機,所以這個問題早被人家給解決了,即我們即將學習的ShareSDK的使用。下面我們分步驟介紹下它的使用。
1、在mob官網進行注冊一個開發者賬號,然後填寫相關的認證信息即可。
2、下載官方提供的SDK。我已經下載好了,最新版本v2.6.3,下載地址sdk下載地址
3、進入ShareSDK解壓目錄,打開“Share SDK for Android”目錄,可以找到“QuickIntegrater.jar”,這個就是快速集成ShareSDK的工具,我們雙擊該工具,選擇我們要分享的平台,填寫好事例名稱和包名,點擊【確定】,然後系統自動給我們生成一個我們需要的demo。

4、我們賦值文件夾下的對應文件,拷貝到我們工程目錄即可。

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信息,例如:

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進行使用。看看效果圖吧!

這個就是一個簡單的快速集成介紹,更多高級功能肯定不會這麼簡單,比如這裡的方向,彈出的對話框的樣式,都是固定死的,不夠靈活,我們可以自己定制,在下篇博客中在來學習下高級的用法。源碼地址
深入理解Android異步消息處理機制
一、概述 Android 中的異步消息處理主要分為四個部分組成,Message、Hndler、MessageQueue 和 Looper。其關系如下圖所示: 1
Android端應用秒開優化體驗
前言 最近部門內拋出了一個問題,應用啟動很慢、卡圖標?主要表現在中低端機型中。究其這個問題,由於對性能優化比較感興趣,借了個低端機和一個中端機來一看究竟,對同一應
Android NestedScrolling 實戰
從 Android 5.0 Lollipop 開始提供一套 API 來支持嵌入的滑動效果。同樣在最新的 Support V4 包中也提供了前向的兼容。有了嵌入滑動
關於Android中工作者線程的思考
本文系2015 北京 GDG Devfest分享內容整理。 在Android中,我們或多或少使用了工作者線程,比如Thread,AsyncTask,Handler