iOS国内SDK接入文档

此文档适用于使用OC接口的SDK,如使用C++接口SDK,请查看iOS国内SDK C++版接入说明文档
越狱版本接入请查看 依游越狱SDK接入说明

1 接入指南

1.1 获取配置文件

接入前,需要由龙图项目负责人完成渠道申报并在龙图后台进行配置,从而获取到该游戏的渠道参数、龙图的.cfg配置文件,直接加入工程(等同bundle资源).。

1.2 龙图SDK构成

龙图 IOS SDK支持 iPhone、iPad、iPod Touch设备,要求armv7、armv7s或arm64架构,操作系统要求Mac要求OSX以上,Xcode要求11以上,iOS SDK要求8.0以上。
龙图iOS SDK主要由以下几部分构成,如下图:
sdk

[1] Longtulib龙图封装静态库
只支持armv7、armv7s和arm64架构,固件要求iOS8.0以上
[2] Thirdilb第三方静态库.a或Framework
龙图静态库封装调用的第三方静态库或Framework
[3] OpenSource第三方开源库
龙图SDK所使用的第三方开源库或源文件,避免SDK与游戏产生冲突
[4] Splash龙图SDK提供的闪屏支持
苹果2020年4月30日后提交的APP不再支持使用LaunchImage,启动图需要使用StoryBoard来搭建;
StoryBoard介绍:http://sdk.longtubas.com/t3/241/4774/1500008855.html

如果还需要使用SDK闪屏功能请参考如下配置:
闪屏为xcode自带闪屏显示后的闪屏,最多支持3张。使用请在info.plist中设置Longtu_Splash字段,类型Number,数量即闪屏数量(不包括xcode自带闪屏), 分辨率以及命名方式以”名称”(根据分辨率一共包含LTBase_Splash/LTBase_Splash_Pad/LTBase_Splash_pro)+”数字”的组合方式默认一张闪屏不需加数字,之后闪屏图片添加数字”2”,”3”(可参考截图和demo)。若需改变闪屏显示时间请在info.plist中设置Longtu_SplashInterval字段,类型string,建议设置范围2-5秒,闪屏默认间隔2秒。

[5]Analytics三方统计所需的静态库文件

1.3 搭建开发环境

1.3.1 工程配置

Xcode->Project->Build Settings工程配置
[1] 添加库的连接参数
请在工程文件Build Settings处,找到Other Linker Flags,并添加以下内容


[2]其他配置参考下图

1.3.2 Framework添加及配置(请特别注意!)

请将LongtuSDK文件夹拖到你的工程Groups&Files面板中,截图如下

注意:2.2.2版本开始需要删除下图中崩溃相关的LTCrashMonitor.a

添加Framework后

请注意Optional的库,除龙图SDK可选内容外,下图中所有内容都需要添加
如下图:
2.2.2版本新增必加SDKKSCrash.framework库 如图:

2.1.8版本新加系统库

2.0.2版本新加SDK库

1.3.2版本新加系统库

1.3.1版本新加SDK库(必接):

1.3.0版本新加系统库

1.1.4版本新增

1.3.3 设置URL Schemes(请特别注意!)

添加URL Schemes 如下图:
1.具体添加内容为三方参数,需和技术支持同步获取
1.3.3_1

具体方法:选中工程中的Target,选中Info标签页,找到底下的URL Types,展开,点击加号,创建URL Scheme

1.3.4 iOS9、10配置(请特别注意!)

[1] 支持HTTP设置
ios9 下苹果要求 App 内访问网络必须使用 HTTPS ,现阶段不能马上改成 https。
请在 Info.plist 中添加 NSAppTransportSecurity 类型 Dictionary.在 NSAppTransportSecurity 下添加 NSAllowsArbitraryLoads 类型 Boolean,值设为 YES。如下图


[2] 白名单设置
单独接入appstore包时不能添加alipay的白名单,有可能被拒审!
请保留weixin白名单配置)*

  1. <key>LSApplicationQueriesSchemes</key>
  2. <array>
  3. <string>weixin</string>
  4. </array>

[3] 相册、日历、拍照权限设置
使用Xcode8打包时,中访问相册和日历功能需要设置权限使用描述,如下图

  1. <key>NSCalendarsUsageDescription</key>
  2. <string>需要使用日历</string>
  3. <key>NSPhotoLibraryUsageDescription</key>
  4. <string>需要使用相册</string>
  5. <key>NSCameraUsageDescription</key>
  6. <string>需要使用相机</string>
  7. <key>NSUserTrackingUsageDescription</key>
  8. <string>idfa权限描述请联系运营获取</string>
  9. <key>LSRequiresIPhoneOS</key>
  10. <true/>

[4] 崩溃、卡顿监控
若游戏不使用该功能,请将LTCrashMonitor.a从工程中去除。
[5] 去除系统冗余日志输出(非必须)
使用Xcode调试出现大量无用输出时请做以下设置,防止无用的系统日志在控制台输出,如下图

1.3.5 dSYM符号化文件配置(请特别注意!)

[1] dSYM文件
在XCODE编译项目之后,会在app旁看见一个同名的dSYM文件。dSYM文件是iOS编译后保存16进制函数地址映射信息的文件,每次应用程序build后,都会生成对应的xxx.app, xxx.app.dSYM文件。通过此文件可以将16进制地址转换成可读的函数地址,精确定位crash位置,如下图所示:
13.4



[2] 工程配置

1.3.6 内购和苹果登录设置

开启内购和苹果登录前提需要苹果证书设置支持.之后再Xcode进行如下设置.

1.3.7 龙图info.plist参数配置表(请特别注意!)

参数名称 必要性 类型 默认值 功能
LTBase_InitOrientation 必须 String UIInterface
Orientation
Landscape
Right
游戏初始化方向
竖屏:
UIInterfaceOrientationPortrait
右横屏:
UIInterfaceOrientationLandscapeRight
左横屏:
UIInterfaceOrientationLandscapeLeft
LTbase_GameResVersion 必须 String 1.0 游戏资源版本号
LTbase_Debugmodel 必须 Boolean YES 出包前请将其设置成NO。
主要用于查看控制台日志。
YES:调试模式
NO:出包模式
LTbase_GameOnline 必须 Boolean YES 游戏类型
YES: 网游
NO:单机
LTbase_AutoOrientation 非必须 Boolean YES 设置SDK界面是否支持旋转
YES:支持
NO:关闭
LTBase_Splash 非必须 Number 0 SDK闪频数量
(不包括xcode自带闪屏)
LTBase_SplashInterval 非必须 String 2 龙图每张图片闪屏显示时长
(1.0-5.0秒之间)
LTbase_FSInterval 非必须 String 0 Xcode自带闪屏延长显示时长
(1.0-5.0秒之间)
LTbase_FVLocation 非必须 Number 1 首次安装悬浮球显示的位置。
1:左上
2:左中
3:左下
4:右上
5:右中
6:右下
LTbase_ShowInitLoading 非必须 Boolean NO 是否显示登录前的Loading框
YES:显示
NO:关闭
LTbase_BlockInterval 非必须 String 0 游戏卡顿监测间隔(>=5.0秒)、
如果主线程阻塞超过
该时长会发送1条卡顿日志,
去除该字段或设置为0即取消监控
LTbase_DefferingSG 非必须 String UIRectEdgeAll 阻塞对应区域的第一次系统手势
UIRectEdgeAll,
UIRectEdgeNone,
UIRectEdgeTop,
UIRectEdgeLeft,
UIRectEdgeBottom,
UIRectEdgeRight
LTbase_HI_AutoHidden 非必须 Boolean NO 是否自动隐藏
iPhoneX的HomeIndicator
YES:隐藏
NO:显示
LTbase_FVLocationX 非必须 Number 0 自定义设置
首次安装app时悬浮球坐标
坐标X
LTbase_FVLocationY 非必须 Number 0 自定义设置
首次安装app时悬浮球坐标
坐标Y
LTbase_isHiddenInitUI 非必须 Boolean NO 初始化loading图是否展示,值为false或者未添加会默认显示初始化loading图,值为true会隐藏初始化loading图(不建议使用此功能,如果影响游戏展示效果可提前或者推迟调用初始化接口的时机)
  1. <key>LTBase_InitOrientation</key>
  2. <string>UIInterfaceOrientationLandscapeLeft</string>
  3. <key>LTBase_Splash</key>
  4. <integer>0</integer>
  5. <key>LTBase_SplashInterval</key>
  6. <string>0</string>
  7. <key>LTbase_AutoOrientation</key>
  8. <true/>
  9. <key>LTbase_BlockInterval</key>
  10. <string>5</string>
  11. <key>LTbase_Currency</key>
  12. <string>填入所需购买项(选接)</string>
  13. <key>LTbase_Debugmodel</key>
  14. <true/>
  15. <key>LTbase_DefferingSG</key>
  16. <string>UIRectEdgeAll</string>
  17. <key>LTbase_FSInterval</key>
  18. <string>0</string>
  19. <key>LTbase_FVLocation</key>
  20. <integer>1</integer>
  21. <key>LTbase_GameOnline</key>
  22. <true/>
  23. <key>LTbase_GameResVersion</key>
  24. <string>1.0</string>
  25. <key>LTbase_HI_AutoHidden</key>
  26. <false/>
  27. <key>LTbase_Push</key>
  28. <true/>
  29. <key>LTbase_ShowInitLoading</key>
  30. <false/>
  31. <key>LTbase_isHiddenInitUI</key>
  32. <false/>

