Unreal接入指引(Linux DS)
本文是介绍Linux DS平台的Unreal SDK详细文档,包含了基本的接入流程,和高级的接口使用介绍。
1 Unreal引擎接入方案
1.1 导入 CrashSight UE Plugin
-
- CrashSight Linux DS SDK目前不开放下载链接,请企业微信联系“CrashSight小助手”获取SDK包。
-
- 将位于同一目录中的 Plugins 文件解压,将 Plugins 文件夹中的CrashSight目录拷贝到UE项目根目录下的Plugins目录(如果没有则创建该文件夹)。点击[文件]刷新 [Visual Studio 项目],然后在 Visual Studio 项目中则可以看到CrashSight plugin 代码以及目录结构,如图所示。
-
- 将CrashSight插件源码和项目源码一起编译,编译完成后则可以在UE编辑器中的编辑插件中看到CrashSight插件,如图所示。
1.2 将CrashSight加入依赖项
在项目主模块的Build.cs中添加:
PrivateDependencyModuleNames.AddRange(new string[] { "CrashSight" });
1.3 执行初始化
- 方法说明 选择第一个场景,或者主场景(scene), 在尽可能较早加载的脚本中调用如下代码进行初始化:
#include "CrashSightAgent.h" //请包含该头文件
#if DEBUG
CrashSightAgent::ConfigDebugMode (true);
#endif
// 设置上报域名,请根据项目发行需求进行填写。(必填)
CrashSightAgent::ConfigCrashServerUrl("UploadUrl");
// 设置上报所指向的APP ID、APP Key和版本号, 并进行初始化。APP ID和APP Key可以在管理端更多->产品设置->产品信息中找到。
CrashSightAgent::Init(CrashSightAppId, CrashSightAppKey, AppVersion);
- 上报域名
国内公有云:pc.crashsight.qq.com
海外公有云:pc.crashsight.wetest.net
2 接口说明
2.1 初始化
static void InitWithAppId(const char* app_id);
说明: 执行初始化工作。 在尽可能早的位置进行初始化以开启崩溃捕获和上报功能。 appid是CrashSight对项目的唯一标识,可以在产品设置->产品信息中查看。
参数 | 类型 | 说明 |
---|---|---|
app_id | const char* | 已注册项目的APP ID |
2.2 上报错误
static void ReportException(int type, const char* name, const char* reason, const char* stack_trace, const char* extras, bool quit, int dump_native_type = 0);
说明: 主动上报错误信息。可以在捕获到错误或者需要上报的时候手动调用,支持多线程调用。 name、reason和stack_trace不能为null。
参数 | 类型 | 说明 |
---|---|---|
type | int | 异常类型, C#: 4, js: 5, lua: 6 |
name | const char * | 异常名称 |
reason | const char * | 异常信息 |
stack_trace | const char * | 堆栈 |
extras | const char * | 其他信息 |
quit | bool | 是否退出 |
dump_native_type | int | 无效,填0即可 |
页面查看:
extras:崩溃详情页->附件下载->extraMessage.txt
2.3 设置用户ID
static void SetUserId(const char* user_id);
说明: 设置用户ID。用户id默认为unknown。
参数 | 类型 | 说明 |
---|---|---|
user_id | const char * | 用户ID |