From ec201783e4b4733770648c2f92c3ffb9629bb7f7 Mon Sep 17 00:00:00 2001 From: crupest Date: Tue, 2 Apr 2019 21:57:01 +0800 Subject: ... --- include/cru/platform/font.hpp | 8 ++++++++ include/cru/platform/text_layout.hpp | 15 +++++++++++++++ include/cru/platform/win/win_font.hpp | 26 ++++++++++++++++++++++++++ include/cru/platform/win/win_text_layout.hpp | 24 ++++++++++++++++++++++++ 4 files changed, 73 insertions(+) create mode 100644 include/cru/platform/font.hpp create mode 100644 include/cru/platform/text_layout.hpp create mode 100644 include/cru/platform/win/win_font.hpp create mode 100644 include/cru/platform/win/win_text_layout.hpp (limited to 'include/cru/platform') diff --git a/include/cru/platform/font.hpp b/include/cru/platform/font.hpp new file mode 100644 index 00000000..750aaae1 --- /dev/null +++ b/include/cru/platform/font.hpp @@ -0,0 +1,8 @@ +#pragma once +#include "cru/common/base.hpp" + +namespace cru::platform { +struct FontDescriptor : virtual Interface { + +}; +} diff --git a/include/cru/platform/text_layout.hpp b/include/cru/platform/text_layout.hpp new file mode 100644 index 00000000..fce6ce5f --- /dev/null +++ b/include/cru/platform/text_layout.hpp @@ -0,0 +1,15 @@ +#pragma once +#include "cru/common/base.hpp" + +#include "cru/common/ui_base.hpp" + +#include + +namespace cru::platform { +struct TextLayout : virtual Interface { + virtual void SetMaxWidth(float max_width) = 0; + virtual void SetMaxHeight(float max_height) = 0; + virtual ui::Rect GetTextBounds() = 0; + virtual std::vector TextRangeRect(const ui::TextRange& text_range) = 0; +}; +} // namespace cru::platform diff --git a/include/cru/platform/win/win_font.hpp b/include/cru/platform/win/win_font.hpp new file mode 100644 index 00000000..69eebdfb --- /dev/null +++ b/include/cru/platform/win/win_font.hpp @@ -0,0 +1,26 @@ +#pragma once +#include "win_pre_config.hpp" + +#include "../font.hpp" + +#include + +namespace cru::platform::win { +class GraphManager; + +class WinFontDescriptor : public Object, public virtual FontDescriptor { + public: + explicit WinFontDescriptor(GraphManager* graph_manager, + const std::wstring_view& font_family); + WinFontDescriptor(const WinFontDescriptor& other) = delete; + WinFontDescriptor(WinFontDescriptor&& other) = delete; + WinFontDescriptor& operator=(const WinFontDescriptor& other) = delete; + WinFontDescriptor& operator=(WinFontDescriptor&& other) = delete; + ~WinFontDescriptor() override = default; + + IDWriteTextFormat* GetDWriteTextFormat() const { return text_format_.Get(); } + + private: + Microsoft::WRL::ComPtr text_format_; +}; +} // namespace cru::platform::win diff --git a/include/cru/platform/win/win_text_layout.hpp b/include/cru/platform/win/win_text_layout.hpp new file mode 100644 index 00000000..68961dd7 --- /dev/null +++ b/include/cru/platform/win/win_text_layout.hpp @@ -0,0 +1,24 @@ +#pragma once +#include "win_pre_config.hpp" + +#include "../text_layout.hpp" +#include "win_font.hpp" + +#include + +namespace cru::platform::win { +class WinTextLayout : public Object, public virtual TextLayout { + public: + explicit WinTextLayout(std::shared_ptr font); + WinTextLayout(const WinTextLayout& other) = delete; + WinTextLayout(WinTextLayout&& other) = delete; + WinTextLayout& operator=(const WinTextLayout& other) = delete; + WinTextLayout& operator=(WinTextLayout&& other) = delete; + ~WinTextLayout() override; + + IDWriteTextLayout* GetDWriteTextLayout() const { return text_layout_.Get(); } + + private: + Microsoft::WRL::ComPtr text_layout_; +}; +} // namespace cru::platform::win -- cgit v1.2.3