1.4 接入准备

服务端配置:请参考 通用接入文档—> 《SDK服务端接入说明文档》

2 初始化【必接】

2.1 启动接口

功能说明
应用启动时,初始化SDK,并添加崩溃监控
接口定义

  1. [[LTGameOCSDK shareInstance] LTSDKApplication:application didFinishLaunchingWithOptions:launchOptions];

接口示例

  1. - (BOOL)application:(UIApplication *)application
  2. didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
  3. {
  4. //保证这一句在最前面
  5. [[LTGameOCSDK shareInstance] LTSDKApplication:application didFinishLaunchingWithOptions:launchOptions];
  6. //在下面添加其他逻辑
  7. }

2.2 初始化接口

功能说明

1、初始化第三方SDK,同时获取SDK所需要的初始化数据
2、检查版本更新,初始化内部封装了第三方的更新接口

接口定义

  1. [[LTGameOCSDK shareInstance] LTSDKInit:根控制器];

注意:
1.初始化接口在不同游戏引擎添加的位置不同,具体参看代码示例
2.因苹果机制问题,在某些设备上一些苹果的权限弹框在didFinishLaunchingWithOptions中出不来,所以都放在applicationDidBecomeActive之后;
3.游戏本身的初始化最好在SDK的初始化结束并成功后开始,因为部分渠道的SDK有自动展示LOGO的功能,如果游戏的初始化先于SDK的初始化或两者并行可能会造成渠道的LOGO展示部出来或显示时间很短的BUG
4.由于SDK已集成收集奔溃日志的功能,如果游戏使用的是U3D引擎,需要将UnityAppController.mm中的部分代码进行注释,如下图:

重要提示

遵守LTGameOCSDKDelegate,并实现代理

  1. //所有回调都基于此代理
  2. [LTGameOCSDK shareInstance].delegate = self;

接口示例

遵守LTGameOCSDKDelegate

  1. //初始化回调代理
  2. /// 初始化回调
  3. /// @param result 是否成功
  4. /// @param dict 返回内容
  5. - (void)ltInitCallBackWhitResult:(BOOL)result dict:(NSDictionary *)dict {
  6. //初始化回调结果
  7. }

(1)对于coco2d-x引擎:
初始化接口必须放在cocos2d::CCApplication::sharedApplication()->run();之后,且需要添加代码self.window.rootViewController = viewController;

  1. - (void)applicationDidBecomeActive:(UIApplication *)application
  2. {
  3. self.window.rootViewController = viewController;
  4. [window makeKeyAndVisible];
  5. NSLog(@"LTGameSDK LOG:游戏开始初始化!");
  6. cocos2d::CCApplication::sharedApplication()→run();
  7. NSLog(@"LTGameSDK LOG:LongtuSDK开始初始化");
  8. [[LTGameOCSDK shareInstance] LTSDKInit:viewController];
  9. }

(2)对于unity3d引擎:
初始化接口必须放在OnUnityReady();之后。

  1. - (void)startUnity:(UIApplication*)application
  2. {
  3. OnUnityReady();
  4. //龙图SDK初始化
  5. NSLog(@"LTGameSDK LOG:LongtuSDK开始初始化");
  6. [[LTGameOCSDK shareInstance] LTSDKInit:unity根控制器];
  7. }

2.3 获取SDK可用接口信息

功能说明:
获取SDK接口是否可用
接口示例:

  1. [[LTGameOCSDK shareInstance] LTSDKGetEnableInterface];

返回数据如下,NSDictionary格式
{
“SwitchAccount” : 1,
“Logout” : 1,
“ShowPausePage” : 0,
“EnterAppCenter” : 0,
“ShowToolBar” : 1,
“HideToolBar” : 1,
“RegisterLogin” : 1,
“EnterUserSetting” : 0,
“EnterAppBBS” : 0,
“IsLogin” : 1,
“EnterPlatform” : 1
}
1: 表示接口可用
0: 表示接口不可用
返回数据说明:
切换账号接口 可用
注销账号接口 可用
暂停页接口 不可用
游戏大厅接口 不可用
显示悬浮球接口 可用
关闭悬浮球接口 可用
注册登录接口 可用
用户设置接口 不可用
进入龙图论坛接口 不可用
登录状态接口 可用
用户中心接口 可用

2.3.1 直接获取SDK可用接口信息

功能说明:
获取SDK用户中心接口是否可用
接口示例:

  1. [[LTGameOCSDK shareInstance] LTSDKGetIsEnterPlatform];

返回bool值,yes为可用No不可用;

2.3.2 直接获取SDK可用接口信息

功能说明:
获取SDK注销接口是否可用
接口示例:

  1. [[LTGameOCSDK shareInstance] LTSDKGetIsLogout];

返回bool值,yes为可用No不可用;

2.3.3 直接获取SDK可用接口信息

功能说明:
获取SDK切换账号接口是否可用
接口示例:

  1. [[LTGameOCSDK shareInstance] LTSDKGetIsSwitchAccount]

返回bool值,yes为可用No不可用;

2.4 获取渠道信息接口

功能说明:
获取当前SDK渠道信息

2.4.1 获取ServiceId

获取当前游戏包中的ServiceId,(游戏联运渠道ID,游戏可根据此ID区分各发行渠道)。

  1. [[LTGameOCSDK shareInstance] LTSDKGetServiceId];

返回NSString字符串

2.4.2 获取渠道ID

获取当前游戏包中的ChannelId,(游戏推广渠道ID,含概CPS渠道,短链渠道等唯一标识)。

  1. [[LTGameOCSDK shareInstance] LTSDKGetChannelId];

返回NSString字符串

2.4.3 获取LocaleId

获取当前游戏包中的LocaleId, (游戏发行区域ID)。

  1. [[LTGameOCSDK shareInstance] LTSDKGetLocaleId];

返回NSString字符串

2.4.4 获取DeviceGroupId 机型组ID

获取当前游戏包中的DeviceGroupId, (机型组ID)。

  1. [[LTGameOCSDK shareInstance] LTSDKGetDeviceGroupId];

返回NSString字符串

2.5 设置openURL

功能说明:
在调用第三方app进行支付时,设置该接口,在支付完成后回调游戏。
接口定义:

  1. - (BOOL)LTSDKApplication:(UIApplication *)application handleOpenURL:(NSURL *)url;
  2. - (BOOL)LTSDKApplication:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options;
  3. - (BOOL)LTSDKApplication:(UIApplication *)application openURL:(NSURL *)url
  4. sourceApplication:(NSString *)sourceApplication annotation:(id)annotation;

