之前完成了 AppDelegate减负之常用三方封装 - 友盟推送篇:

http://www.cnblogs.com/zhouxihi/p/7113511.html

今天接着来完成 - 友盟分享和三方登录篇

首先去友盟上面下载SDK, 一般就新浪/微信/QQ  我们都选择精简版

把下载好的SDK添加到项目,

按照开发文档添加libsqlite3.0.tbd到Linked Frameworks,

在Build Settings -> Linking -> Other Linker Flags 添加-ObjC

然后我们就可以开始了

首先跟之前友盟推送部分一样, 创建一个AppDelegate+UMSocial.h类别

在头文件中导入:

#import <UMSocialCore/UMSocialCore.h>
#import <UShareUI/UShareUI.h>

接下来我们先在头文件中写初始化方法

通用初始化方法:

/**
初始化友盟分享 (推荐方法, 在AppKey.h中配置各项秘钥)
*/
- (void)zx_configureUMSocialSDK;

单一只初始化友盟SDK

/**
单一只初始化友盟分享, 此方法不会去配置微信/QQ/新浪等分享组件 @param appKey 秘钥
*/
- (void)zx_configuerUMSocialSDKWithAppKey:(NSString *)appKey;

下面先写分享部分的方法

配置微信分享的方法

/**
单一只配置微信分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Wechat appKey
@param appSecret Wechat appSecret
@param redirectURL Wechat redirect URL
*/
- (void)zx_configureWechatShareWithAppKey:(NSString *)appKey
appSecret:(NSString *)appSecret
redirectURL:(NSString *)redirectURL;

配置QQ分享的方法

/**
单一只配置QQ分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey QQ appKey
@param appSecret QQ appSecrect (一般传nil)
@param redirectURL QQ redirect URL
*/
- (void)zx_configureQQShareWithAppKey:(NSString *)appKey
appSecret:(NSString *)appSecret
redirectURL:(NSString *)redirectURL;

配置新浪分享的方法

/**
单一只配置新浪分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Sina appKey
@param appSecrect Sina app
@param redirectURL Sina redirect URL
*/
- (void)zx_configureSinaShareWithAppKey:(NSString *)appKey
appSecrect:(NSString *)appSecrect
redirectURL:(NSString *)redirectURL;

下面是实际的分享方法

先定义一个回调方法

typedef void(^UMSocialCallBack)(BOOL success, id responseObject, NSError *error);

分享文本

/**
分享文本 @param text 要分享的文本
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareTextWithString:(NSString *)text
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

分享图片

/**
分享图片 @param image 要分享的图片
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareImageWithImage:(UIImage *)image
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

分享图文

/**
分享图文 @param text 要分享的文字
@param image 要分享的图片
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareTextWithString:(NSString *)text
andImage:(UIImage *)image
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

分享网页

/**
分享网页 @param url 要分享的网页地址
@param title 标题
@param description 描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareWebPageWithURLStr:(NSString *)url
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

分享音乐

/**
分享音乐 @param musicURL 音乐的url
@param title 标题
@param description 描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareMusicWithURLStr:(NSString *)musicURL
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

分享视频

/**
分享视频 @param videoURL 视频的url
@param title 标题
@param description 描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareVideoWithURLStr:(NSString *)videoURL
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

分享微信小程序

/**
分享微信小程序 @param programPath 小程序页面路径
@param webPageURL 兼容网页地址
@param userName 用户名
@param title 小程序标题
@param description 小程序内容描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_WeichatMiniProgramWithPath:(NSString *)programPath
webPageURL:(NSString *)webPageURL
userName:(NSString *)userName
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback;

接下来我们写拉取三方登录授权的方法

拉取新浪登录授权

/**
拉取新浪登录授权信息 @param currentViewController 调用登录的当前控制面板
@param callback 回调方法 */
- (void)zx_getAuthInfoFromSinaWithCurrentViewController:(UIViewController *)currentViewController
CallBack:(UMSocialCallBack)callback;

拉取微信登录授权

/**
拉取微信登录授权信息 @param currentViewController 调用登录的当前控制面板
@param callback 回调方法
*/
- (void)zx_getAuthInfoFromWechatWithCurrentViewController:(UIViewController *)currentViewController
CallBack:(UMSocialCallBack)callback;

拉取QQ登录授权

/**
拉取QQ登录授权信息
@param currentViewController 调用登录的当前控制面板
@param callback 回调方法
*/
- (void)zx_getAuthInfoFromQQWithCurrentViewController:(UIViewController *)currentViewController
CallBack:(UMSocialCallBack)callback;

