Android 微信分享與QQ分享功能(原生實現)
微信分享與QQ分享功能現在都挺常見的,可以根據一些第三方社會化分功能快速實現,不過多多少少都不怎麼純淨,最好都是自己看官方文件來實現就最好了~
一、微信分享
微信分享功能需要先在微信開放平臺註冊應用並獲取APP ID,就可以獲得微信提供的基本介面了
APP ID是對應唯一的應用包名和簽名的,所以即使你的應用變了,只要包名和使用的簽名key檔案不變,就可以繼續使用該ID
首先下載微信SDK,匯入libammsdk.jar
檔案
宣告需要的許可權
<!-- 微信需要的許可權 -->
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
- 1
- 2
- 3
- 4
- 5
- 6
微信分享功能有個比較坑爹的地方,就是如果想要實現分享後回撥,就需要建立指定的包名和Activity名
在主包名下建立一個wxapi包,然後再建立一個Activity,命名為:WXEntryActivity,實現IWXAPIEventHandler介面,用於分享後回撥
佈局檔案有兩個按鈕即可
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_share_entry"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="shareWXSceneSession"
android:text="分享給微信好友" />
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="shareWXSceneTimeline"
android:text="分享到朋友圈" />
</LinearLayout>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
微信分享的全部程式碼
public class WXEntryActivity extends AppCompatActivity implements IWXAPIEventHandler {
private String APP_ID = "填入你自己的ID";
private IWXAPI iwxapi;
enum SHARE_TYPE {Type_WXSceneSession, Type_WXSceneTimeline}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_wxentry);
iwxapi = WXAPIFactory.createWXAPI(this, APP_ID, false);
iwxapi.handleIntent(getIntent(), this);
iwxapi.registerApp(APP_ID);
}
public void shareWXSceneSession(View view) {
share(Type_WXSceneSession);
}
public void shareWXSceneTimeline(View view) {
share(Type_WXSceneTimeline);
}
private void share(SHARE_TYPE type) {
WXWebpageObject webpageObject = new WXWebpageObject();
webpageObject.webpageUrl = "http://www.initobject.com/";
WXMediaMessage msg = new WXMediaMessage(webpageObject);
msg.title = "Hi,Tips";
msg.description = "這是一個校園應用";
Bitmap thumb = BitmapFactory.decodeResource(getResources(), R.drawable.ninja);
msg.thumbData = bmpToByteArray(thumb, true);
SendMessageToWX.Req req = new SendMessageToWX.Req();
req.transaction = buildTransaction("Req");
req.message = msg;
switch (type) {
case Type_WXSceneSession:
req.scene = WXSceneSession;
break;
case Type_WXSceneTimeline:
req.scene = WXSceneTimeline;
break;
}
iwxapi.sendReq(req);
finish();
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
iwxapi.handleIntent(intent, this);
}
@Override
public void onReq(BaseReq baseReq) {
}
@Override
public void onResp(BaseResp resp) {
String result;
switch (resp.errCode) {
case BaseResp.ErrCode.ERR_OK:
result = "分享成功";
break;
case BaseResp.ErrCode.ERR_USER_CANCEL:
result = "取消分享";
break;
case BaseResp.ErrCode.ERR_AUTH_DENIED:
result = "分享被拒絕";
break;
default:
result = "傳送返回";
break;
}
Toast.makeText(this, result, Toast.LENGTH_SHORT).show();
finish();
}
private String buildTransaction(final String type) {
return (type == null) ? String.valueOf(System.currentTimeMillis()) : type + System.currentTimeMillis();
}
public static byte[] bmpToByteArray(final Bitmap bmp, final boolean needRecycle) {
ByteArrayOutputStream output = new ByteArrayOutputStream();
bmp.compress(Bitmap.CompressFormat.PNG, 100, output);
if (needRecycle) {
bmp.recycle();
}
byte[] result = output.toByteArray();
try {
output.close();
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
- 101
- 102
- 103
微信分享及收藏目前支援文字、圖片、音樂、視訊、網頁共五種型別,可以分享至微信好友會話、朋友圈或新增到微信收藏
分享或收藏的目標場景,通過修改scene場景值實現。
傳送到聊天介面——WXSceneSession
傳送到朋友圈——WXSceneTimeline
新增到微信收藏——WXSceneFavorite
- 1
- 2
- 3
- 4
當中 onResp(BaseResp resp)
用於分享後回撥
實現IWXAPIEventHandler介面,微信傳送的請求將回調到onReq方法,傳送到微信請求的響應結果將回調到onResp方法 bmpToByteArray(final Bitmap bmp, final boolean needRecycle)
用於解析圖片
注意,在這裡我使用到的分享的本地圖片是R.drawable.ninja
,微信對圖片大小有限制,我測試時因為圖片太大所以一直分享不成功,最後使用了這張9kb大小的圖片才成功
此外,微信文件中宣告需要為WXEntryActivity宣告exported屬性
<activity
android:name=".wxapi.WXEntryActivity"
android:exported="true" />
- 1
- 2
- 3
這樣,微信分享功能就完成了
二、QQ分享
QQ分享功能同樣需要到QQ互聯官網申請APP ID
下載官方SDK,匯入open_sdk_r5756.jar
檔案
宣告需要的許可權
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
- 1
- 2
還需要宣告兩個Activity
<!--QQ宣告的Activity-->
<activity
android:name="com.tencent.connect.common.AssistActivity"
android:configChanges="orientation|keyboardHidden|screenSize"
android:theme="@android:style/Theme.Translucent.NoTitleBar" />
<activity
android:name="com.tencent.tauth.AuthActivity"
android:launchMode="singleTask"
android:noHistory="true">
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="tencent(加入你自己的ID,不包括括號)" />
</intent-filter>
</activity>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
然後再新建一個Activity,對包名和Activity名沒有要求,我這裡命名為QQActivity,再實現IUiListener介面
佈局檔案有兩個按鈕即可
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/activity_share_entry"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="shareToQQ"
android:text="分享給好友" />
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="shareToQZone"
android:text="分享到QQ空間" />
</LinearLayout>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
public class QQActivity extends AppCompatActivity implements IUiListener {
private Tencent mTencent;
private String APP_ID = "你自己的ID";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_qq);
mTencent = Tencent.createInstance(APP_ID, getApplicationContext());
}
public void shareToQQ(View view) {
}
public void shareToQZone(View view) {
Bundle params = new Bundle();
params.putInt(QQShare.SHARE_TO_QQ_KEY_TYPE, QQShare.SHARE_TO_QQ_TYPE_DEFAULT);
params.putString(QQShare.SHARE_TO_QQ_TITLE, "Hi,葉應是葉");
params.putString(QQShare.SHARE_TO_QQ_SUMMARY, "歡迎訪問我的部落格");
params.putString(QQShare.SHARE_TO_QQ_TARGET_URL, "http://blog.csdn.net/new_one_object");
params.putString(QQShare.SHARE_TO_QQ_IMAGE_URL, "http://avatar.csdn.net/B/0/1/1_new_one_object.jpg");
params.putString(QQShare.SHARE_TO_QQ_APP_NAME, "HiTips");
params.putInt(QQShare.SHARE_TO_QQ_EXT_INT, QQShare.SHARE_TO_QQ_FLAG_QZONE_AUTO_OPEN);
mTencent.shareToQQ(this, params, this);
}
@Override
public void onComplete(Object o) {
Toast.makeText(this, o.toString(), Toast.LENGTH_LONG).show();
}
@Override
public void onError(UiError uiError) {
Toast.makeText(this, uiError.errorMessage + "--" + uiError.errorCode + "---" + uiError.errorDetail, Toast.LENGTH_LONG).show();
}
@Override
public void onCancel() {
Toast.makeText(this, "取消", Toast.LENGTH_SHORT).show();
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (mTencent != null) {
Tencent.onActivityResultData(requestCode, resultCode, data, this);
}
super.onActivityResult(requestCode, resultCode, data);
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
程式碼比較簡單,思路比較容易理解
不過這裡有個問題一直解決不了,可以分享到QQ空間,也可以分享到QQ收藏,就是無法傳送給QQ好友,研究了很久一直無法解決,知道原因的童鞋麻煩指點下=_=
相關推薦
Android 微信分享與QQ分享功能(原生實現)
微信分享與QQ分享功能現在都挺常見的,可以根據一些第三方社會化分功能快速實現,不過多多少少都不怎麼純淨,最好都是自己看官方文件來實現就最好了~一、微信分享微信分享功能需要先在微信開放平臺註冊應用並獲取APP ID,就可以獲得微信提供的基本介面了APP ID是對應唯一的應用包名
android中關於圖片分享到QQ或者微信,朋友圈及其他(免SDK)
最近又做了一個關於圖片分享到朋友圈的一個小功能,起先想到的是要新增比如QQ 或者微信以及其他工具的API,但是很麻煩,還要申請一些亂七八糟的東西並且得通過,才能用。 於是就在網上找一些關於圖片分享的資料,僅供參考(親測可用),,僅限圖片的分享,但是免去了上面所說的那些繁瑣
android 微信登入與分享整合
android微信登入與分享這兩個功能是很常用的,尤其是現在微信使用者日益劇增,qq雖然很經典但是感覺大多數用來辦公每個寫android的小夥伴估計都會寫到這個功能,我也是很久沒有寫android了,這相當於是在畢業之後工作上面第一次寫安卓程式,不管會不會,就是寫。總會有辦法解決問題的。 二、準備工
Android中的微信、支付寶支付功能的簡單實現
眾所周知如果想使用像支付寶的支付功能或者微信的支付功能,前提是必須得先去各自的開發者平臺上建立賬戶獲得appkey,但是在申請的時候需要提交各自材料,如下圖所示: 可以看到申請時需要的材料非常多,不管是企業支付還是個體都需要一系列的材料,但是像我們這樣的個
微信授權登陸接入第三方App(步驟總結)Android
這幾天開發要用到微信授權的功能,所以就研究了一下。可是微信開放平臺接入指南里有幾個地方寫的不清不楚。在此總結一下,以便需要的人。 很多微信公眾平臺的應用如果移植到app上的話就需要微信授權登陸了。 目前移動應用上微信登入只提供原生的登入方式,需要使用者安裝微信客戶端才能配合使用。也就是如果第三
Android 微信 支付寶支付,2行程式碼實現支付
作者簡介 微信公眾號(高質量文章推送):走向全棧工程師 作者:陳博易 宣告:本文是個人原創,未經允許請勿轉載 商業合作請在微信公眾號回覆:聯絡方式 前言 現在的多數App都離不開整合阿里支付寶支付和微信支付
微信授權登陸接入第三方App(步驟總結)Android。
這幾天開發要用到微信授權的功能,所以就研究了一下。可是微信開放平臺接入指南里有幾個地方寫的不清不楚。在此總結一下,以便需要的人。 很多微信公眾平臺的應用如果移植到app上的話就需要微信授權登陸了。 目前移動應用上微信登入只提供原生的登入方式,需要使用者安裝
利用redis實現位置搜尋功能(類似:微信附近的人,根據座標來實現)
利用redis實現位置搜尋功能(類似:微信附近的人,根據座標來實現,測試可行,沒實際用到) 1. 利用redis的geo功能 主要功能有: geoadd key longitude latitude member … 新增成員經緯度 # 添加了
微信小程序實戰之 pay(支付頁面)
pos 9.png bubuko image status xss java htm gin 項目目錄: 邏輯層: pay.js // pages/pay/pay.js Page({ /** * 頁面的初始數據 */ data: { res
微信公眾號支付開發全過程(java版)
sdk 命令 所有 data 權限 {} servle res ast 文章有不當之處,歡迎指正,如果喜歡微信閱讀,你也可以關註我的微信公眾號:好好學java,獲取優質學習資源。 一、微信官方文檔微信支付開發流程(公眾號支付) 首先我們到微信支付的官方文檔的開發步驟部分查
微信小程序學習筆記三(持續更新)---小程序組件通信
操作 nts bin json view data 組件 學習 所有 參照這裏 這裏將重要的點貼一下: 一、項目目錄結構 在項目同級目錄新建components文件夾,新建component會生成wxml,wxss,js,json文件。將所有的公共組件都寫在此文件夾下。 二
微信小程序學習筆記五(持續更新)---小程序上傳文件
gin false round count splice dex 一個 key 屬性 項目中需要用戶上傳圖片,需要實現,上傳按鈕默認為一個,在上傳一張圖片之後,自動增加一個上傳按鈕,上傳三張圖片後按鈕消失。 實現思路: 1、圖片路徑存儲在一個數組中,增加和刪除圖片是對數組進
微信小程式——下拉重新整理(分頁)
1、先定義兩個變數: // 分頁,載入 hasMoreData:true, globalPage:0, 2、函式處理: 3、與後臺互動: 1)、在獲取列表的方法裡面,將下面兩個引數以及其他所需
微信小程式使用第三方庫(第三方js)問題
原文:https://blog.csdn.net/u012421719/article/details/56676801 比如很多人會有這樣的問題: 小程式怎樣引用第三方js呢?
【WEB開發】微信網頁授權第三方登入介面(WEB登入)
本文連結至:http://blog.csdn.net/hxker/article/details/50260669 第一步:獲取AppID AppSecret(不做解釋,自己去微信公眾平臺申請) 第二步:生成掃描二維碼,獲取code https://open
微信小程式學習筆記二(持續更新)---小程式網路請求封裝
寫小程式的你是否已經厭倦了傳送網路請求的wx.request?接著看吧。。。 一、目錄結構 在專案同級目錄下utils資料夾裡新建一個fetch.js檔案,(名字看自己喜好) 二、直接上程式碼 // 定義網路請求API地址 const baseURL = 'h
微信小程式學習筆記四(持續更新)---征服scroll-view下拉重新整理
貼圖 大概實現這種使用swiper做tab切換,資料頁面下拉重新整理的效果。 官方提供的scroll-view作為容器,如果在scroll-view使用onPullDownRefresh實現下拉重新整理,會存在頁面重新整理卡,並且重新整理會出現在tab之上,使
微信小程式,全域性樣式(總的樣式)和區域性樣式(頁面樣式)的用法和區別。
首先,全域性樣式寫在app.wxss裡面, 當然,頁面樣式當然寫在各個頁面的樣式裡, 第二 ,呼叫全域性樣式需要在你寫的類後面或前面加上你全域性樣式定義的類,(樣式的類越排後面,優先順序越高!) 比如: 這是我定義的全域性樣式 然後我要在區域性樣式裡呼叫
微信推送模板資訊介面(乾貨-程式碼)
這裡僅針對推送模板資訊進行程式碼整理~~~ 本文分為以下三個部分: 一、申請模板訊息許可權 二、開發模板訊息SDK 三、JAVA程式碼實現傳送模板訊息 一、申請模板訊息許可權 模板訊息的申請需微信公眾賬號已經認證通過。 在微信公眾平
007-01、微信小程式---元件之swiper(tab切換)
此tab切換以登入頁面為參照。 1、WXMl <view class="tab-title"> <block wx:for="{{msg}}" wx:key="myke