| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- // Copyright (c) 2008-2023 the Urho3D project
- // License: MIT
- #pragma once
- #include "../UI/Menu.h"
- namespace Urho3D
- {
- class ListView;
- /// %Menu %UI element that displays a popup list view.
- class URHO3D_API DropDownList : public Menu
- {
- URHO3D_OBJECT(DropDownList, Menu);
- public:
- /// Construct.
- explicit DropDownList(Context* context);
- /// Destruct.
- ~DropDownList() override;
- /// Register object factory.
- /// @nobind
- static void RegisterObject(Context* context);
- /// Apply attribute changes that can not be applied immediately.
- void ApplyAttributes() override;
- /// Return UI rendering batches.
- void GetBatches(Vector<UIBatch>& batches, Vector<float>& vertexData, const IntRect& currentScissor) override;
- /// React to the popup being shown.
- void OnShowPopup() override;
- /// React to the popup being hidden.
- void OnHidePopup() override;
- /// React to editable status change.
- void OnSetEditable() override;
- /// Add item to the end of the list.
- void AddItem(UIElement* item);
- /// Insert item to a specific position. index can be ENDPOS.
- void InsertItem(i32 index, UIElement* item);
- /// Remove specific item.
- void RemoveItem(UIElement* item);
- /// Remove item at index.
- void RemoveItem(i32 index);
- /// Remove all items.
- void RemoveAllItems();
- /// Set selection.
- /// @property
- void SetSelection(i32 index);
- /// Set place holder text. This is the text shown when there is no selection (-1) in drop down list. Note that if the list has items, the default is to show the first item, so the "no selection" state has to be set explicitly.
- /// @property
- void SetPlaceholderText(const String& text);
- /// Set whether popup should be automatically resized to match the dropdown button width.
- /// @property
- void SetResizePopup(bool enable);
- /// Return number of items.
- /// @property
- i32 GetNumItems() const;
- /// Return item at index.
- /// @property{get_items}
- UIElement* GetItem(i32 index) const;
- /// Return all items.
- Vector<UIElement*> GetItems() const;
- /// Return selection index, or NINDEX if none selected.
- /// @property
- i32 GetSelection() const;
- /// Return selected item, or null if none selected.
- /// @property
- UIElement* GetSelectedItem() const;
- /// Return listview element.
- /// @property
- ListView* GetListView() const { return listView_; }
- /// Return selected item placeholder element.
- /// @property
- UIElement* GetPlaceholder() const { return placeholder_; }
- /// Return place holder text.
- /// @property
- const String& GetPlaceholderText() const;
- /// Return whether popup should be automatically resized.
- /// @property
- bool GetResizePopup() const { return resizePopup_; }
- /// Set selection attribute.
- void SetSelectionAttr(i32 index);
- protected:
- /// Filter implicit attributes in serialization process.
- bool FilterImplicitAttributes(XMLElement& dest) const override;
- /// Filter implicit attributes in serialization process.
- bool FilterPopupImplicitAttributes(XMLElement& dest) const override;
- /// Listview element.
- SharedPtr<ListView> listView_;
- /// Selected item placeholder element.
- SharedPtr<UIElement> placeholder_;
- /// Resize popup flag.
- bool resizePopup_;
- private:
- /// Handle listview item click event.
- void HandleItemClicked(StringHash eventType, VariantMap& eventData);
- /// Handle a key press from the listview.
- void HandleListViewKey(StringHash eventType, VariantMap& eventData);
- /// Handle the listview selection change. Set placeholder text hidden/visible as necessary.
- void HandleSelectionChanged(StringHash eventType, VariantMap& eventData);
- /// Selected item index attribute.
- i32 selectionAttr_;
- };
- }
|