客户端 iOS 集成流程
手动导入
启动Xcode,把 iOS 包中的压缩文件中以下文件拷贝到项目文件夹下,并导入到项目工程中。
通过 CocoaPods 导入相关的依赖库
通过 CocoaPods 导入以下依赖库,如果项目中已经添加可以不添加,也可以手动导入依赖库
pod 'AMap3DMap'
pod 'AMapSearch'
pod 'AMapLocation'
pod 'AFNetworking'
pod 'YTKNetwork'
pod 'YYKit'
pod 'SDWebImage'
pod 'SocketRocket'
pod 'IQKeyboardManager'
pod 'AXRatingView'
pod 'Masonry'
pod 'FMDB'
pod 'SVProgressHUD'
# 颜色
pod 'ChameleonFramework'
pod 'MJRefresh'
#切图
pod 'RSKImageCropper'
#cell高度自适应
pod 'UITableView+FDTemplateLayoutCell'
# 操作钥匙串保存设备唯一识别码
pod 'SAMKeychain'
pod 'RealReachability'
pod 'ReactiveObjC'
#网页交互
pod 'WebViewJavascriptBridge'
主功能配置
SDK用到了地图定位功能,需要在info.plist文件中添加定位授权, 打开Info.plist,添加一个键值对
Privacy - Location When In Use Usage Description,
Privacy - Location When In Use Usage Description
SDK依赖于微信支付与支付宝支付,需要项目集成微信支付和支付宝支付,主工程中的plist中需要添加支付宝和微信的 scheme 。identifier分别设为alipay和weixin
工程Build Settings里Other Linker Flags需要添加”ObjC”项,以确保.framework里的类别能加载上:
增加头文件引用
在需要调用 XTRideSDK的文件中,增加头文件引用。
import < XTRideSDK / XTRideSDK.h>
token申请
针对有意向接入新电出行的所有应用开发者,请先联系商务,确认合作意向及具体需求,商务人员会为您安排及解答接入前的所有问题。与技术人员沟通了解获取token的方式和规则。
SDK方法
SDK提供的方法列表如下,具体使用方法可以参见对应编号的详细介绍。
shareInstance创建单例
XTRideSDK *rideSDK = [XTRideSDK shareInstance];
configMapAppKey配置高德地图AppKey
SDK使用用高德地图,需要到高德地图申请一个APPkey,并通过该方法对其进行配置后方可调起首页地图功能
[rideSDK configMapAppKey:@" 高德地图AppKey"];
通过token注册SDK
与出行平台账号关联成功后生成的token, 通过token注册SDK
[[XTRideSDK shareInstance]registerWithAppId:@" AppId" appSecret:@" appSecret " delegate:self];
注册结果
在回调函数中,获取注册结果,进行后续业务处理。
//失败的回调
- (void)rideRegisterFailure:(NSDictionary *)message{
NSLog(@"注册失败:%@",message[@"message"]);
}
//成功的回调
- (void)rideRegisterSuccesse:(NSDictionary *)message{
NSLog(@"注册成功");
[[XTRideSDK shareInstance]loginWithMobile:@"14000000072"];
}
登录出行平台
注册成功后可进行登录
[self loginWithMobile:@"14000000000" callback:^(NSDictionary *resultDic) {
}];
在登录回调函数中,获取登录结果,判断登录是否成功,并进行相应的操作。
//登录失败的回调
- (void)rideLoginFailure:(NSDictionary *)message{
NSLog(@"登录失败:%@",message[@"message"]);
}
//登录成功的回调
- (void)rideLoginSuccesse:(UserPassengerModel *)passenger{
NSLog(@"登录成功");
}
homeViewController 获取出行首页控制器
UIViewController *vc = [[XTRideSDK shareInstance] homeViewController];
isLogin 判断当前用户是否登录
返回信息true / false 分别对应是否为登录状态。 对于非登录状态可以通过loginWithMobile:方法进行用户登录。如果token失效isToken也会返回false,所以在拉起页面判断是否已经登录成功,可以在rideLoginSuccesse回调方法中进行拉起页面
行程列表页面
[[XTRideSDK shareInstance] showTripListViewFromPage:**self**.window.rootViewController animated:**YES** delegate:**self**];
发票开具页面
[[XTRideSDK shareInstance] showInvoiceViewFromPage:**self**.window.rootViewController animated:**YES** delegate:**self**];
显示我的钱包页面
[[XTRideSDK shareInstance] showWalletViewFromPage:**self**.window.rootViewController animated:**YES** delegate:**self**];
支付
目前SDK支持支付宝和微信支付,所以需要开发者在使用SDK时集成支付宝和微信支付。
微信支付时还需要提供微信支付的Appid和AppSecret(用于商户关联)
行程分享
行程分享是当用户点击行程分享按钮时返服务端会返回一个Url,url链接的页面展示了当前用户的行程信息,实现行程分享的代理方法可以获取到用户要分享的行程信息。
- (**void**)tripShare:(NSDictionary *)tripInfo{
*//*调用第三方分享进行行程分享
}