友盟分享文档
http://dev.umeng.com/social/ios/quick-integration#1_3
1.1 下载并安装SDK
安装SDK可以采用CocoaPods和手动下载两种方式,选择下面其中一种来集成即可,以下只说手动集成方式
1.1.2 手动集成SDK
下载最新版的sdk:http://dev.umeng.com/social/ios/sdk-download
解压后拖拽到项目里面
1.2 添加系统需要的framework
• 添加SDK后需要手动添加系统库SystemConfiguration.framework
· 在other linker flags增加-ObjC 选项,并添加ImageIO 系统framework(实现新浪微博必须完成的步骤)
· 添加SDK依赖的系统库文件
在Xcode中打开工程配置文件,选择“summary”一栏。在“summary”中选择“Linked Frameworks and Libraries”一栏,点击“+”图标添加下面八个库文件,分别是
Security.framework
libiconv.dylib
SystemConfiguration.framework
CoreGraphics.Framework
libsqlite3.dylib
CoreTelephony.framework
libstdc++.dylib
libz.dylib
1.3 设置友盟appkey
· 获取友盟Appkey。如果你之前已经在友盟注册了应用,获得了Appkey,可以继续使用之前获得Appkey。
· 如果你尚未在友盟注册账号,需要先注册,注册之后登录你的账号,点击添加新应用
,完成新应用填写之后,将进入应用管理页面。在该页面就能得到Appkey
。
· 在代码中设置你的友盟Appkey,在 AppDelegate
文件内设置你的AppKey:
- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
//设置友盟的APPKey
[UMSocialDatasetAppKey:@"5770f246e0f55a863a000xxx"];
returnYES;
}
1.4 配置第三方平台APPID及scheme
1.4.1 配置第三方APPID
这里只列出最常用的微信、QQ及新浪微博的配置方法,其他平台如Facebook等请参考对应文档配置,申请平台APPID请直接参考文档申请第三方账号
在APPdelegate.m文件中增加对应下面的配置
- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions {
// //设置友盟的APPKey
// [UMSocialData setAppKey:@"5770f246e0f55a863a000976"];
//设置微信的AppId,Appkey,和分享URL,需要#import"UMSocialQQHandler.h"
[UMSocialWechatHandlersetWXAppId:@"wx6f2c2f302768cfxx"appSecret:@"309d97f1e1da94fdb3427fad32fc2bxx"url:@"http://www.umeng.com/social"];
//设置手机QQ 的AppId,Appkey,和分享URL,需要#import"UMSocialQQHandler.h"
[UMSocialQQHandler setQQWithAppId:@"11055100xx"appKey:@"Y7ySWBJQU4CnKOxx"url:@"http://www.umeng.com/social"];
//打开新浪微博的SSO开关,设置新浪微博回调地址,这里必须要和你在新浪微博后台设置的回调地址一致。需要#import"UMSocialSinaSSOHandler.h"
[UMSocialSinaSSOHandleropenNewSinaSSOWithAppKey:@"29067283xx" secret:@"340c14750dbe80ff125acecf953309xx" RedirectURL:@"http://sns.whalecloud.com/sina2/callback"];
return YES;
}
1.4.2 配置系统回调
在APPdelegate.m中增加下面的系统回调配置,注意如果同时使用微信支付、支付宝等其他需要改写回调代理的SDK,请在if分支下做区分,否则会影响分享、登录的回调。
//在APPdelegate.m中增加下面的系统回调配置,注意如果同时使用微信支付、支付宝等其他需要改写回调代理的SDK,请在if分支下做区分,否则会影响分享、登录的回调
-(BOOL)application:(UIApplication*)app openURL:(NSURL*)url options:(NSDictionary *)options
{
BOOL rst=[UMSocialSnsServicehandleOpenURL:url];
if (rst==false)
{
}
return rst;
}
//添加系统回调 点击返回才不会崩
- (BOOL)application:(UIApplication*)applicationopenURL:(NSURL *)url sourceApplication:(NSString *)sourceApplicationannotation:(id)annotation
{
BOOL result = [UMSocialSnsServicehandleOpenURL:url];
if (result == FALSE) {
//调用其他SDK,例如支付宝SDK等
}
returnresult;
}
-(void)didFinishGetUMSocialDataInViewController:(UMSocialResponseEntity*)response
{
//根据`responseCode`得到发送结果,如果分享成功
if(response.responseCode== UMSResponseCodeSuccess)
{
//得到分享到的微博平台名
NSLog(@"share to snsname is %@",[[response.data allKeys] objectAtIndex:0]);
}
}
1.4.3 配置URL scheme
1.5 设置分享文本、图片
1.5.1 使用默认UI风格
适用人群:希望10分钟集成从无到有实现分享的开发者
打开需要集成分享功能的视图源码UIViewController.m
,把如下代码复制并粘贴到你将弹出一个分享列表的位置,例如到响应分享按钮的方法中。并且修改下面的友盟appkey,你要分享的文字、图片,你要分享到的微博平台,例如下面写的是新浪微博、QQ、微信。
如在分享按钮点击方法里面写:
首先需要 #import "UMSocial.h" 签协议
-(void)shareAction:(UIButton*)sender
{
//微信、微信朋友圈
[UMSocialData defaultData].extConfig.wechatTimelineData.title= 要分享的标题;
[UMSocialData defaultData].extConfig.wechatSessionData.url= 要分享的url;
//QQ、QQ空间
[UMSocialData defaultData].extConfig.qqData.url=要分享的url;
[UMSocialData defaultData].extConfig.qzoneData.url=要分享的url;
[UMSocialSnsService presentSnsIconSheetView:self
appKey:@"友盟上申请的appkey"
shareText:要分享的url
shareImage:[UIImageimageNamed:要分享的图片]
shareToSnsNames:@[UMShareToWechatSession,UMShareToWechatTimeline,UMShareToSina,UMShareToQQ,UMShareToQzone,UMShareToTencent,UMShareToRenren,UMShareToDouban,UMShareToEmail,UMShareToSms]
delegate:self];
}
这时候点击分享按钮就会出现以下界面:
iOS9.0之后在跳转应用进行授权时,如果没有增加可跳转的白名单,就会提示“您的设备没有安装XXX”,进而只进行webview授权或授权/分享失败,那么如何增加可跳转表名单?
在info.plist中加入可跳转白名单
**1****、****
**
右键info.plist用source code打开:
2、
增加以下内容:插入到原本内容的这里
这时候用 Propert list 方式打开info.plist,即可看到如下如新增的内容