接口示例: (以下三个方法必须都添加)

  1. - (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url
  2. {
  3. if ([[LTGameOCSDK shareInstance] LTSDKApplication:application handleOpenURL:url]) {
  4. return YES;
  5. }
  6. return NO;
  7. }
  8. - (BOOL)application:(UIApplication *)application openURL:(NSURL *)url
  9. sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
  10. {
  11. if([[LTGameOCSDK shareInstance] LTSDKApplication:application openURL:url sourceApplication:sourceApplication annotation:annotation]) {
  12. return YES;
  13. }
  14. return NO;
  15. }
  16. - (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
  17. {
  18. if([[LTGameOCSDK shareInstance] LTSDKApplication:app openURL:url sourceApplication:[options valueForKey:@"UIApplicationOpenURLOptionsSourceApplicationKey"] annotation:[options valueForKey:@"UIApplicationOpenURLOptionsAnnotationKey"]]) {
  19. return YES;
  20. }
  21. return NO;
  22. }

2.6 屏幕旋转设置

功能说明:
通过从Info.plist文件中获取的LTbase_AutoOrientation参数来设置游戏是否支持自动旋转。但还需要在appDelegate.mm中设置以下方法
接口定义:

  1. - (BOOL)LTSDKApplicationSupportedInterfaceOrientationsForWindow;

接口示例

  1. - (NSUInteger)application:(UIApplication *)application
  2. supportedInterfaceOrientationsForWindow:(UIWindow *)window
  3. {
  4. if ([[LTGameOCSDK shareInstance] LTSDKApplicationSupportedInterfaceOrientationsForWindow]) {
  5. return [[LTGameOCSDK shareInstance] LTSDKApplication:application supportedInterfaceOrientationsForWindow:window];
  6. }
  7. returnUIInterfaceOrientationMaskAll;
  8. }

2.7 页面旋转接口

功能说明:
用于控制界面旋转,请添加至rootViewController中
接口示例:

  1. Objective-C
  2. - (BOOL)shouldAutorotate
  3. {
  4. return [[LTGameOCSDK shareInstance] LTSDKShouldAutoRotate];
  5. }
  6. Unity3D
  7. BOOL ShouldAutorotate_DefaultImpl(id self_, SEL _cmd)
  8. {
  9. return [[LTGameOCSDK shareInstance] LTSDKShouldAutoRotate];
  10. }

2.8 进入前台接口

功能说明:
在游戏进入前台时候调用,暂停页已封装入此接口,请添加至AppDelegate.mm中,U3D游戏为AppController.mm中
接口示例:

  1. - (void)applicationWillEnterForeground:(UIApplication*)application
  2. {
  3. [[LTGameOCSDK shareInstance] LTSDKApplicationWillEnterForeground:application];
  4. }

2.9 已经进入前台接口

功能说明
在游戏已经进入前台时候调用,请添加至AppDelegate.mm中,U3D游戏为AppController.mm中
接口示例:

  1. - (void)applicationDidBecomeActive:(UIApplication*)application
  2. {
  3. [[LTGameOCSDK shareInstance] LTSDKApplicationDidBecomeActive:application];
  4. }

2.10 通知相关接口

功能说明:
登录龙图用户中心。游戏客户端使用SDK的注册功能;请添加至AppDelegate.mm中,U3D游戏为AppController.mm中
接口示例:

  1. - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
  2. {
  3. [[LTGameOCSDK shareInstance] LTSDKApplication:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];
  4. }
  1. - (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
  2. {
  3. [[LTGameOCSDK shareInstance] LTSDKApplication:application didFailToRegisterForRemoteNotificationsWithError:error];
  4. }
  1. - (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
  2. {
  3. [[LTGameOCSDK shareInstance] LTSDKApplication:application didReceiveRemoteNotification:deviceToken];
  4. }

3 登录功能【必接】

3.1 登录流程


1.手机游戏客户端会调用龙图sdk进行sdk初始化操作
2.龙图sdk向龙图用户中心服务器发起登录/注册的请求
3.龙图用户中心服务器向龙图sdk返回token、用户信息等等
4.龙图sdk向返回游戏客户单登录结果和用户信息
5.游戏客户端上传用户信息到游戏服务器
6.服务器根据token向龙图用户中心服务器获取用户信息
7.龙图用户中心服务器向游戏服务器返回用户信息
8.游戏服务器向游戏客户端返回登录结果

3.2 登录接口

功能说明:
登录龙图用户中心。游戏客户端调用登录接口,登录成功后龙图SDK会通过代理方法回调通知给游戏客户端。

接口定义:

  1. //登录接口
  2. - (void)LTSDKRegistLogin;

接口示例:
遵守LTGameOCSDKDelegate

  1. //回调函数
  2. - (void)ltRegistLoginCallBackWhitResult:(BOOL)result dict:(NSDictionary *_Nullable)dict serviceCode:(NSString *)serviceCode {
  3. if (result) {
  4. //用户登录成功,进入创建角色界面
  5. }
  6. else{
  7. //用户登录失败
  8. }
  9. }

返回的字典数据格式说明:
登录成功时 {“userId”:”龙图平台分配的用户唯一id,区分大小写”,
“returnJson”:{第三方SDK平台返回的数据,一般情况下游戏无需关心},
“tokenId”:”龙图分配的tokenId”,
“currentUserType”:”当前用户类型 speedy=快登用户、common=普通用户名密码用户、phone=手机号注册用户、thirdHidden=第三方隐性用户”,
“userName”:”龙图平台中的用户名”}
“serviceCode”: 用于服务端打点使用

登录失败时 {“desc”:”失败描述”,
“reset”:”状态码”,”status”:”1”}

注意:

  1. 返回失败时,SDK不会弹出提示框,需要游戏自行处理失败问题!对于请求超时(状态码为101),也不会弹出提示框,游戏可自动重新连接或自己添加提示框。
  2. 用户区分大小写,相同字母和数字、大小写不同的用户ID代表的是两个不同的用户账号。因此,游戏在使用和存储龙图用户ID时,务必要严格区分大小写,以免造成游戏内账号和角色的混乱等问题。
  3. 如果游戏有自己的用户ID,必须和龙图用户中心的用户ID一一对应,不得出现一对多或者多对一的情况。也不得根据其他条件,组合生成新的用户ID,否则将会出现账号丢失的情况。

3.3 设置角色信息

功能说明:
当游戏角色注册(登录)成功时设置游戏角色注册(登录)信息。
注:
1、游戏角色注册成功后,调用该接口设置角色注册信息。
2、游戏角色登录成功后,调用该接口设置角色登录信息,否则无法计费。
3、此类型是用于兼容第三方SDK中,角色升级的一种类型。

接口定义:

  1. - (void)LTSDKSetGameLoginInfo:(LTParamOC *)gameInfo gameType:(int)gameType;

参数说明:
|参数名称|重要性|类型|说明|
| —————— | —————— | —————— | —————— |
|ltGameInfo|必须|LTGameInfo|设置游戏账号信息|
|ltGameType|必须|LTGameType|用户标识游戏角色注册登录状态注册:kOCGameRegister 登录:kOCGameLogin 角色升级:kOCGameRoleUpgrade|

LTParam参数说明:

参数名称 重要性 类型 说明
RoleName 必须 NSString 游戏角色名称(不支持富文本)
RoleId 必须 NSString 游戏角色 id
ServerId 必须 NSString 游戏服务器id
ServerName 必须 NSString 游戏服务器名称
RoleLevel 必须 NSString 游戏角色等级
RoleVipLevel 必须 NSString 游戏角色vip等级

接口示例:

  1. LTParamOC *roleInfo = LTParamOC.sharedInstance;
  2. roleInfo.RoleId = @"123456"; //游戏角色id
  3. roleInfo.RoleName = @"Jack"; //游戏角色名称
  4. roleInfo.ServerId = @"123"; //游戏服务器id
  5. roleInfo.ServerName = @"test"; //游戏服务器名称
  6. roleInfo.RoleLevel = @"1"; //游戏角色等级
  7. roleInfo.RoleVipLevel = @"1"; //游戏角色vip等级
  8. //游戏角色注册成功时调用
  9. [[LTGameOCSDK shareInstance] LTSDKSetGameLoginInfo:roleInfo gameType:kOCGameRegister];
  10. //游戏角色登录成功时调用
  11. [[LTGameOCSDK shareInstance] LTSDKSetGameLoginInfo:roleInfo gameType:kOCGameLogin];

3.4 注销接口

功能说明:
注销当前登陆账号。注销成功后,龙图SDK会通过代理方法回调通知给游戏客户端。

接口定义:

  1. - (void)LTSDKLogOut;

接口示例:
遵守LTGameOCSDKDelegate

  1. //回调函数
  2. - (void)ltLogOutCallBackWhitResult:(BOOL)result dict:(NSDictionary *)dict {
  3. //返回的字典数据格式说明
  4. 调用登出接口,登出成功时
  5. {"Type":"Logout"}
  6. 调用切换账号,登出成功时
  7. {"Type":"SwitchAccount"}
  8. }
  9. //注销接口
  10. [LTGameOCSDK.shareInstance LTSDKLogOut];

3.5 切换账号

功能说明
游戏内切换账号功能,调用接口SDK会先拉起切换页面,用户切换完成后会通过切换账号回调返回用户信息.
注意:
当前渠道带有切换账号功能时,游戏需要实现此接口逻辑进行游戏登录。切换账号分2种情况:
一是调用SDK的切换账号接口实现账号的切换,此类型的切换账号按钮是由游戏去实现,建议放到登录界面,切换账号成功后,登录数据会在此接口返回,游戏可执行游戏的登录流程,类似登录成功接口的回调。
二是渠道SDK的悬浮框或者用户中心页面带有切换账号功能,如用户点击切换账号并登录成功后,登录数据会在此接口返回,但如果当前游戏场景处于游戏中,游戏正常应该先返回到登录界面,然后再通过SDK切换账号成功返回的数据执行游戏的登录流程。

接口定义

  1. - (void)LTSDKSwitchAccount;

接口示例

  1. //回调函数
  2. - (void)ltSwitchAccountCallBackWhitResult:(BOOL)result dict:(NSDictionary *)dict{
  3. NSLog(@"*********OC ltSwitchAccountCallBackWhitResult ******** = %@",dict);
  4. if(result)
  5. {
  6. //进入登录页面
  7. NSLog(@" 切换账号成功,进入登录页面 ");
  8. NSString *userid = [dict objectForKey:@"userId"];
  9. NSString *tokenId = [dict objectForKey:@"tokenId"];
  10. NSString *currentUserType = [dict objectForKey:@"currentUserType"];
  11. NSString *userName = [dict objectForKey:@"userName"];
  12. NSLog(@"userid = %@,tokenid = %@,currentusertype = %@,username = %@",userid,tokenId,currentUserType,userName);
  13. }
  14. else
  15. {
  16. NSLog(@" 切换账号失败 ");
  17. }
  18. }
  19. //切换账号接口
  20. [LTGameOCSDK.shareInstance LTSDKSwitchAccount];

4 支付功能【必接,CB期间根据运营需求接入】

4.1 支付流程


1.龙图sdk向龙图计费服务器发起支付请求
2.龙图计费服务器生成订单号,并向sdk返回支付结果
3.龙图计费服务器通知游戏服务器发货
4.游戏服务器发送虚拟物品至玩家手机游戏客户端
5.游戏服务器向计费服务器返回发货结果

4.2 支付接口

功能说明
游戏客户端通过调用计费接口,实现游戏中的道具购买。游戏客户端调用计费接口,计费成功后,龙图SDK会通过代理方法通知游戏客户端。
接口定义:

  1. - (void)LTSDKChargeWithParams:(LTPurchaseParamOC *)params;

参数说明

参数名称 重要性 类型 说明
price 必填 NSString 商品价格,单位详见6.4货币类型及对应ID
currencyType 必填 NSString 货币类型,详见6.4货币类型及对应ID
propName 必填 NSString 商品名称,不含数字
propId 必填 NSString 游戏自定义的商品ID,必传。
propNum 必填 NSString 商品数量,只能是数字
propDescribe 非必填 NSString 商品描述
deleverUrl 非必填 NSString 游戏发放道具服务器地址,用户支付成功后计费中心会回调此地址告知游戏进行道具发放。 可以配置到SDK后台。
extendParams 非必填 NSString 游戏自定义扩展参数*透传参数转json后,必须小于500个字符
gameRoleLevel 非必填 NSString 游戏角色等级
gameRoleVipLevel 非必填 NSString 游戏角色VIP等级

回调说明

参数名称 类型 说明
result BOOL 是否成功(true:成功,false:失败)
ssId NSString 订单号,失败时可能为空
propId NSString 商品ID,失败时可能为空
code NSString 状态码(附录12.1)
msg NSString 描述信息

接口示例:
遵守LTGameOCSDKDelegate

  1. - (void)purchase:(UIButton *)btn
  2. {
  3. LTPurchaseParamOC *params = LTPurchaseParamOC.sharedInstance;
  4. params.price =@"1";//商品价格,以分为单位(必填)
  5. params.propId = @"1004";//商品id(必填)boringcat.diamond.1
  6. params.currencyType = @"1";//货币类型,人民币为1(必填)
  7. params.propName = @"10元宝";//商品名称,不含数字(必填)
  8. params.propNum = @"1";//商品数量
  9. params.propDescribe = @"";//商品描述(可选)
  10. params.deleverUrl = @"";//发货地址(可选)
  11. params.extendParams = @"";//扩展参数(可选)
  12. [LTGameOCSDK.shareInstance LTSDKChargeWithParams:params];//购买接口
  13. }
  14. //代理方法
  15. - (void)ltOnPurchaseResultWithResult:(BOOL)result ssId:(NSString *)ssId propId:(NSString *)propId code:(NSString *)code msg:(NSString *)msg {
  16. NSString *des = [NSString stringWithFormat:@"result = %@ \n ssid = %@ \n propid = %@ \n code = %@ \n msg = %@" ,result ? @"yes" : @"no" , ssId, propId, code, msg];
  17. if (result) {
  18. NSLog(@"ltOnurchascallback success = %@",des);
  19. }
  20. else{
  21. NSLog(@"ltOnurchascallback failed = %@",des);
  22. }
  23. }

4.3礼包码接口

游戏客户端通过调用礼包码接口,实现游戏中的礼包兑换。游戏客户端调用礼包码接口前,需要设置代理,兑换成功后,龙图SDK会通过代理方法通知游戏客户端。
接口定义

  1. /// 礼包码接口
  2. /// @param gameCode 礼包码
  3. /// @param deliverUrl URL
  4. /// @param extendParams 透传参数
  5. - (void)LTSDKExchangeGameCode:(NSString *)gameCode deliverUrl:(NSString *)deliverUrl extendParams:(NSString *)extendParams;
参数名称 重要性 类型 说明
gameCode 必填 NSString 后台配置的礼包码
deliverUrl 必填 NSString 回调地址
extendParams 必填 NSString 拓展参数

接口示例

  1. //调用
  2. [[LTGameOCSDK shareInstance] LTSDKExchangeGameCode:_customPayPrice.text deliverUrl:@"http://pay.z4v.cn/Pay_Accept/ResponseDeliver?ssid=2013030715493703719999" extendParams:@""];
  3. //回调方法
  4. - (void)ltOnGamecodeResultWithResult:(BOOL)result code:(NSString *)code msg:(NSString *)msg {
  5. NSString *des = [NSString stringWithFormat:@"result = %@ \n code = %@ \n msg = %@" ,result ? @"yes" : @"no" , code, msg];
  6. if (result) {
  7. NSLog(@"ltOnGamecodeResult success = %@",des);
  8. }
  9. else{
  10. NSLog(@"ltOnGamecodeResult failed = %@",des);
  11. }
  12. }

5 其他功能

5.1 进入用户中心接口【必接】

功能说明:
进入用户中心界面。根据接口LTSDKGetEnableInterface来判断当前渠道是否支持该接口。
接口示例:

  1. [[LTGameOCSDK shareInstance] LTSDKEnterPaltform];

5.2 打开带导航条的webview【选接】

功能说明
调用native的webview显示页面,带有刷新、前进、后退、关闭的功能

  1. 调用时传入URL即可
  2. [LTGameOCSDK.shareInstance LTSDKOpenWebviewWithNavbarWithUrl:url];

5.3 打开活动公告接口【选接】

功能说明:
调用打开活动公告接口并在回调里返回公告开关信息

  1. 调用时传入获取的公告类型即可(暂只涉及活动公告)
  2. LTGameSDK::GetInstance().GetNotice(kOCNoticeLogin);
  3. typedef NS_ENUM(NSUInteger, LTOCNoticeType){
  4. kOCNoticeLogin=0,
  5. kOCNoticeActivity,//游戏内应该公告使用这个
  6. };

遵守LTGameOCSDKDelegate
最后在回调里拿到相应的活动公告及登录公告的开关信息

  1. // 公告展示回调
  2. - (void)ltNoticeTypeCallBackWithResult:(BOOL)result dict:(NSDictionary *)dict{
  3. int type = [[dict objectForKey:@"type"] intValue];
  4. int start = [[dict objectForKey:@"start"] intValue];
  5. if (start == 100) {//100为跳转游戏内部链接并关闭公告同时增加返回openUrl字段
  6. [[LTGameOCSDK shareInstance] LTSDKShowMessage:[dict objectForKey:@"openUrl"]];
  7. }
  8. if (result) {//true表示请求连接成功,false表示连接请求失败
  9. if(type == 0){//type=0,代表登录公告,1活动公告,2活动页面
  10. if (start == 1) {//start=1s代表页面已打开,2代表已关闭,0代表失败---100为跳转游戏内部链接并关闭公告同时增加返回openUrl字段
  11. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"登录公告打开"];
  12. }
  13. else{
  14. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"登录公告关闭"];
  15. }
  16. }
  17. else if (type == 1){
  18. if (start == 1) {
  19. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"活动公告打开"];
  20. }
  21. else{
  22. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"登录公告打开"];
  23. }
  24. }
  25. else{
  26. if (start == 1) {
  27. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"活动页面打开"];
  28. }
  29. else{
  30. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"活动页面关闭"];
  31. }
  32. }
  33. } else {
  34. if(type == 0){
  35. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack登录公告失败"];
  36. }
  37. else if (type == 1){
  38. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack活动公告失败"];
  39. }
  40. else if (type == 2){
  41. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack活动页面失败"];
  42. }
  43. else{
  44. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack失败"];
  45. }
  46. }
  47. }

