Asroads'Blog 君子不器
VIVO小游戏首屏加载
发布于: 2023-11-13 更新于: 2025-01-01 分类于: game 阅读次数: 

这里是你博客列表显示的摘要文字最近项目要发布VIVO小游戏,由于游戏是从App转到小游戏的,在微信和抖音的平台表现已经是要做很多优化和品质牺牲,到了VIVO小游戏效果更是不乐观,于是按照官方的优化指导接入了他们的小游戏自定义Loading组件

q9qou4sp

步骤

首先我们先看官方文档的说明:

qg.createCustomizeLoading(Object object)

1、参数

属性 类型 必填 说明
background string 背景图片,可以为网络图片或本地图片
text string 加载进度文本
textColor string 文本的颜色。必须是 16 进制格式的颜色字符串,例如:‘#999999’。
loadingColorTop string loading进度条渐变色顶部颜色。必须是 16 进制格式的颜色字符串,默认无背景色,例如:‘#999999’。
loadingColorBottom string loading进度条渐变色底部颜色。必须是 16 进制格式的颜色字符串,默认无背景色,例如:‘#999999’。
loadingProgress Number 进度条的进度
flow Number 首屏所需资源大小,显示流量消耗提示,单位Mb。若首屏所需资源超过30Mb,则必须提供该值,否则可能审核不通过

返回值

创建CustomizeLoading组件

CustomizeLoading.update(Object object)

更新CustomizeLoading样式,传入参数与createCustomizeLoading一致

CustomizeLoading.getProgress(Object object)

获取CustomizeLoading组件的进度

参数

Object object

属性 类型 必填 说明
success Function 成功回调
fail Function 失败回调
success回调参数:Object data
属性 类型 说明
currentProgress Number 当前loading进度

CustomizeLoading.remove()

销毁CustomizeLoading组件

CustomizeLoading.resetLoading() 1092+

重置CustomizeLoading组件进度

我们可以看出,其实需要开发者 给出一张图片,本地相对路径或者网络远程地址作为显示,可以设置进度条的颜色,然后通过自己调用update 更新进度,当更新完成的时候,或者适当的时机,可以调用 remove函数,移除自定义加载组件。

下面给出我写的一个用例代码脚本名字: vivo-custom-loading.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67

window.boot();
//使用该功能时,需判断引擎是否支持
//创建CustomizeLoading组件
if (qg.createCustomizeLoading) {
console.log("VIVO 添加 createCustomizeLoading");
// 生成随机数和时间戳
const randomNumber = Math.floor(Math.random() * 100000) + 1;
const timestamp = Date.now();
let url = "https://xxxx/xxxx/cover4.jpg";
// let url = "screen/cover5.jpg";
url += '?';
url += 'v=' + randomNumber;
url += '&t=' + timestamp;
console.log("url------", url)
window['VIVOCustomizeLoading'] = qg.createCustomizeLoading({
background: '/cover.jpg',
text: '正在加载中...',
textColor: '#ffffff',
loadingColorTop: '#ffffff',
loadingColorBottom: '#000000',
loadingProgress: 0
});
//获取CustomizeLoading进度
//根据实际场景进行更新进度(只能增加)、背景、文字以及文字颜色
//更新CustomizeLoading样式
window['VIVOCustomizeLoadingCount'] = 1;
window['VIVOCustomizeLoadingRate'] = 1;
const CustomizeLoadingId = setInterval(() => {
if (window['VIVOCustomizeLoading'] === null || window['VIVOCustomizeLoading'] === undefined) {
console.log("已经提前完成任务");
clearInterval(CustomizeLoadingId);
} else {
window['VIVOCustomizeLoadingCount'] += (1*window['VIVOCustomizeLoadingRate']);
window['VIVOCustomizeLoadingCount'] = Math.min(100,window['VIVOCustomizeLoadingCount']);
const progress = Math.floor(window['VIVOCustomizeLoadingCount']);
// console.log("VIVOCustomizeLoadingCount------", window['VIVOCustomizeLoadingRate']);
if( window['VIVOCustomizeLoadingRate']>1){
window['VIVOCustomizeLoadingRate']*=1.25;
}
window['VIVOCustomizeLoading'].update({
background: '/cover.jpg',
text: '正在加载中...',
textColor: '#ffffff',
loadingColorTop: '#ffffff',
loadingColorBottom: '#000000',
loadingProgress: progress
})
window['VIVOCustomizeLoading'].getProgress({
success: (data) => {
console.log(`handling success: ${data.currentProgress}`)
if (data.currentProgress >= 100) {
console.log("VIVO模拟加载完成");
clearInterval(CustomizeLoadingId);
window['VIVOCustomizeLoading'] && window['VIVOCustomizeLoading'].remove();
window['VIVOCustomizeLoading'] = null;
}
},
fail: (data, code) => {
console.log(`handling fail, code = ${code}`)
}
})
}
}, 75)
} else {
console.log("系统不支持")
}

