aboutsummaryrefslogtreecommitdiff
path: root/include/cru/ui/controls/ScrollView.h
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-02-08 16:53:51 +0800
committercrupest <crupest@outlook.com>2022-02-08 16:53:51 +0800
commit74bb9cd27242b9320f99ff4d2b50c3051576cc14 (patch)
tree744bac5799c593d1d6f81e7b09581bea626f2cde /include/cru/ui/controls/ScrollView.h
parentb90c398de829d1ba5329651d75bae82f5e4085fe (diff)
downloadcru-74bb9cd27242b9320f99ff4d2b50c3051576cc14.tar.gz
cru-74bb9cd27242b9320f99ff4d2b50c3051576cc14.tar.bz2
cru-74bb9cd27242b9320f99ff4d2b50c3051576cc14.zip
...
Diffstat (limited to 'include/cru/ui/controls/ScrollView.h')
-rw-r--r--include/cru/ui/controls/ScrollView.h32
1 files changed, 32 insertions, 0 deletions
diff --git a/include/cru/ui/controls/ScrollView.h b/include/cru/ui/controls/ScrollView.h
new file mode 100644
index 00000000..46c23691
--- /dev/null
+++ b/include/cru/ui/controls/ScrollView.h
@@ -0,0 +1,32 @@
+#pragma once
+#include "ContentControl.h"
+#include "cru/common/Base.h"
+#include "cru/ui/render/RenderObject.h"
+#include "cru/ui/render/ScrollRenderObject.h"
+
+#include <memory>
+#include <string_view>
+
+namespace cru::ui::controls {
+class CRU_UI_API ScrollView : public ContentControl {
+ public:
+ static ScrollView* Create() { return new ScrollView(); }
+
+ static constexpr StringView control_type = u"ScrollView";
+
+ ScrollView();
+
+ CRU_DELETE_COPY(ScrollView)
+ CRU_DELETE_MOVE(ScrollView)
+
+ ~ScrollView() override = default;
+
+ public:
+ String GetControlType() const override { return control_type.ToString(); }
+
+ render::RenderObject* GetRenderObject() const override;
+
+ private:
+ std::unique_ptr<render::ScrollRenderObject> scroll_render_object_;
+};
+} // namespace cru::ui::controls