5.4 游戏进度上报【必接】

研发上报游戏现在的进度,用于SDK标记游戏现在所处进度,并进行相关操作。
以悬浮层按钮开关为例:
SDK会在进入服务器列表时打开SDK悬浮功能条,
SDK会在离开服务器选择时关闭SDK悬浮功能条,
请研发上报事件时尽量准确。

  1. /**
  2. * 游戏内事件,悬浮按钮定义
  3. */
  4. typedef NS_ENUM(NSUInteger, LTOCGameProcessEventType) {
  5. GAMEOC_PROCESS_EVENT_TYPE_IN_SELECT_SERVERLIST, /**< 进入到选择服务器列表页面。 */
  6. GAMEOC_PROCESS_EVENT_TYPE_OUT_SELECT_SERVERLIST, /**<离开选择服务器列表页面 */
  7. };

研发主动调用,传入不同的事件用于标记游戏现在所处进度

  1. [[LTGameOCSDK shareInstance] LTSDKBaseSendGameProcessEventType:GAMEOC_PROCESS_EVENT_TYPE_IN_SELECT_SERVERLIST];

5.5 展示活动外链页面接口【选接】

功能说明:
调用接口传入活动ID和角色信息,成功后会打开外链页面

  1. LTParamOC *roleInfo = LTParamOC.sharedInstance;
  2. roleInfo.RoleLevel = @"50";
  3. roleInfo.RoleVipLevel = @"0";
  4. [[LTGameOCSDK shareInstance] LTSDKGetAvtivityViewWithActivityId:@"21" Info:roleInfo];

