diff options
author | crupest <crupest@outlook.com> | 2021-05-11 16:02:50 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2021-05-11 16:02:50 +0800 |
commit | 5c050b44558856ad0fe41dab95f97ea0a59d77eb (patch) | |
tree | e9b6f37ee3c737d792f555c5ba32cb85e80bf03e /include | |
parent | e42db68bc5924d55d6885b94def3a4c1cc08463b (diff) | |
download | cru-5c050b44558856ad0fe41dab95f97ea0a59d77eb.tar.gz cru-5c050b44558856ad0fe41dab95f97ea0a59d77eb.tar.bz2 cru-5c050b44558856ad0fe41dab95f97ea0a59d77eb.zip |
...
Diffstat (limited to 'include')
-rw-r--r-- | include/cru/ui/controls/ScrollView.hpp | 32 |
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 |