友盟分享之微信分享
項目中使用了友盟-微信分享。
想要在分享回調(diào)中處理一些邏輯,比如說關(guān)閉預(yù)覽頁面,提示分享結(jié)果等。按照友盟文檔,一步一步操作下來,分享-預(yù)覽頁面-選擇微信-跳轉(zhuǎn)分享,通過微信分享之后,選擇"返回xxx",理論上是觸發(fā)分享回調(diào),關(guān)閉預(yù)覽頁面。但是,直接結(jié)果卻是分享回調(diào)不執(zhí)行。。。
郁悶,不應(yīng)該啊,,,
回到代碼中,發(fā)現(xiàn)分享回調(diào)不執(zhí)行。
private val mUMShareListener = object : UMShareListener {override fun onStart(platform: SHARE_MEDIA?) {// startToastUtils.showCenterToast("正在執(zhí)行分享...")}override fun onResult(platform: SHARE_MEDIA?) {Trace.e("ShareImage","onResult")finishAct()}override fun onError(platform: SHARE_MEDIA?, error: Throwable?) {Trace.e("ShareImage","onError:${error?.message}")finishAct()}override fun onCancel(platform: SHARE_MEDIA?) {Trace.e("ShareImage","onCancel")finishAct()}}分享邏輯沒問題啊,再看看微信回調(diào)Activity-----WXEntryActivity
這個Activity所在路徑不能配置錯誤,一定是應(yīng)用的包名。這里,因為使用的是友盟,所以需要繼承的是
import com.umeng.socialize.weixin.view.WXCallbackActivity class WXEntryActivity: WXCallbackActivity(), IWXAPIEventHandler {// 微信登錄消息處理類override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)WeiChatLoginManager.getWeiChatApi()?.handleIntent(intent, this)}override fun onNewIntent(intent: Intent?) {super.onNewIntent(intent)WeiChatLoginManager.getWeiChatApi()?.handleIntent(intent, this)}override fun onReq(request: BaseReq?) {// 微信發(fā)送請求到第三方應(yīng)用時,會回調(diào)到該方法Log.d("xxx", "WXEntryActivity:[onReq] openId=${request?.openId}, transaction=${request?.transaction}, type=${request?.type}")}override fun onResp(response: BaseResp?) {Log.d("xxx", "WXEntryActivity:[onResp] code=${response?.errCode}, msg=${response?.errStr}")if (response == null) { finishMyself(); return }when (response.errCode) {BaseResp.ErrCode.ERR_AUTH_DENIED, BaseResp.ErrCode.ERR_USER_CANCEL -> {// 登錄或者分享失敗if (WeiChatLoginManager.WEICHAT_RESPONSE_MSG_TYPE_LOGIN == response.type) {WeiChatLoginManager.dealWithLoginResponse(null, "已取消登錄")}}BaseResp.ErrCode.ERR_OK -> {// 登錄或者分享成功if (WeiChatLoginManager.WEICHAT_RESPONSE_MSG_TYPE_LOGIN == response.type) {if (response is SendAuth.Resp) {WeiChatLoginManager.dealWithLoginResponse(response.code)} else {WeiChatLoginManager.dealWithLoginResponse(null)}}}}}}看到這里的邏輯,明白了問題出現(xiàn)的原因了。
因為很早之前集成了微信登錄,所以在這里處理了一些邏輯,正是原來的這些邏輯影響到了分享的回調(diào)。就是上述這個邏輯,當(dāng)時只是處理了登錄的情況,而對分享、支付等情況沒有做處理。
修改如下:
override fun onResp(response: BaseResp?) {Trace.d("xxx", "WXEntryActivity:[onResp] code=${response?.errCode}, msg=${response?.errStr}")if (response == null || response.type == null) { finishMyself(); return }when(response.type) {WeiChatLoginManager.WEICHAT_RESPONSE_MSG_TYPE_LOGIN -> { // 登錄when (response.errCode) {BaseResp.ErrCode.ERR_AUTH_DENIED, BaseResp.ErrCode.ERR_USER_CANCEL -> {// 登錄或失敗WeiChatLoginManager.dealWithLoginResponse(null, "已取消登錄")}BaseResp.ErrCode.ERR_OK -> {// 登錄成功if (response is SendAuth.Resp) {WeiChatLoginManager.dealWithLoginResponse(response.code)} else {WeiChatLoginManager.dealWithLoginResponse(null)}}}}else -> { // 分享等super.onResp(response)}}finishMyself()}?然后調(diào)試,友盟分享的回調(diào)可正常執(zhí)行。
總結(jié)
- 上一篇: notify()唤醒线程,不会立即释放锁
- 下一篇: interrupt()会中断线程的wai