遵守LTGameOCSDKDelegate
最后在回调里拿到相应的活动页面开关信息(公告和活动详情共用一个回调)

  1. - (void)ltNoticeTypeCallBackWithResult:(BOOL)result dict:(NSDictionary *)dict{
  2. int type = [[dict objectForKey:@"type"] intValue];
  3. int start = [[dict objectForKey:@"start"] intValue];
  4. if (start == 100) {//100为跳转游戏内部链接并关闭公告同时增加返回openUrl字段
  5. [[LTGameOCSDK shareInstance] LTSDKShowMessage:[dict objectForKey:@"openUrl"]];
  6. }
  7. if (result) {//true表示请求连接成功,false表示连接请求失败
  8. if(type == 0){//type=0,代表登录公告,1活动公告,2活动页面
  9. if (start == 1) {//start=1s代表页面已打开,2代表已关闭,0代表失败---100为跳转游戏内部链接并关闭公告同时增加返回openUrl字段
  10. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"登录公告打开"];
  11. }
  12. else{
  13. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"登录公告关闭"];
  14. }
  15. }
  16. else if (type == 1){
  17. if (start == 1) {
  18. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"活动公告打开"];
  19. }
  20. else{
  21. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"登录公告打开"];
  22. }
  23. }
  24. else{
  25. if (start == 1) {
  26. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"活动页面打开"];
  27. }
  28. else{
  29. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"活动页面关闭"];
  30. }
  31. }
  32. } else {
  33. if(type == 0){
  34. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack登录公告失败"];
  35. }
  36. else if (type == 1){
  37. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack活动公告失败"];
  38. }
  39. else if (type == 2){
  40. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack活动页面失败"];
  41. }
  42. else{
  43. [[LTGameOCSDK shareInstance] LTSDKShowMessage:@"noticeCallBack失败"];
  44. }
  45. }
  46. }

5.6 客服中心接口【弃用】

客服中心功能弃用,请使用aihelp 客服功能。

5.7 获取ServiceCode接口【必接】

功能说明:
登录成功以后通过登录成功回调返回serviceCode.
可以通过登录成功回调获取。

5.8 获取CDN接口【必接】

功能说明:
调用获取CDN列表接口

  1. [LTGameOCSDK.shareInstance LTSDKGetCdnPathList];

遵守LTGameOCSDKDelegate
最后在回调里拿到CDN列表信息

  1. /// cdn回调
  2. /// @param result 是否成功
  3. /// @param dict 返回内容
  4. - (void)ltUpdateCDNPathListenerWithResult:(BOOL)result dict:(NSDictionary *)dict {
  5. if (result) {
  6. NSLog(@"UpdateCDNPathListener = %@",dict);
  7. [self showMessage:[NSString stringWithFormat:@"%@",[dict objectForKey:@"domainList"]]];
  8. }
  9. else{
  10. NSLog(@"UpdateCDNPathListener = failed");
  11. [self showMessage:@"获取cdn失败"];
  12. }
  13. }

5.9 获取snid接口【停用】

获取产品snid

  1. [[LTGameOCSDK shareInstance] LTSDKGetSnid];

5.10 第三方广告平台打点接口【选接】

接口说明

  1. /// 第三方广告接口
  2. /// @param event_key 事件
  3. /// @param dict 内容
  4. - (void)LTSDKLogEvent:(NSString *)event_key dictionary:(NSDictionary *)dict;

接口示例

  1. NSMutableDictionary *dict = [[NSMutableDictionary alloc] init];
  2. [dict setObject:[[LTGameOCSDK shareInstance] LTSDKGetUserId] forKey:@"userId"];
  3. [dict setObject:@"123456" forKey:@"roleId"];
  4. [[LTGameOCSDK shareInstance] LTSDKLogEvent:@"registration" dictionary:dict];

5.11 显示协议页面【必接】

显示隐私协议页面

  1. [[LTGameOCSDK shareInstance] LTSDKShowPrivacyView];

5.12 苹果商店评价接口【选接】

