android 分享小程序到微信,Android 使用友盟分享微信小程序到微信
Android使用友盟分享微信小程序到微信
在友盟官網上看到了相關的API,但是總是無法正常調用,下面記錄下自己的處理流程:
引入依賴
implementation 'com.umeng.umsdk:common:2.2.5'
implementation 'com.umeng.umsdk:share-core:7.0.2'
implementation 'com.umeng.umsdk:share-board:7.0.2'
//為支持微信分享的模塊
implementation 'com.umeng.umsdk:share-wx:7.0.2'
添加所需權限,創建微信所需的Activity
請在AndroidManifest中添加如下權限
并在AndroidManifest中添加如下代碼(需要提前創建好Activity):
android:configchanges="keyboardHidden|orientation|screenSize"
android:exported="true" android:launchmode="singleTask"
android:name=".wxapi.WXEntryActivity"
android:taskaffinity="net.sourceforge.simcpux"
android:theme="@android:style/Theme.Translucent.NoTitleBar">
在你的項目包中創建wxapi包,并創建WXEntryActivity.class
public class WXEntryActivity extends WXCallbackActivity implements IWXAPIEventHandler {
private IWXAPI wxapi= BaseApplication.getInstance().getWxApi();
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
wxapi.handleIntent(intent, this);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
wxapi.handleIntent(getIntent(), this);
}
@Override
public void onReq(BaseReq baseReq) {
LogUtils.d(baseReq:+baseReq.openId);
}
@Override
public void onResp(BaseResp baseResp) {
if (baseResp.getType()==ConstantsAPI.COMMAND_SENDMESSAGE_TO_WX){
finish();
}else if(baseResp.getType()==ConstantsAPI.COMMAND_SENDAUTH){
LogUtils.d(返回授權+baseResp.errCode);
switch (baseResp.errCode) {
case BaseResp.ErrCode.ERR_OK:
LogUtils.d(返回Code:+((SendAuth.Resp) baseResp).code);
EventBus.getDefault().post(new EventMessage(CodeManager.BIND_PHONE,((SendAuth.Resp) baseResp).code));
break;
case BaseResp.ErrCode.ERR_USER_CANCEL:
case BaseResp.ErrCode.ERR_AUTH_DENIED:
case BaseResp.ErrCode.ERR_UNSUPPORT:
break;
}
finish();
}
}
}
由于我在項目中集成了其他微信相關的SDK,讀者只用關注這個 WXEntryActivity需要繼承 WXCallbackActivity 以及實現 IWXAPIEventHandler 這兩個類。
在自定義的 BaseApplication 的 onCreate 方法中需要注冊友盟
...
@Override
public void onCreate() {
super.onCreate();
initUmeng();
}
private void initUmeng() {
// 在此處調用基礎組件包提供的初始化函數 相應信息可在應用管理 -> 應用信息 中找到 http://message.umeng.com/list/apps
// 參數一:當前上下文context;
// 參數二:應用申請的Appkey;
// 參數三:渠道名稱;
// 參數四:設備類型,必須參數,傳參數為UMConfigure.DEVICE_TYPE_PHONE則表示手機;傳參數為UMConfigure.DEVICE_TYPE_BOX則表示盒子;默認為手機;
// 參數五:Push推送業務的secret 填充Umeng Message Secret對應信息(需替換)
UMConfigure.init(this, 應用在友盟申請的Appkey, Umeng, UMConfigure.DEVICE_TYPE_PHONE, 沒有使用推送服務,傳空字符串就行);
//開通微信分享 第一個值為app在微信注冊時的AppID 第二個值是你們軟件注冊時的AppSecret
PlatformConfig.setWeixin(wx*************, *******AppSecret****);
}
注意!這里一定要添加開通微信分享的代碼,否則點擊分享按鈕將沒有任何反應!!! PlatformConfig.setWeixin("wx*************", "*******AppSecret****");
分享小程序到微信
我將分享邏輯放在彈窗點擊事件里
private void showShareDialog(DistributionMyGoodsBean.ListBean listBean) {
//分享
ShareDialog shareDialog = new ShareDialog(mContext, false);
shareDialog.setOnButtonListener(new ShareDialog.OnButtonListener() {
@Override
public void onWeChatClick() {
ToastUtils.showShort(微信分享);
//兼容低版本的網頁鏈接
UMMin umMin = new UMMin(你想要兼容的網頁鏈接,需要帶上http://);
// 小程序消息封面圖片
umMin.setThumb(new UMImage(mContext, listBean.getImage()));
// 小程序消息title
umMin.setTitle(listBean.getTitle());
//小程序頁面路徑
umMin.setPath(/pages/小程序對應的頁面鏈接);
//小程序原始id,在微信平臺查詢
umMin.setUserName(gh_***********);
//設置小程序版本
//預覽版
Config.setMiniPreView();
//測試版
Config.setMiniTest();
new ShareAction((Activity) mContext)
.setPlatform(SHARE_MEDIA.WEIXIN)
.withMedia(umMin)
.setCallback(shareListener)
.share();
}
@Override
public void onCircleFriendsClick() {
//小程序目前無法分享小程序到朋友圈
}
});
shareDialog.show();
}
注意:在分享小程序之前是必須要設置小程序的版本的,不然點開微信鏈接會報錯
總結
以上是生活随笔為你收集整理的android 分享小程序到微信,Android 使用友盟分享微信小程序到微信的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Network Architectur
- 下一篇: java for循环的这种写法怎么理解: