aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/graph/direct/text_layout.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'include/cru/win/graph/direct/text_layout.hpp')
-rw-r--r--include/cru/win/graph/direct/text_layout.hpp42
1 files changed, 42 insertions, 0 deletions
diff --git a/include/cru/win/graph/direct/text_layout.hpp b/include/cru/win/graph/direct/text_layout.hpp
new file mode 100644
index 00000000..7339eff9
--- /dev/null
+++ b/include/cru/win/graph/direct/text_layout.hpp
@@ -0,0 +1,42 @@
+#pragma once
+#include "../win_pre_config.hpp"
+
+#include "cru/platform/graph/text_layout.hpp"
+
+#include <memory>
+
+namespace cru::win::graph {
+struct IWinNativeFactory;
+class WinFontDescriptor;
+
+class WinTextLayout : public Object, public virtual platform::graph::ITextLayout {
+ public:
+ explicit WinTextLayout(IWinNativeFactory* factory,
+ std::shared_ptr<WinFontDescriptor> font, std::wstring text);
+ WinTextLayout(const WinTextLayout& other) = delete;
+ WinTextLayout(WinTextLayout&& other) = delete;
+ WinTextLayout& operator=(const WinTextLayout& other) = delete;
+ WinTextLayout& operator=(WinTextLayout&& other) = delete;
+ ~WinTextLayout() override = default;
+
+ std::wstring GetText() override;
+ void SetText(std::wstring new_text) override;
+ std::shared_ptr<platform::graph::IFontDescriptor> GetFont();
+ void SetFont(std::shared_ptr<platform::graph::IFontDescriptor> font);
+ void SetMaxWidth(float max_width) override;
+ void SetMaxHeight(float max_height) override;
+ ui::Rect GetTextBounds() override;
+ std::vector<ui::Rect> TextRangeRect(
+ const ui::TextRange& text_range) override;
+
+ IDWriteTextLayout* GetDWriteTextLayout() const { return text_layout_.Get(); }
+
+ private:
+ IWinNativeFactory* factory_;
+ std::wstring text_;
+ std::shared_ptr<WinFontDescriptor> font_descriptor_;
+ float max_width_ = 0.0f;
+ float max_height_ = 0.0f;
+ Microsoft::WRL::ComPtr<IDWriteTextLayout> text_layout_;
+};
+} // namespace cru::platform::win