必看事项:
调用契机
1,仅在用户展示与您的应用程序的互动后才能要求评级。
2,不要中断用户,特别是当他们执行时间敏感或压力很大的任务时。例如一个购物 App 在用户正在下单的过程中弹出一个请求评分
3,不要像瘟疫。这是个比喻,意思为不要频繁请求评分,烦不胜烦!
4,不要使用按钮和其他控件来请求。因为这个 API 的响应机制受限于 App Store 策略,不受我们把控,谁都不希望点击按钮/控件之后无响应出现,搞得用户莫名其妙!

5.12.1 应用内评价

必看事项:
该接口在系统10.3及以上的设备中的同一个应用(线上)一年(365天)内只可以展示3次,是否展示由苹果自行处理不受我们控制(该接口需联网);10.3以下设备为跳转商店方式(同下接口),可多次调用,不受一年三次限制,但都受上面调用契机的限制,否则被苹果审核时发现可能会被打回拒审.

示例:

  1. [[LTGameOCSDK shareInstance] LTSDKOpenStoreReview];

5.12.2 跳转到苹果商店评价

必看事项:
跳转商店方式(同下接口),可多次调用,不受一年三次限制,系统版本不限,但都受上面调用契机的限制,否则被苹果审核时发现可能会被打回拒审.

示例:

  1. [[LTGameOCSDK shareInstance] LTSDKSkipStoreReview];

5.13 获取客户端真实IP【选接】

获取客户端真实IP , 登录成功以后获取。1.2.9版本增加。

  1. [[LTGameOCSDK shareInstance] getClientIP];

5.14 充值异常SDK提示错误弹窗【选接】

游戏自行判断下单时候充值异常(如当前充值的角色账号与登录账号关系不一致时),可选用调用此接口让SDK弹出固定的错误提示弹窗,用户点击弹窗上的确定按钮会自动退出当前账号登录让用户重新登录,也可自行提示。

  1. [[LTGameOCSDK shareInstance] LTSDKShowPurchaseFailedTipView];

5.15 设置语言(海外地区接口)【选接】

注:仅限海外多语言地区使用

  1. typedef NS_ENUM(NSUInteger, LTOCLanguageType){
  2. kOCDefault=0,//默认英文
  3. kOCChinese,//简体
  4. kOCEnglish,//英语
  5. kOCKorean,//韩语
  6. kOCTaiwan,//繁体
  7. kOCGermany,//德语
  8. kOCRussia,//俄语
  9. kOCFrance,//法语
  10. kOCThailand,//泰语
  11. kOCSpain,//西班牙语
  12. kOCItaly,//意大利语
  13. kOCIndonesia,//印度尼西亚语
  14. kOCPortugal,//葡萄牙语
  15. };
  16. [[LTGameOCSDK shareInstance] LTSDKSetLanguage:kOCDefault];

5.16 问卷调查打开【选接】

需要和技术支持协商使用,
问卷调查ID需要在平台配置。
接口说明:

  1. /**
  2. * 打开问卷调查
  3. * @param QuestionId 问卷id
  4. * @param roleLv 角色等级
  5. * @param roleVipLv 角色vip等级
  6. * @param customParams 透传参数 研发自定义 可以为null。透传参数转JSON后,必须小于1000个字符
  7. */
  8. - (void)LTSDKOpenQuestionnaireWithQuestionId:(NSString *_Nonnull)QuestionId roleLv:(NSString *_Nonnull)roleLv roleVipLv:(NSString *_Nonnull)roleVipLv customParams:(NSDictionary *_Nullable)customParams;

调用方法:

  1. NSMutableDictionary *dict = [[NSMutableDictionary alloc] init];
  2. [dict setValue:@"value1" forKey:@"key1"];
  3. [dict setValue:@"value2" forKey:@"key2"];
  4. [[LTGameOCSDK shareInstance] LTSDKOpenQuestionnaireWithQuestionId:@"1" roleLv:@"44" roleVipLv:@"9" customParams:dict];

5.17 清除当前角色信息【选接】

接口说明:角色登出时清除当前登录的角色信息

  1. /// 角色登出
  2. - (void)LTSDKClearRoleData;

调用方法:

  1. /// 角色登出
  2. [[LTGameOCSDK shareInstance] LTSDKClearRoleData];

5.18 获取客户端国家【选接】

接口说明:

  1. - (NSString *)LTSDKGetClientLocationCountry; // 获取客户端国家

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKGetClientLocationCountry];

5.19 获取客户端省份【选接】

接口说明:

  1. - (NSString *)LTSDKGetClientLocationProvince; // 获取客户端省份

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKGetClientLocationProvince];

5.20 服务器公告【选接】

接口说明:当前仅支持登录公告样式,其他公告调用会出现异常.

  1. //公告带服务器ID
  2. - (void)LTSDKGetNoticeWithType:(int)noticeType serverid:(NSString *)serverid;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKGetNoticeWithType:kOCNoticeLogin serverid:@"服务器ID"];

5.21 龙图论坛接口【选接】

5.21.1 直接打开龙图论坛页面接口

2.1.9版本新增
接口说明:调用展示龙图论坛页面(需要在后台提前配置龙图论坛页面).

  1. //龙图论坛
  2. - (void)LTSDKShowForumView;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKShowForumView];

5.21.2 透传参数到龙图论坛接口

2.2.4版本新增
接口说明:调用展示龙图论坛页面(需要在后台提前配置龙图论坛页面).

  1. //龙图论坛
  2. - (void)LTSDKShowForumView:(NSString *_Nullable)customparas;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKShowForumView:@"透传内容"];

5.21.2.1 customparas 透传参数说明

该接口由SDK通过服务端接口platform-app-activity提供,负责按照龙图论坛的要求整理跳转参数,并自动跳转到龙图论坛地址
customparas 介绍

字段 类型 介绍
function string 功能标识; topicId:标识打开指定帖子,此时data中应该传帖子ID; subjectId:标识打开话题主页,此时data 中应该传话题id; encyclopedia:标识打开百科页面; gift-bag:标识打开礼包中心; userCenter:标识打开个人中心; 如果不填写该值,默认跳转到龙图论坛首页
data string 根据不同的function传递不同的数据

5.21.3 龙图论坛设置背景颜色并透传参数

2.3.4版本新增
接口说明:调用展示龙图论坛页面(需要在后台提前配置龙图论坛页面).

  1. /// 龙图论坛设置背景颜色并透传参数
  2. /// - Parameters:
  3. /// - customparas: 透传参数,可传空字符串
  4. /// - colorHex: 16进制颜色码例如:(0xff0000为红色),使用默认颜色可传空字符串
  5. - (void)LTSDKShowForumView:(NSString *_Nullable)customparas colorHex:(NSString *_Nullable)colorHex;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKShowForumView:@"测试test" colorHex:@"0xff0000"];

5.22 双清单接口【必接】

2.2.6版本新增
调用展示已收集个人信息清单页面或与第三方共享个人信息清单

5.22.1 已收集个人信息清单

接口说明:调用展示已收集个人信息清单页面.

  1. /// 已收集个人信息清单
  2. - (void)LTSDKShowPersonalInfoList;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKShowPersonalInfoList];

5.22.2 与第三方共享个人信息清单

接口说明:调用展示与第三方共享个人信息清单页面.

  1. /// 与第三方共享个人信息清单
  2. - (void)LTSDKShowThirdInfoList;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKShowThirdInfoList];

5.23 龙图论坛打开/关闭回调接口【选接】

功能说明:
调用打开龙图论坛接口
注意:此处参考5.21接口

遵守LTGameOCSDKDelegate
最后在回调里拿到龙图论坛开关信息(回调支持2.3.2及以上版本)

  1. - (void)ltGetOpenForumViewCallBack:(BOOL)isOpen{
  2. //isOpen=true为打开,=false为关闭
  3. // NSString *open = [NSString stringWithFormat:@"论坛%@", isOpen ? @"打开" : @"关闭"];
  4. NSLog(@"*********ltGetOpenForumViewCallBack********\n%@",isOpen ? @"open" : @"close");
  5. }

5.24 设置当前控制器接口【选接】

接口说明:传入当前游戏所在控制器

  1. /// 设置游戏当前控制器
  2. /// - Parameter viewController: 控制器
  3. - (void)LTSDKSetSDKViewController:(UIViewController *)viewController;

