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;
//进行判断
.....
}