代码拉取完成,页面将自动刷新
Usage: ./scripts/update_res.py action[clean|all|font|image|ui|style|string]
Example:
./scripts/update_res.py all
./scripts/update_res.py clean
./scripts/update_res.py style
参数action是必须的,其取值如下:
如果需要修改资源生成工具的设置,修改 project.json 即可,设置参数的详细信息如下:
{
......
"assets": {
"activedTheme": "default", // APP运行时的默认主题
"outputDir": "res", // 资源生成的输出目录
"loadFrom": "any",
"const": "resource_data", // 资源的常量格式,有2个选项:
// “resource_data”表示原始数据,“bitmap_data”表示位图数据
"screenDPR": "x1", // LCD的设备像素比(DPR),有3个选项:x1,x2,x3
"defaultLanguage": "zh",
"defaultCountry": "CN",
"themes": { // 项目的所有主题
"default": { // default主题
"activedSystemBar": "system_bar",
"activedBottomSystemBar": "system_bar_b",
"packaged": true, // 是否生成资源
"fonts": { // 主题包含的字体
"default": { // default字体
"text": " !\"#$%&'()*+,-./0123456789:", // “text”为TTF字体的保留字符,
"18": " !\"#$%&'()*+,-./0123456789确定取消" // “18”为Bitmap字体18字号的保留字符
}
},
"lcd": {
"width": "800",
"height": "480",
"colorDepth": "16bit", // LCD的颜色深度
"colorFormat": "BGR(A)" // LCD的颜色尺寸
}
}
}
},
......
}
关于 project.json 的更多说明,请参考 AWTK项目描述文件 也可以通过打开 Designer,进入 “项目设置” 页面进行设置。
update_res.py 在生成资源的前后会分别触发一个before事件和一个after事件。如果需要在资源生成前后做一些额外的处理,则在相应的事件回调中添加代码即可。
具体步骤如下:
#!/usr/bin/python
# ctx参数是一个dict类型,有如下属性:
# ctx['type']: 当前正在生成的资源类型,有all、string、font、script、image、ui、style、data、xml
# ctx['theme']: 当前正在生成的主题
# ctx['imagegen_options']: 当前的图片生成选项,有mono、bgr565、bgra、rgb565、rgba
# ctx['input']: 当前主题原始资源的存放路径,比如'e:/AWTK Application/design/default'
# ctx['output']: 当前主题生成资源的存放路径,比如'e:/AWTK Application/res/assets/default'
#
# 资源生成事件的流程如下:
# |----->----- 开始生成某个主题的资源
# | |
# | on_generate_res_before('all')
# | |
# | on_generate_res_before('string')
# | |
# | on_generate_res_after('string')
# | |
# ^ on_generate_res_before('font')
# | |
# | on_generate_res_after('font')
# | ......
# | on_generate_res_before('xml')
# | |
# | on_generate_res_after('xml')
# | |
# | on_generate_res_after('all')
# | |
# |-----<----- 继续生成下一个主题
#
def on_generate_res_before(ctx):
print('======================= '+ ctx['type'] + ' =======================')
def on_generate_res_after(ctx):
print('======================= '+ ctx['type'] + ' =======================')
update_res.py 须依赖 awtk 提供的公共模块,默认使用 AWTK Designer 安装目录中的 awtk,如果找不到则会尝试在当前工作目录的上3级目录中查找。
如果查找不到 awtk,则会出现如下错误:
ImportError: No module named update_res_app
此时只需修改 update_res.py 中的 AWTK_ROOT 为正确的 awtk 路径即可。
默认情况下,awtk 编译后生成的 fontgen 工具只能生成用于非单色屏的位图字体。因此,如果需要生成用于单色屏的位图字体,重新生成一个专门的 fontgen。
步骤如下:
......
#LCD='SDL_FB_MONO'
......
改为
......
LCD='SDL_FB_MONO'
......
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。