调用方法:

  1. [[LTGameOCSDK shareInstance] LTSDKSetSDKViewController:控制器];

5.25 打开选服页面【选接】

接口说明:打开选服页面

  1. /// 打开选服页面
  2. /// - Parameter productList: 产品数组(详细内容参见文档)
  3. - (void)LTSDKShowProductList:(NSString *_Nullable)productList;

调用方法:

  1. NSMutableDictionary *mGame1 = [[NSMutableDictionary alloc] init];
  2. [mGame1 setValue:@"510050" forKey:@"gameid"];
  3. [mGame1 setValue:@"1002" forKey:@"snid"];
  4. NSMutableDictionary *mGame2 = [[NSMutableDictionary alloc] init];
  5. [mGame2 setValue:@"2000009701" forKey:@"gameid"];
  6. [mGame2 setValue:@"1002" forKey:@"snid"];
  7. NSString *mGameStr1 = [self convertToJsonData:mGame1];
  8. NSString *mGameStr2 = [self convertToJsonData:mGame2];
  9. NSMutableDictionary *mDict = [[NSMutableDictionary alloc] init];
  10. [mDict setValue:@"20000097" forKey:@"id"];
  11. [mDict setValue:mGameStr2 forKey:@"extendParams"];
  12. [mDict setValue:@"16002" forKey:@"customVersion"];
  13. NSMutableDictionary *mDict1 = [[NSMutableDictionary alloc] init];
  14. [mDict1 setValue:@"20000041" forKey:@"id"];
  15. [mDict1 setValue:mGameStr1 forKey:@"extendParams"];
  16. [mDict1 setValue:@"18010" forKey:@"customVersion"];
  17. NSMutableArray *mArr = [[NSMutableArray alloc] init];
  18. [mArr addObject:mDict1];
  19. [mArr addObject:mDict];
  20. NSLog(@"reString1 = %@", mArr);
  21. NSData *jsonData = [NSJSONSerialization dataWithJSONObject:mArr options:NSJSONWritingPrettyPrinted error:nil];
  22. NSString *jsonString = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
  23. NSLog(@"jsonString:%@",jsonString);
  24. [[LTGameOCSDK shareInstance] LTSDKShowProductListjsonString];
  25. 字典转字符串
  26. - (NSString *)convertToJsonData:(NSDictionary *)dict{
  27. if (dict == nil) {
  28. return @"";
  29. }
  30. NSError *error;
  31. NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dict options:NSJSONWritingPrettyPrinted error:&error];
  32. NSString *jsonString;
  33. if(!jsonData) {
  34. NSLog(@"%@",error);
  35. jsonString = [[NSString alloc] init];
  36. }else{
  37. jsonString = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
  38. }
  39. NSMutableString *mutStr = [NSMutableString stringWithString:jsonString];
  40. NSRange range = {0,jsonString.length};
  41. //去掉字符串中的空格
  42. [mutStr replaceOccurrencesOfString:@" " withString:@"" options:NSLiteralSearch range:range];
  43. NSRange range2 = {0,mutStr.length};
  44. //去掉字符串中的换行符
  45. [mutStr replaceOccurrencesOfString:@"\n" withString:@"" options:NSLiteralSearch range:range2];
  46. return mutStr;
  47. }

productList 类型

参数名称 重要性 类型 说明
productList 必填 NSArray 产品数组

数组内JSON类型,请按照下表key,value传入json数组

参数名称 重要性 类型 说明
id 必填 NSString 产品ID
extendParams 可为空 NSString 透传参数,如:{“gameid”:”510050”,”snid”:”1002”}
customVersion 必填 NSString 自定义版本号

5.26 选服页面结果回调【选接】

功能说明:
接收选服页面结果回调接口

遵守LTGameOCSDKDelegate
在回调里拿到选服结果(回调支持2.3.4及以上版本)

5.26.1 选择服务器完成回调

  1. /// 选择服务器完成回调
  2. /// @param productId 产品ID
  3. /// @param serverId 服务器ID
  4. /// @param roleId 角色ID(可能为空)
  5. /// @param extendParams 透传参数
  6. - (void)ltGetSelectServerSuccessCallBackWithProductId:(NSString *)productId serverId:(NSString *)serverId roleId:(NSString *)roleId extendParams:(NSString *)extendParams{
  7. NSLog(@" 选服结果%@ ",[NSString stringWithFormat:@"productId:%@ \n serverId:%@\n roleId:%@ \n extendParams:%@",productId,serverId,roleId,extendParams]);
  8. }

5.26.2 选择服务器失败回调

  1. /// 选择服务器失败回调
  2. /// @param errorCode 错误码 23为失败
  3. - (void)ltGetSelectServerFailCallBack:(int)errorCode{
  4. NSLog(@" 选服失败%d ",errorCode);
  5. }

6 分享功能【选接】

龙图SDK分享功能目前整合了微信、QQ、新浪微博、Facebook、Twitter等SDK,包含文本分享、图片分享、链接分享等功能。点击链接查看详情
http://sdk.longtubas.com/t3/241/4774/1500007469.html

7 语音功能【选接】

龙图SDK语音功能目前整合了腾讯语音SDK,包含离线语音、实时语音等功能。点击链接查看详情
http://sdk.longtubas.com/t3/241/4774/1500007728.html

8 图形验证功能【选接】

整合了极验图形验证功能。点击链接查看详情
http://sdk.longtubas.com/t3/241/4774/1500007733.html

9 AIHelp功能【必接】

整合了AIHelpSDK,包含客服模块、FAQ模块、运营模块等功能。点击链接查看详情
http://sdk.longtubas.com/t3/241/4774/1500009871.html

10 WeGame功能【选接】

整合了WeGameSDK,包含WeGame登录功能。点击链接查看详情
http://sdk.longtubas.com/t3/241/4774/1500010403.html

11 三方登录 【必接】

龙图三方登录是一个聚合SDK,目前整合了微信、QQ、新浪微博、Facebook、Twitter等SDK,包含登录功能
http://sdk.longtubas.com/t3/241/4774/1500007469.html

12 附录

12.1 客户端错误码

状态码 说明
101 连接超时
102 网络异常,请检查网络
103 数据异常
104 SDK初始化参数错误
105 SDK语言配置文件错误
106 ltgame.cfg配置文件错误
107 SDK未初始化成功
108 SDK未设置登录回调
109 未设置服务器id
110 未设置价格
111 未设置货币类型
112 未设置商品名称
113 未设置商品id
114 未设置虚拟货币单位
115 未设置虚拟货币数量
116 未设置发货地址
117 未设虚拟货币单位
118 未设商品数量
119 用户取消支付
120 支付失败
121 支付页面加载失败
141 下单操作过于频繁
200 支付成功
201 下单成功

12.2 用户中心错误码

