ShareSDK 集成文档 http://wiki.sharesdk.cn/%E5%BF%AB%E9%80%9F%E9%9B%86%E6%88%90%E6%8C%87%E5%8D%97/
注意点:
1.配置ShareSDK的appkey和appSecret时,安卓的和iOS的可以用同一个
[ShareSDK connectTencentWeiboWithAppKey:@"302147650"
appSecret:@"ae54f4rerer6e1c232423b543569fdfdfdff5c"
redirectUri:@"http://www.sharesdk.cn"
wbApiCls:[WeiboApi class]];
2.QQ和QQ空间的appkey是用同一个
3.在mob上创建应用时,iOS和安卓要分开创建
4. [container setIPadContainerWithView:sender arrowDirect:UIPopoverArrowDirectionUp];
如果没有做iPad的话,可以不用添加这一句
5.集成文档中的第六步一定要认真做
6.实现回调,因为之前接入了腾讯登录的SDK,所以在回调函数中需要实现两个回调函数。(跳客户端需要处理客户端回调,像微信,QQ,如果不加的话,那么回调不能返回成功,只能返回取消)
解决方法1:判断url的前缀,每个SDK的前缀是独一无二的,可以打印url获取
参考代码:
NSString *string = [url absoluteString];
if ([string hasPrefix:@"ShareSDKurl的前缀"]) {
return [ShareSDK handleOpenURL:url sourceApplication:sourceApplication annotation:annotation wxDelegate:self];
} else if ([string hasPrefix:@"腾讯url的前缀"]) {
return [TencentOAuth HandleOpenURL:url];
}
解决方法2:因为我们在使用到ShareSDK的分享时,也包括QQ好友分享,和QQ空间分享,它们的url的前缀跟腾讯登录SDK的url的前缀是一样的,所以我们采用了本地判断的方法解决了这一问题。
参考代码:在初始化QQ登录时将[[MobShare shareMobShare] handleType] 置为 HANDLE_QQLOGIN, 在初始化ShareSDK时将[[MobShare shareMobShare] handleType] 置为 HANDLE_SHARE,其中HANDLE_QQLOGIN和HANDLE_SHARE为枚举
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
int type = [[MobShare shareMobShare] handleType];
if (type == HANDLE_QQLOGIN) {
return [TencentOAuth HandleOpenURL:url];
} else if (type == HANDLE_SHARE) {
return [ShareSDK handleOpenURL:url sourceApplication:sourceApplication annotation:annotation wxDelegate:self];
} else {
return YES;
}
}
- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
{
int type = [[MobShare shareMobShare] handleType];
if (type == HANDLE_QQLOGIN) {
return [TencentOAuth HandleOpenURL:url];
} else if (type == HANDLE_SHARE) {
return [ShareSDK handleOpenURL:url wxDelegate:self];
} else {
return YES;
}
}
7.微信平台初始化
[ShareSDK connectWeChatWithAppId: @"wx4868b35061f87885"
appSecret: @"64020361b8ec4c99936c0e3999a9f249"
wechatCls: [WXApi class]];
这个初始化是微信总的初始化,初始化完成后,微信好友,微信朋友圈,微信收藏就都开启了,也就是在分享菜单那里就都有了图标显示了。
当然也可以分开初始化微信的这三个平台
微信好友:
[ShareSDK connectWeChatSessionWithAppId: @"wx4868b35061f87885"
appSecret: @"64020361b8ec4c99936c0e3999a9f249"
wechatCls: [WXApi class]];
微信朋友圈:
[ShareSDK connectWeChatTimelineWithAppId: @"wx4868b35061f87885"
appSecret: @"64020361b8ec4c99936c0e3999a9f249"
wechatCls: [WXApi class]];
微信收藏:
[ShareSDK connectWeChatFavWithAppId: @"wx4868b35061f87885"
appSecret: @"64020361b8ec4c99936c0e3999a9f249"
wechatCls: [WXApi class]];
8.[ShareSDK connectWeChatSessionWithAppId:WXAppid wechatCls:[WXApi class]];
[ShareSDK connectWeChatSessionWithAppId:WXAppid appSecret:WXSec wechatCls:[WXApi class]];
这两种初始化方法的区别: 第一个只能分享,第二个可以做分享和登录的功能
9.id<ISSAuthOptions> authOptions = [ShareSDK authOptionsWithAutoAuth:YES
allowCallback:YES
authViewStyle:SSAuthViewStyleFullScreenPopup
viewDelegate:nil
authManagerViewDelegate:_appDelegate.viewDelegate];
其中_appDelegate.viewDelegate是用来修改UI的委托,可以传入nil
10.初始化分享内容
id<ISSContent> publishContent = [ShareSDK content:CONTENT
defaultContent:@""
image:[ShareSDK imageWithPath:imagePath]
title:NSLocalizedString(@"TEXT_HELLO_QZONE", @"Hello QQ空间")
url:@"http://www.mob.com"
description:nil
mediaType:SSPublishContentMediaTypeText];
在初始化分享内容时,如果只分享文字的话 mediaType:SSPublishContentMediaTypeText
如果需要分享文字和图片:mediaType:SSPublishContentMediaTypeNews
11.初始化分享内容时: content是分享的内容,description是内容的描述,defaultContent是默认的分享内容,有的平台是显示content,有的平台是显示description
可以把content,description,defaultContent都填上,该显示哪个就显示哪个。
(腾讯微博显示的是content,QQ空间和QQ好友显示的是description)
12.可以自定制UI,各个平台单独初始化 (12点和13点都是在ShareSDK Demo中的AGApiViewController类中)
)
几个主要平台的初始化方法:
/**
* @brief 分享到新浪微博
*
* @param sender 事件对象
*/
- (void)shareToSinaWeiboClickHandler:(UIButton *)sender
{
//创建分享内容
NSString *imagePath = [[NSBundle mainBundle] pathForResource:IMAGE_NAME ofType:IMAGE_EXT];
id<ISSContent> publishContent = [ShareSDK content:CONTENT
defaultContent:@""
image:[ShareSDK imageWithPath:imagePath]
title:nil
url:nil
description:nil
mediaType:SSPublishContentMediaTypeText];
//创建弹出菜单容器
id<ISSContainer> container = [ShareSDK container];
[container setIPadContainerWithView:sender arrowDirect:UIPopoverArrowDirectionUp];
id<ISSAuthOptions> authOptions = [ShareSDK authOptionsWithAutoAuth:YES
allowCallback:YES
authViewStyle:SSAuthViewStyleFullScreenPopup
viewDelegate:nil
authManagerViewDelegate:_appDelegate.viewDelegate];
//在授权页面中添加关注官方微博
[authOptions setFollowAccounts:[NSDictionary dictionaryWithObjectsAndKeys:
[ShareSDK userFieldWithType:SSUserFieldTypeName value:@"ShareSDK"],
SHARE_TYPE_NUMBER(ShareTypeSinaWeibo),
[ShareSDK userFieldWithType:SSUserFieldTypeName value:@"ShareSDK"],
SHARE_TYPE_NUMBER(ShareTypeTencentWeibo),
nil]];
//显示分享菜单
[ShareSDK showShareViewWithType:ShareTypeSinaWeibo
container:container
content:publishContent
statusBarTips:YES
authOptions:authOptions
shareOptions:[ShareSDK defaultShareOptionsWithTitle:nil