此文档主要是用于在游戏及应用开发商需要接入龙图SDK各渠道特殊功能时的补充文档。
此文档内功能仅接入过程是不能够测试的,需要通过龙图自动打包工具,打包以后才可以调试。
**请各位根据接入的地区查看需要的接口使用。
接入龙图BaseSDK的游戏及应用的android客户端开发者。
因为此文档内接口回调接口为一个,根据接口内ID区分,所以建议在初始化就注册回调,回调接口使用在每个接口内有具体说明。
LTBaseSDK.getInstance(this).LTBaseSDKSetExtendListener(mLTBaseExtendListener);
接入龙图BaseSDK的游戏及应用的android客户端开发者。
调用抖音功能,需要先获取功能实列。
LTBase_DouYin_Charging mLTBase_DouYin_Charging = (LTBase_DouYin_Charging)
LTBaseSDK.getInstance(LTBase_Demo_MainActivity.mMainActivity).LTBaseSDKGetChannelsObject();
游戏调用此接口后,可以展示抖音激励视频。
参数 | 参数说明 | 参数类型 | 是否必选 |
---|---|---|---|
广告ID | 抖音分配的广告ID | String | 必选 |
广告展示方式 | 固定值: “1” 竖屏 “2” 横屏 | int | 必选 |
奖励道具的名称 | 用户看完广告奖励的道具的名称 | String | 必选 |
奖励道具的数量 | 用户看完广告奖励的道具的数量 | int | 必选 |
回调 | 视频播放结果回调 | LTBase_DouYin_showDyAdListener | 必选 |
/**
* 加载抖音激励广告
*
* @param codeId 广告ID
* @param orientation 广告展示方向 LGBaseConfigAdDTO.ORIENTATION_HORIZONTAL 横屏
* LGBaseConfigAdDTO.ORIENTATION_VERTICAL 竖屏
* @param rewardName 奖励道具的名称
* @param rewardAmount 奖励道具的数量
* @param listener 回调
*/
public void LT_DouYin_loadDyAd(String codeId, int orientation, String rewardName, int rewardAmount, LTBase_DouYin_showDyAdListener listener);
/**
* 展示抖音激励视频
*/
mLTBase_DouYin_Charging.LT_DouYin_loadDyAd("945073805", LGBaseConfigAdDTO.ORIENTATION_VERTICAL,
"金币", 100, mLTBase_DouYin_showDyAdListener);
接收到的数据为激励视频 播放结果。
接口 | 接口说明 |
---|---|
onShowDyAdFail | 视频激励失败 |
onShowDyAdSuc | 视频激励成功 |
onShowDyAdError | 视频激励错误 |
onShowDyAdSkip | 视频激励跳过 |
/**
* 激励视频结果回调
*/
private LTBase_DouYin_showDyAdListener mLTBase_DouYin_showDyAdListener = new LTBase_DouYin_showDyAdListener() {
@Override
public void onShowDyAdFail() {
Logs.i(LOGTAG, " 视频激励失败 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 视频激励失败 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onShowDyAdSuc() {
Logs.i(LOGTAG, " 视频激励成功 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 视频激励成功 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onShowDyAdError() {
Logs.i(LOGTAG, " 视频激励错误 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 视频激励错误 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onShowDyAdSkip() {
Logs.i(LOGTAG, " 视频激励跳过 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 视频激励跳过 ", Toast.LENGTH_SHORT).show();
}
};
检测当前登录的用户,是否为渠道的游客账号。
可以用于判断是否展示绑定接口。
/**
* 检查当前用户是否为游客,暂时只为抖音开放
* @return true为游客, false 为非游客
*/
public boolean LTBaseCheckUserisgGuest();
LTBaseSDK.getInstance(LTBase_Demo_MainActivity.mMainActivity).LTBaseCheckUserisgGuest();
抖音的游客账号,绑定为抖音正式账号。
/**
* 渠道的绑定账号,用于渠道需要主动触发绑定的情况
*
* @param listener 结果回回调
*/
public void LTBaseChannelBindAccount(LTBaseAccountBindListener listener)
/**
* 绑定账号
*/
LTBaseSDK.getInstance(LTBase_Demo_MainActivity.mMainActivity).LTBaseChannelBindAccount(mLTBaseAccountBindListener);
接收到的数据为激励视频 播放结果。
接口 | 接口说明 |
---|---|
LTBaseBindSuccess | 绑定成功 |
LTBaseBindFail | 绑定失败 |
/**
* 绑定结果
*/
private LTBaseAccountBindListener mLTBaseAccountBindListener = new LTBaseAccountBindListener() {
@Override
public void LTBaseBindSuccess(int i, String s) {
Logs.i(LOGTAG, " 绑定成功 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 绑定成功 ", Toast.LENGTH_SHORT).show();
}
@Override
public void LTBaseBindFail(int i, String s) {
Logs.i(LOGTAG, "绑定失败");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, "绑定失败 ", Toast.LENGTH_SHORT).show();
}
};
检测当前设置是否支持录屏
/**
* 是否允许屏幕录制。
*
* @return true 支持录屏 false 不支持录屏
*/
public boolean LT_DouYin_checkSupScreenRecord()
mLTBase_DouYin_Charging.LT_DouYin_checkSupScreenRecord();
录制当前游戏屏幕
参数值 | 参数说明 |
---|---|
LGScreenRecordOperate.START | 开始 |
LGScreenRecordOperate.PAUSE | 暂停 |
LGScreenRecordOperate.RESUME | 继续 |
LGScreenRecordOperate.STOP | 结束 |
/**
* 录制屏幕:支持开始、暂停、继续、结束
* <p>
* 注意:
* 只有调用结束录制屏幕,才会生成合法的视频文件,中断录屏流程将不会生成合法视频文件
*/
public void LT_DouYin_SupSreenReoocrd(LGScreenRecordOperate operate, LTBase_DouYin_screenRecordListener listener) ;
// 录屏开始 举例
mLTBase_DouYin_Charging.LT_DouYin_SupSreenReoocrd(LGScreenRecordOperate.START,
mLTBase_DouYin_screenRecordListener);
// 录屏结束 举例
mLTBase_DouYin_Charging.LT_DouYin_SupSreenReoocrd(LGScreenRecordOperate.STOP,
mLTBase_DouYin_screenRecordListener);
接收到的数据为激励视频 播放结果。
接口 | 接口说明 | 参数说明 |
---|---|---|
onScreenRecordSuc | 录制成功 | recordFilePath 录制成功后的视频地址 |
onScreenRecordFail | 录制失败 |
/**
* 抖音录屏结果
*/
private LTBase_DouYin_screenRecordListener mLTBase_DouYin_screenRecordListener = new LTBase_DouYin_screenRecordListener() {
@Override
public void onScreenRecordFail() {
Logs.i(LOGTAG, " 录制失败 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 录制失败 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onScreenRecordSuc(String recordFilePath) {
Logs.i(LOGTAG, " 录制成功 recordFilePath = " + recordFilePath);
mRecordFilePath = recordFilePath;
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 录制成功 ", Toast.LENGTH_SHORT).show();
}
};
打开交叉推广, 打开以后是抖音的一个悬浮广告框, 需要在抖音后台配置才有作用
/**
* 交叉推广
* @param x 展示坐标
* @param y 展示坐标
*/
public void LT_DouYin_showOverlapping_Recommend(int x, int y)
// 打开交叉推广
mLTBase_DouYin_Charging.LT_DouYin_showOverlapping_Recommend(0, 0);
关闭交叉推广框
// 关闭交叉推广
public void LT_DouYin_closeOverlapping_Recommend()
// 关闭交叉推广
mLTBase_DouYin_Charging.LT_DouYin_closeOverlapping_Recommend();
由抖音Ai系统对视频进行编辑,
编辑过程不可见,回调会返回编辑进度,游戏需要自行展示编辑中进度条。
参数 | 参数说明 | 参数类型 | 是否必选 |
---|---|---|---|
videoPath | 需要编辑的视频路径 | String | 必选 |
isShare | 是否吧编辑以后的视频进行分享 true 分享 false 不分享 | boolean | 必选 |
回调 | 编辑结果回调 | LTBase_DouYin_aiEditorVideoShareListener | 必选 |
/**
* 视频编辑
*
* @param videoPath 视频路径
* @param isShare 是否分享 true 分享 false 不分享
* @param listener 结果回调
*/
public void LT_Douyin_aiEditorVideoShare(String videoPath, boolean isShare, LTBase_DouYin_aiEditorVideoShareListener listener);
// 视频编辑
mLTBase_DouYin_Charging.LT_Douyin_aiEditorVideoShare(
mRecordFilePath, false,
mLTBase_DouYin_aiEditorVideoShareListener);
接收到的数据为激励视频 播放结果。
接口 | 接口说明 | 参数说明 |
---|---|---|
onScreenRecordSuc | 视频编辑成功 | aiEditedVideoPath 编辑成功后的视频地址 ,stayInDouYin 分享成功是否留在抖音 |
onEditingProgress | 视频编辑进度 | progress 视频编辑进度 |
onAiEditorVideoFail | 视频编辑失败 |
/**
* 抖音视频编辑结果回调
*/
private LTBase_DouYin_aiEditorVideoShareListener mLTBase_DouYin_aiEditorVideoShareListener
= new LTBase_DouYin_aiEditorVideoShareListener() {
@Override
public void onAiEditorVideoFail() {
Logs.i(LOGTAG, " 视频编辑失败 ");
mAiScreenReocrdIng = false;
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 视频编辑失败 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onAiEditorVideoSuc(String aiEditedVideoPath, boolean stayInDouYin) {
Logs.i(LOGTAG, " 视频编辑成功 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 视频编辑成功 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onEditingProgress(int progress) {
Logs.i(LOGTAG, " 视频编辑进度 progress = " + progress);
}
};
检查当前设备是否支持分享
/**
* 是否允许分享
*
* @return true 支持,false 不支持
*/
public boolean LT_DouYin_checkSupDouYinShare()
// 是否允许分享
mLTBase_DouYin_Charging.LT_DouYin_checkSupDouYinShare();
抖音分享:支持视频和图片分享
LGDouYinShareDTO 参数介绍
参数 | 参数说明 | 参数类型 | 是否必选 |
---|---|---|---|
type | 分享类型,LGDouYinShareDTO.Type.VIDEO 视频, LGDouYinShareDTO.Type.PICTURE 图片 | int | 必选 |
pathList | 资源列表,图片支持多张图片,视频只能添加一个 | ArrayList | 必选 |
回调 | 编辑结果回调 | LTBase_DouYin_ShareListener | 必选 |
/**
* 抖音分享接口
*
* @param douYinShareDTO 分享参数
* @param listener 分享回调
*/
public void LT_DouYin_SupDouYinShare(LGDouYinShareDTO douYinShareDTO, LTBase_DouYin_ShareListener listener);
// 抖音分享。
LGDouYinShareDTO mLGDouYinShareDTO = new LGDouYinShareDTO();
mLGDouYinShareDTO.type = LGDouYinShareDTO.Type.VIDEO;
mLGDouYinShareDTO.pathList.add(mRecordFilePath);
mLTBase_DouYin_Charging.LT_DouYin_SupDouYinShare(mLGDouYinShareDTO, mLTBase_DouYin_ShareListener);
接收到的数据为激励视频 播放结果。
接口 | 接口说明 | 参数说明 |
---|---|---|
onShareSuc | 分享成功 | stayInDouYin 分享成功是否留在抖音 |
onShareSaveAlbum | 分享成功后,视频保存路径 | filePathList 视频或者图片保存路径列表 |
onShareFail | 分享失败 |
/**
* 抖音分享回调
*/
private LTBase_DouYin_ShareListener mLTBase_DouYin_ShareListener = new LTBase_DouYin_ShareListener() {
@Override
public void onShareFail() {
Logs.i(LOGTAG, " 分享失败 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 分享失败 ", Toast.LENGTH_SHORT).show();
}
@Override
public void onShareSuc(boolean stayInDouYin) {
Logs.i(LOGTAG, " 分享成功 stayInDouYin = " + stayInDouYin);
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 分享成功", Toast.LENGTH_SHORT).show();
}
@Override
public void onShareSaveAlbum(ArrayList filePathList) {
Logs.i(LOGTAG, " 分享成功后视频保存成功 ");
Toast.makeText(LTBase_Demo_MainActivity.mMainActivity, " 分享成功后视频保存成功 ", Toast.LENGTH_SHORT).show();
}
};
发送抖音日志,自定义日志
参数 | 参数说明 |
---|---|
eventName | 事件名,由运营同学分配 |
jsonObject | 事件参数 ,json格式, 由运营同学分配 |
/**
* 发送自定义事件
*
* @param eventName 点位名称
* @param jsonObject 自定义事件数据,可以为null
*/
public void LT_DouYin_setOnEventV3(String eventName, JSONObject jsonObject)
// 发送一条 自定义事件
JSONObject eventJson = new JSONObject();
try {
eventJson.put("sample1", "sample1");
eventJson.put("sample2", "sample2");
} catch (Exception e) {
e.printStackTrace();
}
mLTBase_DouYin_Charging.LT_DouYin_setOnEventV3("diyevent", eventJson);
上海中清龙图软件有限公司