这里值得注意的是 window['VIVOCustomizeLoadingRate'] 这个属性,游戏在正常打开第一个场景后 我会在游戏内调用:

1
2
3
4
5
6
7
8
if(如果是vivo小游戏){
if (window['VIVOCustomizeLoading']) {
console.log("游戏内提前显示要移除自定义loading");
window['VIVOCustomizeLoadingRate'] = 1.25;
// window['VIVOCustomizeLoading'] && window['VIVOCustomizeLoading'].remove();
// window['VIVOCustomizeLoading'] = null;
}
}

拓展

如果 进入游戏 马上调用
2f23406b359b414109555f5c6273da79

游戏会报错 :
image-20231113212221810

原因是:创建之后就进行获取导致的,可以延迟调用即可。

2024-11-01更新加载

vivo-custom-loading.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81

window.boot();
//使用该功能时,需判断引擎是否支持
//创建CustomizeLoading组件
if (qg.createCustomizeLoading) {
console.log("VIVO 添加 createCustomizeLoading");
window['VIVOCustomizeLoadingOK'] = false;
// 生成随机数和时间戳
const randomNumber = Math.floor(Math.random() * 100000) + 1;
const timestamp = Date.now();
// let url = "https://tcs-cdn.galsanggame.com/tcs/miniv2/com/share/config/vivo/screen/cover4.jpg";
// url += '?';
// url += 'v=' + randomNumber;
// url += '&t=' + timestamp;
let url = "image/cover.jpg";

console.log("url------", url)
window['VIVOCustomizeLoading'] = qg.createCustomizeLoading({
background: url,
text: '正在初始化加载数据...',
textColor: '#ffffff',
loadingColorTop: '#ffffff',
loadingColorBottom: '#000000',
loadingProgress: 0
});
//获取CustomizeLoading进度
//根据实际场景进行更新进度(只能增加)、背景、文字以及文字颜色
//更新CustomizeLoading样式
window['VIVOCustomizeLoadingCount'] = 1;
window['VIVOCustomizeLoadingRate'] = 1;
window['VIVOCustomizeLoadingStage'] = 1;
window['VIVOCustomizeLoadingProgress'] = 0;
window['VIVOCustomizeLoadingOK'] = false;

const stages = [
'正在初始化加载数据...',
'游戏主包资源正在加载中...',
'游戏分包正在加载中...'
];
const CustomizeLoadingId = setInterval(() => {
if (window['VIVOCustomizeLoading'] === null || window['VIVOCustomizeLoading'] === undefined) {
console.log("已经提前完成任务");
clearInterval(CustomizeLoadingId);
} else {
window['VIVOCustomizeLoadingCount'] += (1 * window['VIVOCustomizeLoadingRate']);
window['VIVOCustomizeLoadingCount'] = Math.min(100, window['VIVOCustomizeLoadingCount']);
const progress = Math.floor(window['VIVOCustomizeLoadingCount']);
window['VIVOCustomizeLoadingProgress'] = progress;

if (window['VIVOCustomizeLoadingRate'] > 1) {
window['VIVOCustomizeLoadingRate'] *= 1.25;
}

window['VIVOCustomizeLoading'].update({
background: url,
text: stages[window['VIVOCustomizeLoadingStage'] - 1],
textColor: '#ffffff',
loadingColorTop: '#ffffff',
loadingColorBottom: '#000000',
loadingProgress: progress
});

if (progress >= 100) {
// 检查 VIVOCustomizeLoadingOK 状态
if (window['VIVOCustomizeLoadingOK'] || window['VIVOCustomizeLoadingStage'] === 3) {
console.log("VIVO模拟加载完成");
clearInterval(CustomizeLoadingId);
window['VIVOCustomizeLoading'] && window['VIVOCustomizeLoading'].remove();
window['VIVOCustomizeLoading'] = null;
} else {
// 进入下一阶段
window['VIVOCustomizeLoading'].resetLoading();
window['VIVOCustomizeLoadingStage'] += 1;
window['VIVOCustomizeLoadingCount'] = 1; // 重置进度
}
}
}
}, 50);
} else {
console.log("系统不支持")
}

