微信分享中的回调处理-OnResp

1.回调代理方法的位置,是在AppDelegate还是指定界面

  • 在微信所给的demo中是通过委托让AppDelegate.m中来执行回调方法的,但在实际项目中确会把分享相关的代码写在自定义的控制器中,这就需要指定的界面作为代理执行回调方法
  • 实例化一个控制器,作为代理,且添加协议
@interface ShareViewController : BaseViewController<WXApiDelegate>

-(BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url{//9.0-

    ShareViewController  *shareVC = [[ShareViewController alloc] init];
    return [WXApi handleOpenURL:url delegate:shareVC];
}

-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options//9.0+
{
    ShareViewController *shareVC =[[ShareViewController alloc] init];
    return [WXApi handleOpenURL:url delegate:shareVC];
}

2.区分分享到朋友圈还是微信好友

  • 某些统计或特殊需求需要在分享的时候能够区分是朋友圈还是好友,但是在微信提供的SDK中,只是在分享时进行区分,回调方法中不会进行区分,这就需要自己添加标记来实现功能
  • 使用单例进行标记-[Singleton sharedSingleton].shareScene,分享之前进行标记,分享之后获取标记
  • 其中就算点击分享跳到微信,用户还是可以不进行分享操作,直接返回app的,所以,需要在标记中进行加减1000,避免这种情况
#pragma mark - 具体的分享
- (void)WXApi_ShareWebpage:(int)scene dict:(NSDictionary *)dict{
    .....

  //请求request
    SendMessageToWXReq* req = [[SendMessageToWXReq alloc] init];
    req.bText = NO;
    req.message = message;
    //1.可以选择发送到会话(WXSceneSession)或者朋友圈(WXSceneTimeline)
    req.scene = scene;
    //2.发出请求 
     [WXApi sendReq:req];
    //3.使用单例进行标记:朋友圈还是好友
    [Singleton sharedSingleton].shareScene = req.scene+10000;       
}
#pragma mark - 微信分享后的回调
-(void)onResp:(BaseResp *)resp{
   //获取分享结果 
   int errCode = resp.errCode;
   //获取分享到的位置
   [Singleton sharedSingleton].shareScene -= 10000;
   //进行判断   
   .....
}

你可能感兴趣的:(iOS)