From 74bb9cd27242b9320f99ff4d2b50c3051576cc14 Mon Sep 17 00:00:00 2001 From: crupest Date: Tue, 8 Feb 2022 16:53:51 +0800 Subject: ... --- include/cru/ui/controls/TextBlock.h | 44 +++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 include/cru/ui/controls/TextBlock.h (limited to 'include/cru/ui/controls/TextBlock.h') diff --git a/include/cru/ui/controls/TextBlock.h b/include/cru/ui/controls/TextBlock.h new file mode 100644 index 00000000..5e5674a2 --- /dev/null +++ b/include/cru/ui/controls/TextBlock.h @@ -0,0 +1,44 @@ +#pragma once +#include "NoChildControl.h" + +#include "TextHostControlService.h" + +namespace cru::ui::controls { +class CRU_UI_API TextBlock : public NoChildControl, public virtual ITextHostControl { + public: + static constexpr StringView control_type = u"TextBlock"; + + static TextBlock* Create(); + static TextBlock* Create(String text, bool selectable = false); + + protected: + TextBlock(); + + public: + TextBlock(const TextBlock& other) = delete; + TextBlock(TextBlock&& other) = delete; + TextBlock& operator=(const TextBlock& other) = delete; + TextBlock& operator=(TextBlock&& other) = delete; + ~TextBlock() override; + + String GetControlType() const final { return control_type.ToString(); } + + render::RenderObject* GetRenderObject() const override; + + String GetText() const; + void SetText(String text); + + bool IsSelectable() const; + void SetSelectable(bool value); + + gsl::not_null GetTextRenderObject() override; + render::ScrollRenderObject* GetScrollRenderObject() override { + return nullptr; + } + + private: + std::unique_ptr text_render_object_; + + std::unique_ptr service_; +}; +} // namespace cru::ui::controls -- cgit v1.2.3