ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 通过控制台输出报文 通过课件编辑软件,菜单中的项目保存,正常保存之后,你可以得到保存信息的相关报文,在报文的**最后一行**可以得到课件目录。 ``` /Users/robin/Library/Application Support/courseware-eeditor/tmp/668f1e76-099e-407a-a7cf-7b20a650e5e2/save .... /Users/robin/Library/Application Support/courseware-eeditor/LookThisDir ``` ## 通过项目目录 课件编辑器中的预览以及保存操作都会保存课件资源,对应的文件为/egret/src/workspace/PageBar.ts. 其中项目保存方法:onProjectSave,项目预览的方法:onPreviewProject,都会调用保存序列化对象的方法:saveSerializedSubjects。 具体方法内容: 1. 清空文件夹 2. 遍历页面列表,进行信息获取 3. 生成xml文档 4. 提示保存成功 ## ipc.projecct的抽象定义 在方法内部有个ipc,具有的属性如下:基本为引入的libs中的模块属性,在project中定义了项目需要的方法。 ![](https://box.kancloud.cn/a671e6eef52a13eeac177e40e85ec679_308x182.png) ## ipc.project , 路径:egret/libs/ipc/project.d.ts 定义内容 ``` declare namespace ipc.project { function saveProjectDialog(cb: Function, thisObj: any): void; function clearTempDir(cb: Function, thisObj: any): void; function saveXml(xmlString: string, jsonString: string, cb: Function, thisObj: any): void; function copyFiles(fileList: Array<ResourceItem>, cb: Function, thisObj: any): void; function upload(projectInfo: any, cb: Function, thisObj: any): void; function download(projectInfo: any, cb: Function, thisObj: any): void; function unzip(projectInfo: any, cb: Function, thisObj: any): void; } ``` ## 判断题的元素从哪里来? 路径:Subject.Template.ABChoice 调用转换方法之前获取的,judgementSubject.ts在调用方法时传入了全量的判断题数据。 中判断题全部相关的内容,其中比较关键的有_serializationElements,序列化的元素,以及subjectname:judgment-1. 在构造器中初始化大量的判断题的模板数据,添加到画布中,并在最后,归纳到_serializationElements中。 ## xml转换之前,拿到的是所有的元素的对象集合 ![](https://box.kancloud.cn/41c50b1f567c9a3b3eeb7827cfdb5c89_398x484.png) 在文件中,/src/subject/template/judgementHelper 的 serializationXML方法,其中是判断题需要的所有的字段信息,内部是对象的各种属性都有的,实际只需要保存下类型和地址信息即可,用getResources方法。解析得到的结果如图: ![](https://box.kancloud.cn/8941af2ca529755fbff010c54eabceae_632x266.png) 因为属性不正确,所以根据正确的key进行重新赋值一遍对所有资源,得到resource的列表 而各个判断题的基本对象的属性,进行一次过滤,其中每个对象都具有自己的属性过滤方法,拿到属性后全量配置到scence中,根据每个对象的值,尤其是资源配置,从资源map中取值。(这个方法中可以看到大量的配置属性都是固定值,而非用户设置值)。 而actions默认是空的,返回空即可。 ## 经过xml转化之后,配置信息变为 ![](https://box.kancloud.cn/eaa5af988d3c7187cccb064453febd33_372x116.png) 也就是xml需要的节点信息的前身, ``` // 初始化需要变量 let attribute = [], resources = [], scenes = [], actions = []; // 拼接json的节点信息 let root = { root: { attribute, resources, scenes, actions } } // 保存文件 利用json2xml模块 const json2xml = $require('json2xml'); const xml = json2xml(root, { attributes_key: '$', header: true }); ```