project.json5 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  1. // 项目json结构
  2. {
  3. // 版本号
  4. "version": "1.0.0",
  5. // 应用元数据
  6. "meta": {
  7. // 项目名称
  8. "name": "智能HOME项目",
  9. // 项目版本号
  10. "version": "1.0.0",
  11. // 项目描述
  12. "description": "智能HOME项目",
  13. // 项目类型
  14. "type": "chip", // 'analog_display' | 'chip' | 'board' 1: 模拟显示 2: 芯片 3: 板卡
  15. // 屏幕类型
  16. "screenType": "single", // 'single' | 'double' 1:单屏 2:双屏
  17. // 语言
  18. "language": "zh-cn",
  19. // 资源打包方式
  20. "resourcePackaging": "c_bin", // 'c' | 'c_bin' 1: C源码 2: C源码+BIN
  21. // BIN数量
  22. "binNum": "1", // 1~32
  23. // 芯片配置
  24. "chip": {
  25. // 芯片型号
  26. "model": "ESP32",
  27. // 闪存大小
  28. "flash_size": {
  29. "capacity": "16",
  30. "unit": "M"
  31. },
  32. // 内存大小
  33. "ram_size": {
  34. "capacity": "4",
  35. "unit": "M"
  36. }
  37. },
  38. // 板卡配置
  39. "board": {
  40. // 板卡型号
  41. "model": "ESP32",
  42. },
  43. // 屏幕配置
  44. "screens": [
  45. {
  46. // 屏幕类型
  47. "type": "1", // 1:主屏 2:副屏
  48. // 接口类型
  49. "interface": "RGB",
  50. // 屏幕宽
  51. "width": 1920,
  52. // 屏幕高
  53. "height": 1080,
  54. // 颜色深度
  55. "colorDepth": "16bit",
  56. // 颜色格式
  57. "colorFormat": "BGR",
  58. // 屏幕参数
  59. "params": {
  60. "PCLK": "",
  61. "VBP": "",
  62. "VFP": "",
  63. "HBP": "",
  64. "HFP": "",
  65. "HSYNC": "",
  66. "VSYNC": "",
  67. "HSYNC_WIDTH": "",
  68. "HSYNC_WIDTH": ""
  69. }
  70. }
  71. ],
  72. // 创建时间
  73. "createTime": "2025-09-01 12:00:00",
  74. // 修改时间
  75. "modifyTime": "2025-09-01 12:00:00",
  76. },
  77. // BIN列表
  78. "bins": [
  79. {
  80. "id": "bin_1",
  81. "fileName": "bin1.bin",
  82. "path": "./src/bin/bin1.bin"
  83. },
  84. {
  85. "id": "bin_2",
  86. "fileName": "bin2.bin",
  87. "path": "./src/bin/bin2.bin"
  88. }
  89. ],
  90. // 资源
  91. "resources": {
  92. // 图片资源
  93. "images": [
  94. {
  95. "id": "img_1",
  96. "fileName": "image1.png",
  97. "fielType": "png",
  98. "path": "./src/assets/images/image1.png",
  99. "compressFormat": "rle", // 无压缩、RLE压缩、QOI压缩、JPEG压缩、PNG压缩
  100. "alpha": 255, // 透明度0-255
  101. "bin": "bin_1", // 关联的BIN ID
  102. "colorFormat": "RGB565", // 颜色格式
  103. "colorDepth": "16bit", // 颜色深度
  104. }
  105. ],
  106. // 字体资源
  107. "fonts": [
  108. {
  109. "id": "font_1",
  110. "fileName": "font1.ttf",
  111. "fielType": "ttf",
  112. "path": "./src/assets/fonts/font1.ttf",
  113. "range": ["page", "custom", "range"], // 'all' | 'page' | 'custom' | 'range' 0: 全部 1:界面文本 2:自定义文本 3: 编码范围
  114. // 编码范围
  115. "codeRange": ["0x4E00-0x9FA5"],
  116. // 额外的文本内容
  117. "extText": "abcdefghijklmnopqrstuvwxyz",
  118. "bin": "bin_1" // 关联的BIN ID
  119. }
  120. ],
  121. "others": [
  122. // 动画资源
  123. {
  124. "id": "o_1",
  125. "fileName": "other.an",
  126. "fileType": "an",
  127. "path": "./src/assets/others/other.an"
  128. },
  129. // 样式资源
  130. {
  131. "id": "o_2",
  132. "fileName": "a.style",
  133. "fileType": "style",
  134. "path": "./src/assets/others/a.style"
  135. }
  136. ]
  137. },
  138. // 复用控件
  139. "widgets": [
  140. {
  141. "id": "copy_obj_1",
  142. // 控件类型
  143. "widgetType": "lv_object",
  144. // 属性 根据每个控件生成
  145. "props": {
  146. // 坐标x
  147. "x": 0,
  148. // 坐标y
  149. "y": 0,
  150. // 宽度
  151. "width": 100,
  152. // 高度
  153. "height": 100,
  154. // 布局方式 flex grid
  155. "layout": "flex",
  156. // 启用
  157. "enable": true,
  158. // 可见
  159. "visible": true,
  160. // 值
  161. "value": {
  162. "valueType": "VARIABLE",
  163. "value": "page_1_a"
  164. },
  165. },
  166. // 样式 根据每个控件生成
  167. "style": {
  168. // 样式
  169. "style": "default",
  170. "state": {
  171. // 默认状态
  172. "normal": {
  173. // 直接使用颜色值
  174. "bg_color": "#000000",
  175. "border": "all", // all left right top bottom
  176. // 绑定变量或主题色
  177. "border_color": {
  178. // valueType的值: TEXT: 文本,VARIABLE: 变量,LANGUAGE: 多语言, COLOR: 主题颜色,不同的控件可以配置不同类型的属性
  179. "valueType": "TEXT",
  180. "value": "#ffffff"
  181. },
  182. "border_width": 1,
  183. "round_radius": 4
  184. },
  185. // 禁用状态
  186. "disabled": {
  187. "bg_color": "#000000",
  188. "border": "all",
  189. }
  190. }
  191. },
  192. // 事件
  193. "events": [
  194. {
  195. "id": "event_1",
  196. // 事件名称
  197. "name": "lv_obj_click_event",
  198. // 触发事件
  199. "trigger": "click",
  200. // 动作类型
  201. "type": "function", // 'play_animation' | 'function' -> play_animation: 播放动画 function: 执行函数
  202. // 动画ID
  203. animation: "",
  204. // 动画播放前函数ID
  205. animationPlayerBeforeEvent: "",
  206. // 动画播放后函数ID
  207. animationPlayerAfterEvent: "",
  208. // 函数ID
  209. function: "method_1"
  210. },
  211. // 加载完毕播放动画
  212. {
  213. "id": "event_1",
  214. // 事件名称
  215. "name": "lv_obj_click_event",
  216. // 触发事件
  217. "trigger": "click",
  218. // 动作类型
  219. "type": "play_animation", // 'play_animation' | 'function' -> play_animation: 播放动画 function: 执行函数
  220. // 动画ID
  221. animation: "animation_1",
  222. // 动画播放前函数ID
  223. animationPlayerBeforeEvent: "method_animation_1",
  224. // 动画播放后函数ID
  225. animationPlayerAfterEvent: "method_animation_2",
  226. // 函数ID
  227. function: ""
  228. }
  229. ],
  230. // 子对象
  231. "children": [
  232. {
  233. "id": "label_1",
  234. "name": "lv_label",
  235. "parentId": "lv_obj_01",
  236. "type": "object",
  237. "hidden": false,
  238. "locked": false,
  239. "props": [
  240. {
  241. "id": "prop_1",
  242. "name": "text",
  243. "type": "string",
  244. "text": {
  245. "valueType": "LANGUAGE",
  246. "value": "hello"
  247. }
  248. }
  249. ]
  250. }
  251. ]
  252. },
  253. ],
  254. // 全局变量定义
  255. "variables": [
  256. {
  257. // 组ID
  258. "id": "group_1",
  259. // 组名称
  260. "name": "全局变量",
  261. // 变量
  262. "variables": [
  263. {
  264. "id": "var_1",
  265. "name": "a",
  266. "value": "1",
  267. "type": "int"
  268. }
  269. ]
  270. }
  271. ],
  272. // 主题
  273. "themes": [
  274. {
  275. "id": "theme_0",
  276. // 主题名称
  277. "name": "默认主题",
  278. // 默认主题
  279. "default": true,
  280. // 颜色集
  281. "colors": [
  282. {
  283. "id": "color_1",
  284. // 颜色名称
  285. "name": "背景颜色",
  286. // 颜色值
  287. "value": "#000000",
  288. // 透明度
  289. "alpha": 255
  290. }
  291. ]
  292. },
  293. {
  294. "id": "theme_1",
  295. // 主题名称
  296. "name": "高亮主题",
  297. // 默认主题
  298. "default": false,
  299. // 颜色集 这里的颜色只能从默认主题获取,可以修改值
  300. "colors": [
  301. {
  302. "id": "color_1",
  303. // 颜色名称
  304. "name": "背景颜色",
  305. // 颜色值
  306. "value": "#ffffff",
  307. // 透明度
  308. "alpha": 255
  309. }
  310. ]
  311. }
  312. ],
  313. // 动画
  314. "animations": [
  315. {
  316. // 动画名称
  317. "name": "move_x_animation",
  318. // 时间轴
  319. "timeline": [
  320. {
  321. // 目标属性
  322. "target": "x",
  323. // 开始值
  324. "start": 0,
  325. // 结束值
  326. "end": 100,
  327. // 延迟时间
  328. "delay": 0,
  329. // 动画时间
  330. "duration": 500,
  331. // 动画效果
  332. "timingFunction": "ease",
  333. // 动画次数
  334. "iterationCount": "infinite" // 数值或infinite
  335. }
  336. ]
  337. }
  338. ],
  339. // 多语言
  340. "languages": [
  341. {
  342. "id": "language_1",
  343. // 语言表示
  344. "key": "hello",
  345. // 语言内容
  346. "values": [
  347. {
  348. "language": "zh-cn",
  349. "value": "你好",
  350. "font": "font_1"
  351. },
  352. {
  353. "language": "en",
  354. "value": "hello"
  355. },
  356. {
  357. "language": "ja",
  358. "value": "こんにちは"
  359. },
  360. {
  361. "language": "ko",
  362. "value": "안녕하세요"
  363. },
  364. {
  365. "language": "fr",
  366. "value": "bonjour"
  367. }
  368. ]
  369. }
  370. ],
  371. // 方法
  372. "methods": [
  373. {
  374. "id": "method_1",
  375. "name": "lv_obj_click",
  376. "action": "static lv_obj_click(void* ctx) { // TODO: 添加事件处理逻辑 }"
  377. }
  378. ],
  379. // 屏幕
  380. "screens": [
  381. {
  382. "id": "screen_1",
  383. "name": "主屏",
  384. // 类型
  385. "type": "screen",
  386. // 屏幕宽 未设置取通用配置
  387. "width": 1920,
  388. // 屏幕高 未设置取通用配置
  389. "height": 1080,
  390. // 隐藏
  391. "hidden": false,
  392. // 锁定
  393. "locked": false,
  394. // 页面
  395. "pages": [
  396. {
  397. "id": "page_1",
  398. // 页面名称
  399. "name": "启动页",
  400. // 类型
  401. "type": "page",
  402. // 隐藏
  403. "hidden": false,
  404. // 锁定
  405. "locked": false,
  406. // 参考线
  407. "referenceLine": [
  408. {
  409. "id": "r_1",
  410. // 垂直 水平
  411. "layout": "horizontal",
  412. // 位置
  413. "position": 0,
  414. // 显示
  415. "visible": true
  416. }
  417. ],
  418. // 属性
  419. "props": {},
  420. // 样式
  421. "style": {},
  422. // 事件
  423. "events": [],
  424. // 页面变量
  425. "variables": [
  426. {
  427. "id": "page_1_var_1",
  428. "name": "page_1_a",
  429. "value": "1",
  430. "type": "int"
  431. }
  432. ],
  433. // 子组件
  434. "children": [
  435. {
  436. "id": "lv_obj_01",
  437. // 复用控件ID
  438. "widgetId": "obj_1",
  439. // 控件名称
  440. "name": "容器",
  441. // 类型
  442. "type": "widget",
  443. // 隐藏
  444. "hidden": false,
  445. // 锁定
  446. "locked": false,
  447. // 属性 根据每个控件生成
  448. "props": {
  449. // 坐标x
  450. "x": 100,
  451. // 坐标y
  452. "y": 100
  453. }
  454. }
  455. ]
  456. }
  457. ]
  458. }
  459. ]
  460. }