解决UMSocial分享组件中微信收藏不同步显示的bug

最近在做友盟分享,发现UMeng一个小bug,在UMeng官方论坛搜索问题,发现有些骚年也遇到了类似的问题,那为了 让大家不再遇到此bug,特给出解决方案!

问题描述

由于苹果审核政策需求,对未安装客户端平台我们在做分享的时候就需要进行隐藏,于是我们就有了如下代码

//设置微信AppId,设置分享url,默认使用友盟的网址
[UMSocialWechatHandler setWXAppId:WXAppId appSecret:WXAppSecret url:WXAppShareURL];          
                              
//由于苹果审核政策需求,对未安装客户端平台进行隐藏
[UMSocialConfig hiddenNotInstallPlatforms:@[UMShareToSina,
                                            UMShareToQQ,
                                            UMShareToQzone, 
                                            UMShareToWechatSession,
                                           UMShareToWechatTimeline,
                                           UMShareToWechatFavorite]];
//设置你要在分享面板中出现的平台
[UMSocialConfig setSnsPlatformNames:@[UMShareToSina, UMShareToQQ, 
                                     UMShareToQzone, UMShareToWechatSession,
                                     UMShareToWechatTimeline, UMShareToWechatFavorite,
                                     UMShareToEmail, UMShareToSms]];

这样看似合情合理,运行真机发现,WTF,怎么只有微信好友以及朋友圈,我的微信收藏去哪儿了,按照道理来讲,微信收藏应该和微信好友以及朋友圈同时出现或者同时隐藏,纵使心中有一 万只草泥马在奔腾,也不能改变微信收藏这个按钮没了的事实,移动代码之前真机图片如下图:

微信收藏消失,移动代码之前

解决方案

当我移动设置微信appId和appSecret [UMSocialWechatHandler setWXAppId:WXAppId appSecret:WXAppSecret url:WXAppShareURL];这行代码到 hiddenNotInstallPlatforms 隐藏方法之后,问题解决了,代码如下

//由于苹果审核政策需求,对未安装客户端平台进行隐藏
[UMSocialConfig hiddenNotInstallPlatforms:@[UMShareToSina,
                                        UMShareToQQ,
                                        UMShareToQzone, 
                                        UMShareToWechatSession,
                                       UMShareToWechatTimeline,
                                       UMShareToWechatFavorite]];

//也就是把设置微信AppId这行代码放到[UMSocialConfig hiddenNotInstallPlatforms 之后就行了
//这样,当设置了微信AppId之后,sdk就会自动检测是否安装微信,微信收藏就可以和微信好友以及朋友圈同时出现或者同时隐藏了
//设置微信AppId,设置分享url,默认使用友盟的网址
[UMSocialWechatHandler setWXAppId:WXAppId appSecret:WXAppSecret url:WXAppShareURL];          

//设置你要在分享面板中出现的平台
[UMSocialConfig setSnsPlatformNames:@[UMShareToSina, UMShareToQQ, 
                                 UMShareToQzone, UMShareToWechatSession,
                                 UMShareToWechatTimeline, UMShareToWechatFavorite,
                                 UMShareToEmail, UMShareToSms]];

移动代码之后的效果如下图:


微信收藏显示,移动代码之后

给项目解耦

我们为了给自己项目降低耦合度,防止以后换了第三方分享api而不至于让整个项目出现变动,于是自己在中间再封装一层,以后如果换成了shareSDK就只有需要更改这一个文件,方便至极!

/* 注意分享到新浪微博我们使用新浪微博SSO授权,你需要在xcode工程设置url scheme,并重写AppDelegate中的 - (BOOL)application openURL sourceApplication方法,详细见文档。否则不能跳转回来原来的app*/
+ (void)showShareList:(UIViewController *)presentViewConrtroller UMSocialUIDelegate:(id<UMSocialUIDelegate>)delegate dictionary:(NSDictionary *)dict {

//重写邮箱点击事件,根据dict中dict[@""]添加指定的收件人
UMSocialSnsPlatform *emailPlatform = [UMSocialSnsPlatformManager getSocialPlatformWithName:UMShareToEmail];
emailPlatform.snsClickHandler = ^(UIViewController *presentingController, UMSocialControllerService * socialControllerService, BOOL isPresentInController){
    NSLog(@"点击邮箱事件被重写了");
};

//重写短信点击事件,根据dict中dict[@""]添加指定的收件人
UMSocialSnsPlatform *smsPlatform = [UMSocialSnsPlatformManager getSocialPlatformWithName:UMShareToSms];
smsPlatform.snsClickHandler = ^(UIViewController *presentingController, UMSocialControllerService * socialControllerService, BOOL isPresentInController){
    NSLog(@"点击短信事件被重写了");
};

//添加自定义复制链接按钮
UMSocialSnsPlatform *customCopyPlatform = [[UMSocialSnsPlatform alloc] initWithPlatformName:@"CustomSmsPlatform"];
customCopyPlatform.bigImageName = @"UMS_email_icon.png";
customCopyPlatform.displayName = @"复制链接";
customCopyPlatform.snsClickHandler = ^(UIViewController *presentingController, UMSocialControllerService * socialControllerService, BOOL isPresentInController){
    NSLog(@"自定义复制链接");
};
 // 让UMSocialConfig对customCopyPlatform作为一个强引用
 [UMSocialConfig addSocialSnsPlatform:@[customCopyPlatform]];
 //自定义完成后还必须设置你要在分享面板中出现的平台,上面只是保证不会把局部变量给销毁掉,要想在分享列表中显示自定义平台必须再set一次
 [UMSocialConfig setSnsPlatformNames:@[UMShareToSina,@"CustomCopyPlatform"]];


//dict[@"qqData"][@"url"];自己封装的,可以根据传过来的dict来动态生成分享title,url,shearText,sharedImage等
//dict[@"qqData"][@"title"];
//设置QQ
[UMSocialData defaultData].extConfig.qqData.url = @"http://baidu.com";
[UMSocialData defaultData].extConfig.qqData.title = @"QQ分享title";

//设置微信好友
[UMSocialData defaultData].extConfig.wechatSessionData.url = @"http://www.yunlu6.com";
[UMSocialData defaultData].extConfig.wechatSessionData.title = @"微信好友title";
//设置微信朋友圈
[UMSocialData defaultData].extConfig.wechatTimelineData.url = @"http://baidu.com";
[UMSocialData defaultData].extConfig.wechatTimelineData.title = @"微信朋友圈title";
//设置微信收藏
[UMSocialData defaultData].extConfig.wechatFavoriteData.url = @"http://dev.umeng.com/social/ios/quick-integration#2_3";
[UMSocialData defaultData].extConfig.wechatFavoriteData.title = @"微信收藏title";

//设置email,我们需要自定义收件人,就不用UM提供的了
//[UMSocialData defaultData].extConfig.emailData.title = @"http://dev.umeng.com/social/ios/quick-integration#2_3";
//设置sms,我们需要自定义收件人,就不用UM提供的了
//[UMSocialData defaultData].extConfig.smsData.

//分享内嵌文字
NSString *shareText = @"导购";//dict[shareText]
//分享内嵌图片
UIImage *shareImage = [UIImage imageNamed:@"UMS_social_demo"];//dict[shareImage]
//UIImage *shareImage = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"UMS_social_demo" ofType:@"png"]];
//调用快速分享接口
[UMSocialSnsService presentSnsIconSheetView:presentViewConrtroller
                                     appKey:UmengAppkey
                                  shareText:shareText
                                 shareImage:shareImage
                            shareToSnsNames:nil
                                   delegate:delegate];

}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容