对应的 游戏内逻辑:

1
2
3
4
5
6
if(Browser.onVivoMiniGame){
if (window['VIVOCustomizeLoading']) {
console.log("游戏内提前显示要移除自定义loading");
window['VIVOCustomizeLoadingOK'] = true;
}
}
1
2
3
4
5
6
if(Browser.onVivoMiniGame){
if (window['VIVOCustomizeLoading']) {
console.log("游戏内提前显示要移除自定义loading");
window['VIVOCustomizeLoadingRate'] = 1.25;
}
}

python逻辑:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54

# 使用方法 替换 签名文件 VIVO小游戏
sign_release = os.path.join(release_folder, 'sign', "release")
sign_debug = os.path.join(release_folder, 'sign', "debug")

# 复制文件和配置加载文件到新目录
source_subpackages = os.path.join(release_folder, 'subpackages' , 'main')
destination_src = os.path.join(release_folder, 'src' , 'main' )
vivio_build_dir = os.path.join(release_folder, 'build','main')

destination_src_cfg_json = os.path.join(release_folder, 'src' , 'main' , "index.js")
vivio_build_dir_cfg_json = os.path.join(release_folder, 'build','main' , "index.js")

# 使用方法 替换 首屏自定义加载 VIVO小游戏
js_main_path = os.path.join(release_folder, "main.js") # main.js
js_boot_path = os.path.join(release_folder, 'engine', "src", "boot.js") # boot.js
vivo_custom_loading_path = os.path.join(cmd_folder, "builder","vivo-custom-loading.js") # vivo-custom-loading.js

loading_directory = os.path.join(cmd_folder, "builder",'config','loading')
loading_directory_src = os.path.join(release_folder, "src","image")

if args.c == 'vivo' or args.c == 'oppo' or args.c == 'hw':
# VIVO 签名复制操作
FUtils.recursive_copy(sign_release, sign_debug, 0)
if args.c == 'vivo':
# VIVO 目前自定义加载也废弃掉
FUtils.recursive_copy(source_subpackages, destination_src, 0)
FUtils.recursive_copy(source_subpackages, vivio_build_dir, 0)
FUtils.recursive_copy(loading_directory, loading_directory_src, 0)
if os.path.exists(destination_src_cfg_json):
try:
os.remove(destination_src_cfg_json)
except OSError as e:
# 如果无法删除,可能是因为文件正在被使用,打印错误并继续
print(f"无法删除 {destination_src_cfg_json}, 错误: {e}")

if os.path.exists(vivio_build_dir_cfg_json):
try:
os.remove(vivio_build_dir_cfg_json)
except OSError as e:
# 如果无法删除,可能是因为文件正在被使用,打印错误并继续
print(f"无法删除 {vivio_build_dir_cfg_json}, 错误: {e}")

# FUtils.recursive_copy(loading_directory, loading_directory_src, 0)
# FUtils.recursive_copy(loading_directory, vivio_build_dir, 0)
# 使用示例
js_main_result = FUtils.replace_content_in_file(js_main_path, vivo_custom_loading_path, 'window.boot();',
'console.log("VIVO 添加 createCustomizeLoading");')
# 使用示例
js_boot_result = FUtils.replace_content_in_file(js_boot_path, vivo_custom_loading_path, 'window.boot();',
'console.log("VIVO 添加 createCustomizeLoading");')
print("VIVO渠道构建修改:",js_main_result,js_boot_result)
else:
print("非VIVO渠道 不需要复制操作")

修改内容

  • 进度重置:每当达到 100% 时,进度条会重置为 1,直到第三阶段完成为止。

  • 立即完成加载:在进度达到 100% 时,检查 window['VIVOCustomizeLoadingOK'] 的状态;若为 true,则直接完成加载并清除组件。

  • 阶段推进:只有当 window['VIVOCustomizeLoadingOK']false 时才会推进到下一个阶段,否则立即终止。

--- 本文结束 The End ---