用户中心错误码 信息
01010001 成功
01010002 次数已经达到上限,请12小时后再发送
01010003 该用户没有绑定手机
01010004 原密码不正确
01010005 没有找到该用户信息
01010006 令牌验证错误
01010007 验证码不正确
01010008 验证码超时
01010009 该用户已经绑定手机
01010010 用户昵称不存在
01010011 昵称已存在,请重新输入
01010012 该账号已存在
01010013 Email不存在,请重新输入Email
01010014 发送验证码失败
01010014 繁体-发送验证码失败
01010015 失败
01010016 邮箱验证失败
01010017 邮箱验证成功
01010018 密码修改失败
01010019 密码修改成功
01010020 昵称修改失败
01010021 昵称修改成功
01010022 手机验证码发送失败
01010023 手机验证码发送成功
01010024 发送未绑定手机验证码失败
01010025 发送未绑定手机验证码成功
01010026 用户绑定失败
01010027 用户绑定成功
01010028 手机绑定失败
01010029 手机绑定成功
01010030 邮箱绑定失败
01010031 邮箱绑定成功
01010032 手机验证码验证失败
01010033 手机验证码验证成功
01010034 重置密码失败
01010035 重置密码成功
01010036 获取用户信息失败
01010037 获取用户信息成功
01010038 该用户暂未绑定手机
01010039 该手机号已被绑定,请更换手机号
01010040 用户名不能是手机号
01010041 用户名不能是邮箱
01010043 邮箱绑定失败
01010044 密码修改失败,新密码与原密码相同
01010045 用户密码为空
01010046 登录密码不正确
01010047 手机解绑失败
01010048 第三方用户已绑定
01010049 账号为6-18位,数字、字母、”_”
01010050 密码为6-14位,数字、字母组合
01010051 该账号不存在
01010052 昵称不合法
01010053 接口参数不正确,请确认
01010054 输入的身份证号码格式有误
01010055 当前用户已做过验证
01010056 真实姓名格式有误
01010057 角色信息参数有误
01010058 参数不全或不完整
01010059 用户名未作更改
01010060 未获取到用户信息
01010061 游戏服Id不得为空
01010062 用户Id不能为空
01010063 产品接口未配置
01010064 调用查询角色接口出错
01010065 未查询到角色
01020001 成功
01020002 密码错误,请重试
01020003 密码错误,请重试
01020004 注册失败
01020005 失败
01020006 该账号已存在
01020007 账号为6-18位,数字、字母、”_”
01020008 限制登录
01020009 限制首登
01020010 限制初始化
01020011 当前玩家的手持设备的IP地址已经被游戏封停
01020012 玩家的手持设备已经被游戏封停
01020013 当前玩家账号已经被游戏封停
01020014 没有找到该用户信息
01020015 查询激活信息失败
01020016 激活的tokenId不正确
01020017 用户激活失败
01020018 激活码无效
01020019 密码为6-14位,数字、字母组合
01020020 请使用已激活的账号登录
01020021 激活码已经被使用
01020022 您已经激活过其他设备,不能在多台设备上激活
01020023 用户密码不能为空
01020024 该账号不存在
01020025 内测阶段,暂不支持第三方登录
01020026 您的账号存在安全隐患,请联系客服:4000688900
01020027 没有该用户信息
01020028 设备信息获取失败
01020029 验证码有误
01020030 验证码已过期
01020031 注册手机号不能为空
01020032 验证码不能为空
01020033 该手机号已被绑定,请更换手机号
01020034 登录失败,请使用账号密码重试!
01030000 心跳处理成功
01030001 心跳处理失败
01030002 sessionId为空
01030003 session已过期
01040000 成功
03010000 已经被激活
03010001 角色查询参数不全
03010002 参数不全
03010003 角色已注册
03010004 注册发生错误

12.3 计费中心错误码

计费 错误码 信息
21000 成功
21001 请求的json串格式不正确
21002 json对象格式不正确
21003 json字符串转换为对象错误
21004 道具格式不正确
21005 返回bean格式不正确
21006 没有筛出计费点
21007 驱动格式不正确
21099 全局异常错误
21100 common节点格式不正确
21101 options节点格式不正确
21102 common中interfaceId不能为空
21103 tokenId格式不正确
21104 serviceId格式不正确
21105 deviceGroupId格式不正确
21106 localeId格式不正确
21107 pCode格式不正确
21108 netSource格式不正确
21120 device格式不正确
21121 mac格式不正确
21122 手机号码错误
21123 发货地址格式不正确
21130 批价ID格式不正确
21131 道具ID格式不正确
21132 sdkVersion格式不正确
21133 userId格式不正确
21134 roleId格式不正确
21135 roleName格式不正确
21136 gameType格式不正确
21137 gameServerId格式不正确
21138 gameClientVersion格式不正确
21139 当前业务下没有该道具
21140 计费点ID格式不正确
21141 充值金额格式不正确
21142 货币类型格式不正确
21143 gameServerId在平台没有启用,需要在平台上配置游戏服ID
21144 游戏产品不存在
21145 平台操作失败.
21146 请求报文头格式不正确
21147 手机平台ID格式不正确
21148 设备名称格式不正确
21149 设备系统版本号格式不正确
21150 设备分辨率格式不正确
21151 设备UDID格式不正确
21152 运营商格式不正确
21153 设备厂商格式不正确
21154 手机号格式不正确
21155 用户ID格式不正确
21156 代计费功能同步渠道异常
21157 超过用户日最大计费金额
21158 超过用户月最大计费金额
21159 黑名单用户
21160 充值失败
21161 超过计费点日最大计费金额
21162 超过计费点月最大计费金额
21163 道具名称不能为空
21164 通知发货成功
21165 计费失败
21166 等待支付结果
21167 指令错误
21168 已经订购,无需重复订购(包月)
21169 黑名单用户
21170 虚拟货币单位格式不正确
21171 虚拟货币数量格式不正确
21172 虚拟货币单位非法
21173 虚拟货币数量非法
21174 货币格式非法
21175 发货地址在mis上没有配置
21176 SDK同步_验签失败
21177 SDK同步_订单缓存不存在
21178 SDK同步_签名信息格式不正确
21179 官网_订单号格式不正确
21180 官网_订单缓存不存在
21181 官网_充值卡号格式不正确
21182 官网_充值卡类型格式不正确
21183 官网_充值卡密码格式不正确
21184 官网_银行类型格式不正确
21185 官网_计费点ID格式不正确
21185 礼包码不得为空
21186 发货失败
21187 礼包码不存在或不可用
21188 礼包码已过期
21189 礼包码未领取
21190 礼包码已使用
21191 该用户已兑换过礼包码
21192 该设备已兑换过礼包码
21193 礼包活动暂停中
21194 礼包码已经用完
21195 网络异常
21196 服务内部错误
21197 传入的礼包码有错误
21198 传入的礼包ID有错误
21199 用户未登录
21200 兑换超过用户最大限制
21201 游戏产品有误
21202 策略关系不存在
21203 联运渠道或推广渠道有误
21204 推广渠道有误
21205 机型组有误
21206 语言有误
21207 逻辑服策略不存在
21208 逻辑服有误
21209 已配置回调地址,sdk同步数据不予处理
21210 官网充值支付类型格式不正确
21211 官网充值支付校验类型格式不正确
21212 官网充值支付校验码格式不正确
21213 官网充值支付角色不存在
21214 官网_用户ID格式不正确
21215 官网_查询起始时间格式不正确
21216 官网_查询起结束时间式不正确
21217 官网_分页信息格式不正确
21218 官网_分页信息每页数量信息格式不正确
21219 官网_分页信息当前页参数格式不正确
21220 官网_分页信息当前日期范围不正确
21221 手机同步订单号和计费点ID不能同时为空
21222 游戏奖励活动不存在
21223 游戏奖励活动状态未开启
21224 不在游戏活动有效期
21225 用户已领取活动奖励
21226 未查询到玩家活动充值记录
21227 用户天兑换次数超出上限
21228 用户周兑换次数超出上限
21229 用户月兑换次数超出上限
23153 官网_第三方订单号不能为空
23152 官网_实际支付金额不能为空
23154 签名不能为空
23155 该笔订单已发货
23156 离线计费缓存为空
23157 礼包码未到生效时间
22000 app_product_id格式不正确

12.4 货币类型及对应ID

货币ID 货币名称 货币单位
1 人民币
2 美元 美分
3 日元
4 港币
5 英镑 便士
6 新加坡币
7 越南盾
8 台币
9 韩元
10 泰铢 萨当

12.5 启动屏配置说明

苹果2020年4月30日后提交的APP不再支持使用LaunchImage,启动图需要使用StoryBoard来搭建;
该文档对启动图StoryBoard做个简单使用说明
http://sdk.longtubas.com/t3/241/4774/1500008855.html

12.6 iOS配置多套图标说明

2021年12月08号,苹果推出 App Store 产品页的新功能,在 App Store 中开发者可以针对 app 产品页的不同版本上使用不同的图标、截屏和 app 预览,通过 A/B Test 找出效果最佳的版本
http://sdk.longtubas.com/t3/241/4774/1500010244.html

Apple 正在大力推动 APP 开发者在深层链接上有更好的体验。所有的消息都围绕着深层链接技术。与此同时, Apple 推出通用链接:一种能够方便的通过传统 HTTP 链接来启动 APP, 使用相同的网址打开网站和 APP
http://sdk.longtubas.com/t3/241/4774/1500010117.html