1.【技术系列】开源之DrawDocker源码略读(一)
【技术系列】开源之DrawDocker源码略读(一)
本文由神州数码云基地团队整理撰写,码解若需转载,码解请注明出处。码解本文将简要解析开源图形化工具“神笔马良”(DrawDocker)的码解设计引擎和设计试图视角功能,以供后续开发者参考。码解分析基于年月日的码解高格源码master分支代码,读者应依据实际情况进行判断。码解
项目包含侧栏、码解画布和右侧格式栏,码解以及上方工具栏。码解侧栏提供搜索图形、码解便笺本、码解自定义Kubeapps组件栏、码解mrcms 源码更多图形按钮等功能。码解其中,码解搜索图形功能通过关键字实现,由Sidebar对象的addSearchPalette方法控制。便笺本功能则用于保存临时图形模板,自定义Kubeapps组件栏则能展示并生成自定义应用组件。libfaac 源码Kubeapps应用组件栏显示所有应用组件模板,通过读取kubeappsPalette.json文件的数据,创建包含图形、应用名、chart名和chart地址等信息的应用组件。
创建新的linkedhashmap源码组件栏需新增添加面板方法,并在初始化时调用。更多图形方法位于MoreShapesDialog中,新建的组件栏需添加至条目中才能在“更多图形”中显示。自定义属性或格式图形模板需在shapes和stencils目录下创建相应文件。
画布部分主要由mxGraph对象实现,提供选中、sendto 源码获得样式等功能。右侧格式栏提供绘图、样式、文本、调整图形和安装参数栏,依据选中状态动态显示。样式栏显示图形属性及其值,若为Kubeapps图形,显示应用名、安装状态等。安装参数栏显示安装或删除按钮等。工具栏包含菜单、撤销、重做、删除、重命名、保存、语言等功能,通过Actions、EditorUi等对象实现。
如需改进安装功能,可在Actions对象中修改或定义新动作,甚至在AppController.java文件中调整。项目已开源在GitHub,有兴趣的开发者可自行探索和优化。