diff options
author | crupest <crupest@outlook.com> | 2018-09-27 22:53:54 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2018-09-27 22:53:54 +0800 |
commit | eab8d69ccac6f7b306561a49e9c1f8fda21376d2 (patch) | |
tree | 914b66de1428ddfa55a190495e7e24cbb5f8b8c2 | |
parent | 692af0a1b202f128b6871ba790c0610f036e2944 (diff) | |
download | cru-eab8d69ccac6f7b306561a49e9c1f8fda21376d2.tar.gz cru-eab8d69ccac6f7b306561a49e9c1f8fda21376d2.tar.bz2 cru-eab8d69ccac6f7b306561a49e9c1f8fda21376d2.zip |
Create Border. Make text control relayout when text changed.
-rw-r--r-- | CruUI.vcxproj | 2 | ||||
-rw-r--r-- | CruUI.vcxproj.filters | 6 | ||||
-rw-r--r-- | src/main.cpp | 12 | ||||
-rw-r--r-- | src/ui/controls/border.cpp | 58 | ||||
-rw-r--r-- | src/ui/controls/border.h | 85 | ||||
-rw-r--r-- | src/ui/controls/text_control.cpp | 2 |
6 files changed, 162 insertions, 3 deletions
diff --git a/CruUI.vcxproj b/CruUI.vcxproj index 4c10ad6a..5149d358 100644 --- a/CruUI.vcxproj +++ b/CruUI.vcxproj @@ -121,11 +121,13 @@ <ClCompile Include="src\timer.cpp" /> <ClCompile Include="src\ui\animations\animation.cpp" /> <ClCompile Include="src\ui\control.cpp" /> + <ClCompile Include="src\ui\controls\border.cpp" /> <ClCompile Include="src\ui\controls\button.cpp" /> <ClCompile Include="src\ui\controls\linear_layout.cpp" /> <ClCompile Include="src\ui\controls\margin_container.cpp" /> <ClCompile Include="src\ui\controls\text_block.cpp" /> <ClCompile Include="src\ui\controls\text_box.cpp" /> + <ClInclude Include="src\ui\controls\border.h" /> <ClInclude Include="src\ui\controls\text_control.h" /> <ClCompile Include="src\ui\controls\toggle_button.cpp" /> <ClCompile Include="src\ui\events\ui_event.cpp" /> diff --git a/CruUI.vcxproj.filters b/CruUI.vcxproj.filters index 4d94b6e5..58d9f369 100644 --- a/CruUI.vcxproj.filters +++ b/CruUI.vcxproj.filters @@ -69,6 +69,9 @@ <ClCompile Include="src\ui\events\ui_event.cpp"> <Filter>Source Files</Filter> </ClCompile> + <ClCompile Include="src\ui\controls\border.cpp"> + <Filter>Source Files</Filter> + </ClCompile> </ItemGroup> <ItemGroup> <ClInclude Include="src\application.h"> @@ -137,6 +140,9 @@ <ClInclude Include="src\ui\controls\text_control.h"> <Filter>Header Files</Filter> </ClInclude> + <ClInclude Include="src\ui\controls\border.h"> + <Filter>Header Files</Filter> + </ClInclude> </ItemGroup> <ItemGroup> <ClCompile Include="src\application.cpp"> diff --git a/src/main.cpp b/src/main.cpp index 67b35406..4f711208 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -1,13 +1,13 @@ #include "application.h" #include "ui/window.h" +#include "ui/events/ui_event.h" #include "ui/controls/linear_layout.h" #include "ui/controls/text_block.h" #include "ui/controls/toggle_button.h" #include "ui/controls/button.h" #include "ui/controls/margin_container.h" -#include "ui/events/ui_event.h" #include "ui/controls/text_box.h" - +#include "ui/controls/border.h" using cru::String; using cru::Application; @@ -22,6 +22,7 @@ using cru::ui::controls::ToggleButton; using cru::ui::controls::Button; using cru::ui::controls::MarginContainer; using cru::ui::controls::TextBox; +using cru::ui::controls::Border; int APIENTRY wWinMain( HINSTANCE hInstance, @@ -142,7 +143,12 @@ int APIENTRY wWinMain( window.AddChild(layout); */ - window.AddChild(CreateWithLayout<TextBox>(LayoutSideParams::Stretch(), LayoutSideParams::Stretch())); + window.AddChild( + CreateWithLayout<Border>(LayoutSideParams::Exactly(200), LayoutSideParams::Content(), + std::initializer_list<cru::ui::Control*>{ + CreateWithLayout<TextBox>(LayoutSideParams::Stretch(), LayoutSideParams::Content()) + } + )); window.Show(); diff --git a/src/ui/controls/border.cpp b/src/ui/controls/border.cpp new file mode 100644 index 00000000..f79d610f --- /dev/null +++ b/src/ui/controls/border.cpp @@ -0,0 +1,58 @@ +#include "border.h" + +#include "graph/graph.h" + +namespace cru::ui::controls +{ + using graph::CreateSolidBrush; + + Border::Border() : Control(true) + { + border_brush_ = CreateSolidBrush(D2D1::ColorF(D2D1::ColorF::Black)); + } + + void Border::SetDrawBorder(bool draw_border) + { + draw_border_ = draw_border; + Repaint(); + } + + void Border::SetBorderBrush(Microsoft::WRL::ComPtr<ID2D1Brush> border_brush) + { + border_brush_ = std::move(border_brush); + Repaint(); + } + + void Border::SetBorderWidth(const float border_width) + { + border_width_ = border_width; + Repaint(); + } + + void Border::SetBorderStrokeStyle(Microsoft::WRL::ComPtr<ID2D1StrokeStyle> stroke_style) + { + border_stroke_style_ = std::move(stroke_style); + Repaint(); + } + + void Border::SetBorderRadiusX(const float border_radius_x) + { + border_radius_x_ = border_radius_x; + Repaint(); + } + + void Border::SetBorderRadiusY(const float border_radius_y) + { + border_radius_y_ = border_radius_y; + Repaint(); + } + + void Border::OnDraw(ID2D1DeviceContext* device_context) + { + if (draw_border_) + { + const auto size = GetSize(); + device_context->DrawRoundedRectangle(D2D1::RoundedRect(D2D1::RectF(0.0f, 0.0f, size.width, size.height), border_radius_x_, border_radius_y_), border_brush_.Get(), border_width_, border_stroke_style_.Get()); + } + } +} diff --git a/src/ui/controls/border.h b/src/ui/controls/border.h new file mode 100644 index 00000000..74e12c92 --- /dev/null +++ b/src/ui/controls/border.h @@ -0,0 +1,85 @@ +#pragma once + +#include <initializer_list> + +#include "ui/control.h" + +namespace cru::ui::controls +{ + class Border : public Control + { + public: + static Border* Create(const std::initializer_list<Control*>& children = std::initializer_list<Control*>()) + { + const auto border = new Border(); + for (const auto control : children) + border->AddChild(control); + return border; + } + + protected: + Border(); + + public: + Border(const Border& other) = delete; + Border(Border&& other) = delete; + Border& operator=(const Border& other) = delete; + Border& operator=(Border&& other) = delete; + ~Border() override = default; + + bool IsDrawBorder() const + { + return draw_border_; + } + + void SetDrawBorder(bool draw_border); + + Microsoft::WRL::ComPtr<ID2D1Brush> GetBorderBrush() const + { + return border_brush_; + } + + void SetBorderBrush(Microsoft::WRL::ComPtr<ID2D1Brush> border_brush); + + float GetBorderWidth() const + { + return border_width_; + } + + void SetBorderWidth(float border_width); + + Microsoft::WRL::ComPtr<ID2D1StrokeStyle> GetBorderStrokeStyle() const + { + return border_stroke_style_; + } + + void SetBorderStrokeStyle(Microsoft::WRL::ComPtr<ID2D1StrokeStyle> stroke_style); + + float GetBorderRadiusX() const + { + return border_radius_x_; + } + + void SetBorderRadiusX(float border_radius_x); + + float GetBorderRadiusY() const + { + return border_radius_y_; + } + + void SetBorderRadiusY(float border_radius_y); + + protected: + void OnDraw(ID2D1DeviceContext* device_context) override; + + private: + bool draw_border_ = true; + + Microsoft::WRL::ComPtr<ID2D1Brush> border_brush_; + float border_width_ = 1.0f; + Microsoft::WRL::ComPtr<ID2D1StrokeStyle> border_stroke_style_ = nullptr; + + float border_radius_x_ = 0.0f; + float border_radius_y_ = 0.0f; + }; +} diff --git a/src/ui/controls/text_control.cpp b/src/ui/controls/text_control.cpp index 845b090a..692c4451 100644 --- a/src/ui/controls/text_control.cpp +++ b/src/ui/controls/text_control.cpp @@ -267,6 +267,8 @@ namespace cru::ui::controls void TextControl::OnTextChangedCore(const String& old_text, const String& new_text) { RecreateTextLayout(); + if (const auto window = GetWindow()) + window->Relayout(); Repaint(); } |