下面是实现方法:

//
// AppDelegate+UMSocial.m
// ThirdPartDemo
//
// Created by Jackey on 2017/7/4.
// Copyright © 2017年 com.zhouxi. All rights reserved.
// #import "AppDelegate+UMSocial.h"
#import "AppKey.h" @implementation AppDelegate (UMSocial) #pragma mark - 配置UMSocial SDK /**
初始化友盟分享 (推荐方法, 在AppKey.h中配置各项秘钥)
*/
- (void)zx_configureUMSocialSDK { // 配置友盟秘钥
[self zx_configuerUMSocialSDKWithAppKey:UMSocialAppKey]; // 配置Wechat
if ([WechatAppKey length] > ) { NSLog(@"配置微信");
[self zx_configureWechatShareWithAppKey:WechatAppKey
appSecret:WechatAppSecret
redirectURL:WeChatRedirectURL];
} // 配置QQ
if ([QQAppKey length] > ) { NSLog(@"配置QQ");
[self zx_configureQQShareWithAppKey:QQAppKey
appSecret:QQAppSecrect
redirectURL:QQRedirectURL];
} // 配置Sina
if ([SinaAppKey length] > ) { NSLog(@"配置新浪");
[self zx_configureSinaShareWithAppKey:SinaAppKey
appSecrect:SinaAppSecrect
redirectURL:SinaRedirectURL];
}
} /**
单一只初始化友盟分享, 此方法不会去配置微信/QQ/新浪等分享组件 @param appKey 秘钥
*/
- (void)zx_configuerUMSocialSDKWithAppKey:(NSString *)appKey { // 打开调试日志
[[UMSocialManager defaultManager] openLog:YES]; // 设置友盟appKey
[[UMSocialManager defaultManager] setUmSocialAppkey:UMSocialAppKey];
} /**
单一只配置微信分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Wechat appKey
@param appSecret Wechat appSecret
@param redirectURL Wechat redirect URL
*/
- (void)zx_configureWechatShareWithAppKey:(NSString *)appKey
appSecret:(NSString *)appSecret
redirectURL:(NSString *)redirectURL { [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_WechatSession
appKey:appKey
appSecret:appSecret
redirectURL:redirectURL];
} /**
单一只配置QQ分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey QQ appKey
@param appSecret QQ appSecrect (一般传nil)
@param redirectURL QQ redirect URL
*/
- (void)zx_configureQQShareWithAppKey:(NSString *)appKey
appSecret:(NSString *)appSecret
redirectURL:(NSString *)redirectURL { [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_QQ
appKey:appKey
appSecret:appSecret
redirectURL:redirectURL];
} /**
单一只配置Sina分享 (推荐使用- (void)zx_configureUMSocialSDK;方法统一配置) @param appKey Sina appKey
@param appSecrect Sina app
@param redirectURL Sina redirect URL
*/
- (void)zx_configureSinaShareWithAppKey:(NSString *)appKey
appSecrect:(NSString *)appSecrect
redirectURL:(NSString *)redirectURL { [[UMSocialManager defaultManager] setPlaform:UMSocialPlatformType_Sina
appKey:appKey
appSecret:appSecrect
redirectURL:redirectURL];
} #pragma mark - 配置系统回调 - (BOOL)application:(UIApplication *)application
openURL:(nonnull NSURL *)url
sourceApplication:(nullable NSString *)sourceApplication
annotation:(nonnull id)annotation { BOOL result = [[UMSocialManager defaultManager] handleOpenURL:url sourceApplication:sourceApplication annotation:annotation]; if (!result) { // 其他如支付等SDK的回调
// 如果有多个回调需求处理的话, 应该再创建一个分类别统一实现回调
}
return result;
} #pragma mark - 友盟分享方法 /**
分享文本 @param text 要分享的文本
@param callback 回调方法
*/
- (void)zx_shareTextWithString:(NSString *)text
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 设置文本
messageObject.text = text; // 调用友盟分享面板
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { // 调用分享接口
[[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} /**
分享图片 @param image 要分享的图片
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareImageWithImage:(UIImage *)image
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建图片内容对象
UMShareImageObject *shareObject = [[UMShareImageObject alloc] init]; // 如果有缩略图, 则设置缩略图
if (thumImage) { shareObject.thumbImage = thumImage;
} // 设置分享的图片
if (image) { [shareObject setShareImage:image];
} // 分享消息对象设置分享内容对象
messageObject.shareObject = shareObject; // 调用友盟分享面板
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} /**
分享图文 @param text 要分享的文字
@param image 要分享的图片
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareTextWithString:(NSString *)text
andImage:(UIImage *)image
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 设置文本
messageObject.text = text; // 创建图片内容对象
UMShareImageObject *shareObject = [[UMShareImageObject alloc] init]; // 如果有缩略图, 则设置缩略图
if (thumImage) { shareObject.thumbImage = thumImage;
} // 设置分享的图片
if (image) { [shareObject setShareImage:image];
} // 分享消息对象设置分享内容对象
messageObject.shareObject = shareObject; // 调用分享接口
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} /**
分享网页 @param url 要分享的网页地址
@param title 标题
@param description 描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareWebPageWithURLStr:(NSString *)url
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建网页内容对象
UMShareWebpageObject *shareObject = [UMShareWebpageObject shareObjectWithTitle:title
descr:description
thumImage:thumImage]; // 设置网页地址
shareObject.webpageUrl = url; // 分享消息对象设置分享内容对象
messageObject.shareObject = shareObject; // 调用分享接口
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} /**
分享音乐 @param musicURL 音乐的url
@param title 标题
@param description 描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareMusicWithURLStr:(NSString *)musicURL
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建音乐内容对象
UMShareMusicObject *shareObject = [UMShareMusicObject shareObjectWithTitle:title
descr:description
thumImage:thumImage]; // 设置音乐网页播放地址
shareObject.musicUrl = musicURL; // 分享消息对象设置分享内容对象
messageObject.shareObject = shareObject; // 调用分享接口
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} /**
分享视频 @param videoURL 视频的url
@param title 标题
@param description 描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
- (void)zx_shareVideoWithURLStr:(NSString *)videoURL
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建视频内容对象
UMShareVideoObject *shareObject = [UMShareVideoObject shareObjectWithTitle:title
descr:description
thumImage:thumImage]; // 设置视频网页播放地址
shareObject.videoUrl = videoURL; // 分享消息对象设置分享内容对象
messageObject.shareObject = shareObject; // 调用分享接口
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} /**
分享微信小程序 @param programPath 小程序页面路径
@param webPageURL 兼容网页地址
@param userName 用户名
@param title 小程序标题
@param description 小程序内容描述
@param thumImage 缩略图
@param currentVC 调用分享方法的控制面板
@param callback 回调方法
*/
-(void)zx_WeichatMiniProgramWithPath:(NSString *)programPath
webPageURL:(NSString *)webPageURL
userName:(NSString *)userName
title:(NSString *)title
description:(NSString *)description
thumImage:(UIImage *)thumImage
currentViewController:(UIViewController *)currentVC
callback:(UMSocialCallBack)callback { // 创建分享消息对象
UMSocialMessageObject *messageObject = [UMSocialMessageObject messageObject]; // 创建小程序消息对象
UMShareMiniProgramObject *shareObject = \
[UMShareMiniProgramObject shareObjectWithTitle:title
descr:description
thumImage:thumImage]; shareObject.webpageUrl = webPageURL;
shareObject.userName = userName;
shareObject.path = programPath; // 分享消息对象设置分享内容对象
messageObject.shareObject = shareObject; // 调用分享接口
[UMSocialUIManager showShareMenuViewInWindowWithPlatformSelectionBlock:^(UMSocialPlatformType platformType, NSDictionary *userInfo) { [[UMSocialManager defaultManager] shareToPlatform:platformType
messageObject:messageObject
currentViewController:currentVC
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
}];
} #pragma mark - 友盟登录方法 /**
拉取新浪登录授权信息 @param currentViewController 调用登录的当前控制面板
@param callback 回调方法 */
- (void)zx_getAuthInfoFromSinaWithCurrentViewController:(UIViewController *)currentViewController
CallBack:(UMSocialCallBack)callback { [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_Sina
currentViewController:currentViewController
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
} /**
拉取微信登录授权信息 @param currentViewController 调用登录的当前控制面板
@param callback 回调方法
*/
- (void)zx_getAuthInfoFromWechatWithCurrentViewController:(UIViewController *)currentViewController
CallBack:(UMSocialCallBack)callback { [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_WechatSession
currentViewController:currentViewController
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
} /**
拉取QQ登录授权信息
@param currentViewController 调用登录的当前控制面板
@param callback 回调方法
*/
- (void)zx_getAuthInfoFromQQWithCurrentViewController:(UIViewController *)currentViewController
CallBack:(UMSocialCallBack)callback { [[UMSocialManager defaultManager] getUserInfoWithPlatform:UMSocialPlatformType_QQ
currentViewController:currentViewController
completion:^(id result, NSError *error) { if (error) { if (callback) callback(FALSE, result, error);
} else { if (callback) callback(TRUE, result, error);
}
}];
} @end

对应的Appkey放在AppKey.h中

//
// AppKey.h
// ThirdPartDemo
//
// Created by Jackey on 2017/7/5.
// Copyright © 2017年 com.zhouxi. All rights reserved.
// #ifndef AppKey_h
#define AppKey_h /*
Notice:
以下定义内容, 请不要删除以免编译报错
如果不需要集成某一个SDK, 可以将对应的appKey内容清空, 只保留@"" */ // 友盟推送
#define UMessageAppKey @"57d6583a67e58e3d75001f15" // 友盟分享
#define UMSocialAppKey @"57d6583a67e58e3d75001f15"
#define WechatAppKey @"wx406b36767a2d7615"
#define WechatAppSecret @"4402d0be403a89f7c0527764371bf46a"
#define WeChatRedirectURL @"http://mobile.umeng.com/social"
#define QQAppKey @"101390775"
#define QQAppSecrect @"09193c1b916f14e07e888c84f16fa797"
#define QQRedirectURL @"http://mobile.umeng.com/social"
#define SinaAppKey @"3628080196"
#define SinaAppSecrect @"584f67d21fca39ad0af7df3706166db1"
#define SinaRedirectURL @"https://sns.whalecloud.com/sina2/callback" #endif /* AppKey_h */

使用的时候在AppDelegate.m中中导入

#import "AppDelegate+UMengPush.h"
#import "AppDelegate+UMSocial.h"

一行代码配置

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// Override point for customization after application launch.
// 配置UMSocial
[self zx_configureUMSocialSDK]; return YES;
}

在要使用分享的控制器中导入:

#import "AppDelegate.h"
#import "AppDelegate+UMengPush.h"
#import "AppDelegate+UMSocial.h"

最好把这三个加到pch中

分享部分我们简单以分享文本做个示例

 NSLog(@"分享文字");

    AppDelegate *app = (AppDelegate *)[[UIApplication sharedApplication] delegate];

    [app zx_shareTextWithString:@"分享" currentViewController:self callback:^(BOOL success, id responseObject, NSError *error) {

        if (success) {

            NSLog(@"分享成功");
} else { NSLog(@"分享失败");
}
}];

三方登录部分我用新浪做个示例

NSLog(@"新浪登录");

    AppDelegate *app = (AppDelegate *)[[UIApplication sharedApplication] delegate];

    [app zx_getAuthInfoFromSinaWithCurrentViewController:self CallBack:^(BOOL success, id responseObject, NSError *error) {

        if (success) {

            UMSocialUserInfoResponse *resp = responseObject;

            // 授权信息
NSLog(@"Wechat uid: %@", resp.uid);
NSLog(@"Wechat openid: %@", resp.openid);
NSLog(@"Wechat accessToken: %@", resp.accessToken);
NSLog(@"Wechat refreshToken: %@", resp.refreshToken);
NSLog(@"Wechat expiration: %@", resp.expiration); // 用户信息
NSLog(@"Wechat name: %@", resp.name);
NSLog(@"Wechat iconurl: %@", resp.iconurl);
NSLog(@"Wechat gender: %@", resp.unionGender); // 第三方平台SDK源数据
NSLog(@"Wechat originalResponse: %@", resp.originalResponse); } else { NSLog(@"登录失败: %@", error);
}
}];

最后提供Demo地址给大家:

https://github.com/zhouxihi/ThirdPartDemo

欢迎大家提供建议, 如果好用也希望大家帮忙star

谢谢

后面会再做支付部分

AppDelegate减负之常用三方封装 - 友盟分享 / 三方登录篇的更多相关文章

  1. AppDelegate减负之常用三方封装 - 友盟推送篇

    之前分享过集成友盟推送的方法, 需要的朋友可以查看一下链接: http://www.cnblogs.com/zhouxihi/p/6533058.html 一般开发中我们比较多使用的三方有友盟推送, ...

  2. iOS友盟分享的使用总结

    现在几乎所有的APP都会集成分享,为了可以更好的推广自己的APP. 目前市面上常用的分享无非就三个: 1.友盟分享; 2.shareSDK(mob); 3.苹果原生. 由于苹果原生的分享使用起来不方便 ...

  3. iOS开发-友盟分享(3)

    iOS 友盟分享 这个主要是提到如何通过友盟去自定义分享的步骤: 一.肯定要去友盟官网下载最新的SDK包,然后将SDK导入到你的工程文件夹里面去: 二.注册友盟账号,将你的APP添加到你的账号里面然后 ...

  4. iOS开发-友盟分享使用(2)

    1.友盟SDK提供功能:分享喜欢的东西到新浪微博.qq空间.为微信朋友圈等等等等社交圈. 2.友盟分享前期准备 (1)注册账号 去官网 (2)创建应用获取appkey 类似5556a53667e*** ...

  5. 友盟分享--集成QQ和微信

    随着社交工具的应用范围越来越广,分享一些内容的功能也开始要求实现了. 用得比较多的第三方,比如说友盟,比如说Share等等... 前几天刚用友盟写了集成QQ和微信客户端的功能,觉得有必要分享一下. 在 ...

  6. iOS开发——友盟分享

    ==========2016-01-29 更新=====刘成利 email:liu_cheng_li@qq.com========== 自己成功集成到公司的项目前,也已做了测试好的友盟分享demo 目 ...

  7. iOS关于友盟分享弹不出面板问题

    在程序代理类中声明 [NSThread sleepForTimeInterval:10];//设置启动页面时间 [self.window makeKeyAndVisible]; [[UMSocialM ...

  8. IOS 集成友盟分享

    #import <Foundation/Foundation.h> @interface UMSocialSinaHandler : NSObject +(void)openSSOWith ...

  9. 友盟分享小结 - iOS

    因之前都写在了 AppDelegate 类中,看起来过于臃肿,此次基于友盟分享重新进行了一次优化,此次分享内容基于已经成功集成 SDK 后 code 层级部分.注:此次分享基于 SDK 6.9.3,若 ...

随机推荐

  1. Lua 设置table为只读属性

    项目中部分只读表易被人误改写,故决定在非线上环境里对这些表附加只读属性,方便在出现误改写的时候抛出lua错误,最终版代码如下: --[[-------------------------------- ...

  2. Microsoft Azure IoTHub Serials 1 - 使用Android设备与Azure IoTHub进行交互

    Azure IoTHub的目标是为物联网的应用场景提供方便的设备接入,完成消息的发送和接收(C2D和D2C).经过持续不断的努力,目前Azure IoTHub已经支持多种操作系统设备的接入,包括And ...

  3. R TUTORIAL: VISUALIZING MULTIVARIATE RELATIONSHIPS IN LARGE DATASETS

    In two previous blog posts I discussed some techniques for visualizing relationships involving two o ...

  4. 【2017-06-05】Jquery.ajax

    AJAX  是一种网页数据异步加载技术 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. 一.Json     ...

  5. java中的流程控制语句总结

    程序的结构分类: 顺序结构:按照写代码的顺序 一次执行 选择结构:根据条件的不同有选择的执行不同的代码 循环结构:在一定条件下 反复执行某一片代码 选择结构: 也叫分支结构 根据条件的不同,有选择的执 ...

  6. Html5模拟通讯录人员排序(sen.js)

    // JavaScript Document var PY_Json_Str = ""; var PY_Str_1 = ""; var PY_Str_2 = & ...

  7. 关于JS跨域问题的解决

    这里不提供什么高深的代码了,只说明一个解决跨域问题的方法,个人觉得这个方法是最方便也是最有效的. 那就是一用不同源的JS,虽然JS不允许不同源的访问,但是可以引用不同源的JS,用这样的方法我们可以引用 ...

  8. php 多条件查询

    1.效果图如下: 点击提交后,把符合条件的筛选出来 2.代码: 逻辑:选中数据----以数组方式提交---拼接sql语句 难点: (1)从数据库里读取的数据要去重 (2)读取的数据是数组,要拼接 (3 ...

  9. Java NIO学习笔记七 Non-blocking Server

    Java NIO:Non-blocking Server 即使你了解了Java NIO非阻塞功能的工作(怎么样Selector,Channel, Buffer等等),设计一个无阻塞服务器仍然很难.非阻 ...

  10. JS监听div的resize事件

    原文地址:http://zhangyiheng.com/blog/articles/div_resize.html 需求 开发过程中经常遇到的一个问题就是如何监听一个div的size变化. 比如我用c ...