你的位置:首页 > 操作系统

[操作系统]GacUI学习(一)

GacUI学习(一)之高仿系统记事本(一)

转载请注明来源:http://www.cnblogs.com/lyfh/p/6107215.html 

       GacUI是轮子哥(vczh)精心打造的跨平台C++转用UI库,包含了轮子哥毕生的C++功力。针对GacUI,轮子哥写过中文教程和Demo,教程地址https://segmentfault.com/a/1190000004055577,Demo在其博客,可自行前去阅读。

       本程序正是根据其中的《GacUI Demo:文本框基本应用》扩展而来,兼容其后的文本框高亮系列。话不多说,先上图(本图为记事本主界面,并带上了文本框高这功能,高亮模式由状态条上的高亮模式确定):

       GacUI包含丰富的排版本功能,具体参见轮子哥的博客《GacUI基本概念(二)——排版(1)》和《GacUI基本概念(二)——排版(2)》。本程序采用了最外层一个三行一列的GuiTableComposition进行布局,然后内部每行一个GuiCellComposition。再在GuiCellComposition内进行控件布置。 具体步骤如下:

       首先新建一个继承自vl::presentation::controls::GuiWindow的类TextBoxEditorWindow,作为基础窗口,所有的排版布局及控件操作都将在此窗口上进行。TextBoxEditorWindow构造函数如下:

1 TextBoxEditorWindow::TextBoxEditorWindow() : GuiWindow(GetCurrentTheme()->CreateWindowStyle())                      2 {3   this->SetText(TEXT("GacTextBox"));4   this->GetContainerComposition()->SetMinSizeLimitation(GuiGraphicsComposition::LimitToElementAndChildren);5   this->SetClientSize(Size(888, 679));6 }

 

      然后再在此构造函数内新建一个table,来进行布局

 1 /* 2     布局采用3行1列形式 3     行1:菜单栏,显示各项菜单 4     行2:编辑栏,显示文本 5     行3:状态栏,显示行号等状态信息 6   */ 7   GuiTableComposition* table = new GuiTableComposition; 8   table->SetAlignmentToParent(Margin(0, 0, 0, 0)); 9   table->SetCellPadding(2);10   table->SetRowsAndColumns(3, 1);11   table->SetRowOption(0, GuiCellOption::MinSizeOption());12   table->SetRowOption(1, GuiCellOption::PercentageOption(1.0));13   table->SetRowOption(2, GuiCellOption::MinSizeOption());14   table->SetColumnOption(0, GuiCellOption::PercentageOption(1.0));15   this->GetContainerComposition()->AddChild(table);

 

       这几行代码设置了table的一系列属性,具体意义可以参见GacUI的文档http://gaclib.net/Document.html#~/。重点是最后一行,将此table添加到TextBoxEditorWindow。剩下的就是在table的每一格中创建相应的控件。