aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-05-11 16:02:50 +0800
committercrupest <crupest@outlook.com>2021-05-11 16:02:50 +0800
commit5c050b44558856ad0fe41dab95f97ea0a59d77eb (patch)
treee9b6f37ee3c737d792f555c5ba32cb85e80bf03e /include
parente42db68bc5924d55d6885b94def3a4c1cc08463b (diff)
downloadcru-5c050b44558856ad0fe41dab95f97ea0a59d77eb.tar.gz
cru-5c050b44558856ad0fe41dab95f97ea0a59d77eb.tar.bz2
cru-5c050b44558856ad0fe41dab95f97ea0a59d77eb.zip
...
Diffstat (limited to 'include')
-rw-r--r--include/cru/ui/controls/ScrollView.hpp32
1 files changed, 32 insertions, 0 deletions
diff --git a/include/cru/ui/controls/ScrollView.hpp b/include/cru/ui/controls/ScrollView.hpp
new file mode 100644
index 00000000..93fd1712
--- /dev/null
+++ b/include/cru/ui/controls/ScrollView.hpp
@@ -0,0 +1,32 @@
+#pragma once
+#include "ContentControl.hpp"
+#include "cru/common/Base.hpp"
+#include "cru/ui/render/RenderObject.hpp"
+#include "cru/ui/render/ScrollRenderObject.hpp"
+
+#include <memory>
+#include <string_view>
+
+namespace cru::ui::controls {
+class ScrollView : public ContentControl {
+ public:
+ static ScrollView* Create() { return new ScrollView(); }
+
+ static constexpr std::u16string_view control_type = u"ScrollView";
+
+ ScrollView();
+
+ CRU_DELETE_COPY(ScrollView)
+ CRU_DELETE_MOVE(ScrollView)
+
+ ~ScrollView() override = default;
+
+ public:
+ std::u16string_view GetControlType() const override { return control_type; }
+
+ render::RenderObject* GetRenderObject() const override;
+
+ private:
+ std::unique_ptr<render::ScrollRenderObject> scroll_render_object_;
+};
+} // namespace cru::ui::controls