/DoDoUI

DoDoUI

Primary LanguageC++Apache License 2.0Apache-2.0

DoDoUI

DoDoUI

一个精简版的Slate,仿照Unreal的Slate制作,学习Slate的UI框架和UI渲染流程使用。

ToDo

🌏

渲染流程

  • Vulkan后端渲染UI生成的顶点数据
  • 纹理资源管理器
  • 多窗口多交换链渲染

控件

  • 单一子槽SCompoundWidget
  • 叶子控件SLeafWidget
  • 逻辑窗口SWindow
  • 背景板SBorder
  • 按钮SButton
  • ...

布局

  • 锚点
  • 画板控件SConstriantCanvas
  • 分割线SSplitter
  • 水平盒子SBoxPanel
  • ...

输入

  • 2D点和矩形碰撞检测
  • widget树遍历
  • 冒泡事件派发
  • 委托绑定
  • ...

样式

  • 样式按需加载,根据纹理资源注册表
  • 圆角矩形
  • ...

优化

  • globa invalidation
  • widget cache
  • ...

展示

水平盒子

声明式语法构建水平盒子

		SAssignNew(root_window2, SWindow)
			.Title("hello2")
			.ClientSize(glm::vec2(1280.0f, 720.0f))
			.ScreenPosition(glm::vec2(1000.0f, 200.0f))
		    [
		        SNew(SBorder)
		        .BorderBackgroundColor(glm::vec4(0.7f, 0.3f, 0.2f, 1.0f))
				[
		            SNew(SHorizontalBox)
		            + SHorizontalBox::Slot()
		            .Padding(30.0f, 30.0f)
		            .fill_width(0.2f)
					.max_width(600.0f)
		            [
		                SNew(SBorder)
		                .BorderImage(FCoreStyle::get().get_brush("Checkboard"))
		            ]
					+ SHorizontalBox::Slot()
		            .Padding(40.0f, 40.0f)
		            .fill_width(0.8f)
		            .max_width(600.0f)
		            [
		                SNew(SBorder)
		                .BorderBackgroundColor(glm::vec4(0.95f, 0.3f, 0.6f, 1.0f))
		            ]
		            + SHorizontalBox::Slot()
		            .Padding(40.0f, 40.0f)
		            .fill_width(0.3f)
		            .max_width(600.0f)
		            [
		                SNew(SBorder)
		                .BorderBackgroundColor(glm::vec4(0.2f, 0.5f, 0.4f, 1.0f))
		            ]
		            + SHorizontalBox::Slot()
		            .Padding(40.0f, 40.0f)
		            .fill_width(0.3f)
		            .max_width(600.0f)
		            [
		                SNew(SBorder)
		                .BorderBackgroundColor(glm::vec4(0.43f, 0.2f, 0.8f, 1.0f))
		            ]
		            + SHorizontalBox::Slot()
		            .Padding(40.0f, 40.0f)
		            .fill_width(0.4f)
		            .max_width(600.0f)
		            [
		                SNew(SBorder)
		                .BorderImage(FCoreStyle::get().get_brush("Checkboard"))
		            ]
				]
		
		    ];

Build

git submodule update --init --recursive
mkdir build
cd build
cmake .. -DCMAKE_BUILD_TYPE=Debug 
    
or cmake .. -DCMAKE_BUILD_TYPE=Debug -DCMAKE_GENERATOR_TOOLSET=ClangCL

Test

mkdir BuildTest
cd BuildTest
ctest --build-and-test .. . --build-generator "Visual Studio 17 2022" --build-options -DENABLE_TEST=1 --test-command ctest -C Debug