码迷,mamicode.com
首页 > 移动开发 > 详细

iOS 友盟分享

时间:2017-06-24 19:43:36      阅读:351      评论:0      收藏:0      [点我收藏+]

标签:tracking   空间   link   launch   overflow   自己   view   hid   开放平台   

iOS 友盟分享

这个主要是提到怎样通过友盟去自己定义分享的步骤:

一、肯定要去友盟官网下载最新的SDK包,然后将SDK导入到你的project目录里面去。

二、注冊友盟账号。将你的APP加入到你的账号里面然后获取到一个Key;

三、  在AppDelegate内设置友盟AppKey

-(BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

{

[UMSocialData setAppKey:@"***这个是你注冊后的APP的Key****"];

}

四、然后在你要显示分享界面的控制器设置友盟自带的分享。比如 :点击一个分享button在分享button里面加入

[UMSocialSnsService presentSnsIconSheetView:self

appKey:@"你APPKey"

shareText:@“你要分享的文字”

shareImage:[UIImage imageNamed:@"icon"]

shareToSnsNames:[NSArray arrayWithObjects:UMShareToSina,UMShareToTencent,UMShareToRenren,UMShareToEmail,UMShareToSms,nil]

delegate:nil];

这个是使用友盟原生的分享,以下给大家介绍一下自己定义的

前三步还是以上三步。

四、首先你得搭建好你想要显示什么要UI效果。比方你用UIScrollView或者 UICollectionView 或者你直接是往View里面加入Buttonbutton;

我介绍下我使用UICollectionView做的自己定义:

1、首先实现UICollectionView最主要的协议和代理方法。

2、在UICollectionView的点击事件的方法里去依据你要加入多少个分享平台去设置;

五、首先以分享新浪,腾讯微博。人人网,豆瓣网。QQ空间,邮箱。短信为例:1.在UICollectionView

- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath{

NSMutableArray * shareArray =[NSMutableArray arrayWithObjects:UMShareToSina,UMShareToTencent,UMShareToRenren,UMShareToDouban,UMShareToQzone,UMShareToEmail,UMShareToSms,nil];

for (int i = 0; i< shareArray.count; i++) {

if ( indexPath.row == i )

{//新浪,腾讯微博。人人网,豆瓣网,QQ空间,邮箱。短信

[UMSocialAccountManager               isOauthAndTokenNotExpired:shareArray[i]];

//进入授权页面

[UMSocialSnsPlatformManager getSocialPlatformWithName:shareArray[i]].loginClickHandler(self,[UMSocialControllerService defaultControllerService],YES,^(UMSocialResponseEntity *response){

if (response.responseCode == UMSResponseCodeSuccess) {

//获取微博username、uid、token等

UMSocialAccountEntity *snsAccount = [[UMSocialAccountManager socialAccountDictionary] valueForKey:shareArray[i]];

NSLog(@"username is %@, uid is %@, token is %@",snsAccount.userName,snsAccount.usid,snsAccount.accessToken);

//进入你的分享内容编辑页面

}

});

}}

}

这样这几个分享的功能就实现了

假设还想注冊微信/手机QQ/Facebook等等

那就要看接下来的几个步骤了

1、微信你要把你所下载的SDK中Wechat文件放在project中;

2、进入微信开放平台注冊申请得到一个WXAppId;

3、在你的程序APPdelegate入口方法加入以下的代码

#import "UMSocialWechatHandler.h"

// 设置微信 AppId 、 appSecret ,分享 url

[UMSocialWechatHandler setWXAppId:@“你的微信AppId" appSecret:@"db426a9829e4b49a0dcac7b4162da6b6" url:@“要分享的URL”];

4、在你的project设置项,targets 一栏下,选中自己的 target,在 Info->URL Types 中加入 URL Schemes,加入xcode的url scheme为微信应用appId,比如“wxd9a39c7122aa6516”;

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url

{

return[UMSocialSnsService handleOpenURL:url];   

}

- (BOOL)application:(UIApplication *)application

openURL:(NSURL *)url

sourceApplication:(NSString *)sourceApplication

annotation:( id )annotation

{

return[UMSocialSnsService handleOpenURL:url];

}

5、在你的点击方法中依据indexPath.row进行推断点击的第几个button中加入

[[UMSocialDataService defaultDataService]  postSNSWithTypes:@[UMShareToWechatSession] content:@"分享内嵌文字" image:nil location:nil urlResource:nil presentedController: self completion:^(UMSocialResponseEntity *response){

if(response.responseCode == UMSResponseCodeSuccess) {

NSLog(@"分享成功!");

}

}];

到这儿微信的自己定义加入就结束了;

以下就介绍下加入手机QQ的。

首先你须要到腾讯开放平台注冊获取Key,然后在UMSocial_Sdk_Extra_Frameworks文件夹下的。加入TencentOpenAPI文件夹到project 加入以下几个系统framework

1、在Xcode中打开project配置文件。选择“summary”一栏。在“summary”中选择“Linked Frameworks and Libraries”一栏。点击“+”图标加入以下八个库文件,各自是

?     Security.framework

?     libiconv.dylib

?     SystemConfiguration.framework

?     CoreGraphics.Framework

?     libsqlite3.dylib

?     CoreTelephony.framework

?     libstdc++.dylib

?     libz.dylib

2、在AppDelegate中

import "UMSocialQQHandler.h"

[UMSocialQQHandler setQQWithAppId:@"100424468" appKey:@"c7394704798a158208a74ab60104f0ba" url:@“http://www.umeng.com/social"];

这里注意了:在你的project设置项,targets 一栏下,选中自己的 target,在 Info->URL Types 中加入 URL Schemes,设置Xcode的url scheme格式为“QQ”+腾讯QQ互联应用appId转换成十六进制(不足8位前面补0),比如“QQ05FC5B14”。并在QQ互联后台的URL schema中填入此字符串保持一致。 额外设置 url schemes 的格式为"tencent"+腾讯QQ互联应用appId,比如“tencent100424468”

假设 URL schemes 配置错误,则分享完毕后无法返回应用

在Xcode 6.0创建project时,默认可能没有单独设置Bundle display name属性值。可是由于SDK须要用到Bundle display name的值,所以务必请检查确保这个属性存在,假设没有请加入上。

技术分享

3.在APPdelegate里面实现

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url

{

return[UMSocialSnsService handleOpenURL:url];   

}

- (BOOL)application:(UIApplication *)application

openURL:(NSURL *)url

sourceApplication:(NSString *)sourceApplication

annotation:( id )annotation

{

return[UMSocialSnsService handleOpenURL:url];

}

4、然后再在点击事件里加入

[[UMSocialDataService defaultDataService]  postSNSWithTypes:@[UMShareToQQ(这里假设要分享到QQ空间仅仅要把UMShareToQQ换成UMShareToQzone的就能够了)] content:@"分享文字" image:nil location:nil urlResource:nil presentedController: selfcompletion:^(UMSocialResponseEntity *response){

if(response.responseCode == UMSResponseCodeSuccess) {

NSLog(@"分享成功!

");

}

}];

到这儿QQ的加入已经完毕了

以下给大家介绍一个Facebook的加入

1.在Facebook开放平台( 点击链接 ) 注冊你的facebook应用,注意在你的应用Native iOS App填写Bundle ID

2.把你的SDK中在UMSocial_Sdk_Extra_Frameworks文件夹下,把Facebook文件夹加入到project;

3.在你的project设置项,targets 一栏下,选中自己的 target,在 Info->URL Types 中加入 URL Schemes,设置Xcode的url scheme格式为“fb”+facebook AppID。比如“fb1440390216179601”

4.在APPdelegate里实现

[UMSocialFacebookHandler setFacebookAppID:@"1440390216179601" shareFacebookWithURL:@"http://www.umeng.com/social"];

- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url

{

return[UMSocialSnsService handleOpenURL:url]; 

}

- (BOOL)application:(UIApplication *)application

openURL:(NSURL *)url

sourceApplication:(NSString *)sourceApplication

annotation:( id )annotation

{

return[UMSocialSnsService handleOpenURL:url];

}

/**假设上面的几个分享已经加入这个那就不须要再次加入了*/

介绍就到这里了,至于其它的一些分享大家能够好好看看友盟的官方文档非常具体的介绍了怎样使用自己定义的

这个是链接: http://dev.umeng.com/social/ios/detail-share

当然了国内除了友盟之外另一个shareSDK。仅仅只是个人感觉友盟的更简洁更方便一些;

iOS 友盟分享

标签:tracking   空间   link   launch   overflow   自己   view   hid   开放平台   

原文地址:http://www.cnblogs.com/liguangsunls/p/7074147.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!