aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2018-09-27 22:53:54 +0800
committercrupest <crupest@outlook.com>2018-09-27 22:53:54 +0800
commiteab8d69ccac6f7b306561a49e9c1f8fda21376d2 (patch)
tree914b66de1428ddfa55a190495e7e24cbb5f8b8c2
parent692af0a1b202f128b6871ba790c0610f036e2944 (diff)
downloadcru-eab8d69ccac6f7b306561a49e9c1f8fda21376d2.tar.gz
cru-eab8d69ccac6f7b306561a49e9c1f8fda21376d2.tar.bz2
cru-eab8d69ccac6f7b306561a49e9c1f8fda21376d2.zip
Create Border. Make text control relayout when text changed.
-rw-r--r--CruUI.vcxproj2
-rw-r--r--CruUI.vcxproj.filters6
-rw-r--r--src/main.cpp12
-rw-r--r--src/ui/controls/border.cpp58
-rw-r--r--src/ui/controls/border.h85
-rw-r--r--src/ui/controls/text_control.cpp2
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();
}