Crazy Eddie's GUI System
0.8.4
|
Base class for standard Tree widget. More...
Public Member Functions | |
void | doTreeRender () |
void | doScrollbars () |
size_t | getItemCount (void) const |
Return number of items attached to the tree. | |
size_t | getSelectedCount (void) const |
Return the number of selected items in the tree. | |
TreeItem * | getFirstSelectedItem (void) const |
Return a pointer to the first selected item. | |
TreeItem * | getLastSelectedItem (void) const |
Return a pointer to the first selected item. | |
TreeItem * | getNextSelected (const TreeItem *start_item) const |
Return a pointer to the next selected item after item start_item. | |
TreeItem * | getNextSelectedItemFromList (const LBItemList &itemList, const TreeItem *start_item, bool &foundStartItem) const |
bool | isSortEnabled (void) const |
return whether tree sorting is enabled | |
void | setItemRenderArea (Rectf &r) |
Scrollbar * | getVertScrollbar () |
Scrollbar * | getHorzScrollbar () |
bool | isMultiselectEnabled (void) const |
return whether multi-select is enabled | |
bool | isItemTooltipsEnabled (void) const |
TreeItem * | findFirstItemWithText (const String &text) |
Search the tree for an item with the specified text. | |
TreeItem * | findNextItemWithText (const String &text, const TreeItem *start_item) |
TreeItem * | findItemWithTextFromList (const LBItemList &itemList, const String &text, const TreeItem *start_item, bool foundStartItem) |
TreeItem * | findFirstItemWithID (uint searchID) |
Search the tree for an item with the specified text. | |
TreeItem * | findNextItemWithID (uint searchID, const TreeItem *start_item) |
TreeItem * | findItemWithIDFromList (const LBItemList &itemList, uint searchID, const TreeItem *start_item, bool foundStartItem) |
bool | isTreeItemInList (const TreeItem *item) const |
Return whether the specified TreeItem is in the tree. | |
bool | isVertScrollbarAlwaysShown (void) const |
Return whether the vertical scroll bar is always shown. | |
bool | isHorzScrollbarAlwaysShown (void) const |
Return whether the horizontal scroll bar is always shown. | |
virtual void | initialise (void) |
Initialise the Window based object ready for use. | |
void | resetList (void) |
Remove all items from the tree. | |
void | addItem (TreeItem *item) |
Add the given TreeItem to the tree. | |
void | insertItem (TreeItem *item, const TreeItem *position) |
Insert an item into the tree after a specified item already in the tree. | |
void | removeItem (const TreeItem *item) |
Removes the given item from the tree. If the item is has the auto delete state set, the item will be deleted. | |
void | clearAllSelections (void) |
Clear the selected state for all items. | |
bool | clearAllSelectionsFromList (const LBItemList &itemList) |
void | setSortingEnabled (bool setting) |
Set whether the tree should be sorted. | |
void | setMultiselectEnabled (bool setting) |
Set whether the tree should allow multiple selections or just a single selection. | |
void | setShowVertScrollbar (bool setting) |
Set whether the vertical scroll bar should always be shown. | |
void | setShowHorzScrollbar (bool setting) |
Set whether the horizontal scroll bar should always be shown. | |
void | setItemTooltipsEnabled (bool setting) |
void | setItemSelectState (TreeItem *item, bool state) |
Set the select state of an attached TreeItem. | |
void | setItemSelectState (size_t item_index, bool state) |
Set the select state of an attached TreeItem. | |
virtual void | setLookNFeel (const String &look) |
Set the LookNFeel that shoule be used for this window. | |
void | handleUpdatedItemData (void) |
Causes the tree to update it's internal state after changes have been made to one or more attached TreeItem objects. | |
void | ensureItemIsVisible (const TreeItem *item) |
Ensure the item at the specified index is visible within the tree. | |
Tree (const String &type, const String &name) | |
Constructor for Tree base class. | |
virtual | ~Tree (void) |
Destructor for Tree base class. | |
Static Public Attributes | |
static const String | EventNamespace |
Namespace for global events. | |
static const String | WidgetTypeName |
static const String | EventListContentsChanged |
static const String | EventSelectionChanged |
static const String | EventSortModeChanged |
static const String | EventMultiselectModeChanged |
static const String | EventVertScrollbarModeChanged |
static const String | EventHorzScrollbarModeChanged |
static const String | EventBranchOpened |
static const String | EventBranchClosed |
Protected Member Functions | |
virtual Rectf | getTreeRenderArea (void) const |
Return a Rect object describing, in un-clipped pixels, the window relative area that is to be used for rendering tree items. | |
virtual Scrollbar * | createVertScrollbar (const String &name) const |
create and return a pointer to a Scrollbar widget for use as vertical scroll bar. | |
virtual Scrollbar * | createHorzScrollbar (const String &name) const |
create and return a pointer to a Scrollbar widget for use as horizontal scroll bar. | |
virtual void | cacheTreeBaseImagery () |
Perform caching of the widget control frame and other 'static' areas. This method should not render the actual items. Note that the items are typically rendered to layer 3, other layers can be used for rendering imagery behind and infront of the items. | |
bool | containsOpenItemRecursive (const LBItemList &itemList, TreeItem *item) |
Checks if a tree item is visible (searches sub-items) | |
void | addTreeEvents (void) |
Add tree specific events. | |
void | configureScrollbars (void) |
display required integrated scroll bars according to current state of the tree and update their values. | |
void | selectRange (size_t start, size_t end) |
select all strings between positions start and end. (inclusive) including end. | |
float | getTotalItemsHeight (void) const |
Return the sum of all item heights. | |
void | getTotalItemsInListHeight (const LBItemList &itemList, float *heightSum) const |
float | getWidestItemWidth (void) const |
Return the width of the widest item. | |
void | getWidestItemWidthInList (const LBItemList &itemList, int itemDepth, float *widest) const |
bool | getHeightToItemInList (const LBItemList &itemList, const TreeItem *treeItem, int itemDepth, float *height) const |
Clear the selected state for all items (implementation) | |
bool | clearAllSelections_impl (void) |
Clear the selected state for all items (implementation) | |
TreeItem * | getItemAtPoint (const Vector2f &pt) const |
Return the TreeItem under the given window local pixel co-ordinate. | |
TreeItem * | getItemFromListAtPoint (const LBItemList &itemList, float *bottomY, const Vector2f &pt) const |
bool | resetList_impl (void) |
Remove all items from the tree. | |
bool | handle_scrollChange (const EventArgs &args) |
Internal handler that is triggered when the user interacts with the scrollbars. | |
virtual void | populateGeometryBuffer () |
Update the rendering cache. | |
bool | handleFontRenderSizeChange (const EventArgs &args) |
handler function for when font render size changes. | |
void | drawItemList (LBItemList &itemList, Rectf &itemsArea, float widest, Vector2f &itemPos, GeometryBuffer &geometry, float alpha) |
virtual void | onListContentsChanged (WindowEventArgs &e) |
Handler called internally when the tree contents are changed. | |
virtual void | onSelectionChanged (TreeEventArgs &e) |
Handler called internally when the currently selected item or items changes. | |
virtual void | onSortModeChanged (WindowEventArgs &e) |
Handler called internally when the sort mode setting changes. | |
virtual void | onMultiselectModeChanged (WindowEventArgs &e) |
Handler called internally when the multi-select mode setting changes. | |
virtual void | onVertScrollbarModeChanged (WindowEventArgs &e) |
Handler called internally when the forced display of the vertical scroll bar setting changes. | |
virtual void | onHorzScrollbarModeChanged (WindowEventArgs &e) |
Handler called internally when the forced display of the horizontal scroll bar setting changes. | |
virtual void | onBranchOpened (TreeEventArgs &e) |
Handler called internally when the user opens a branch of the tree. | |
virtual void | onBranchClosed (TreeEventArgs &e) |
Handler called internally when the user closes a branch of the tree. | |
virtual void | onSized (ElementEventArgs &e) |
Handler called when the window's size changes. | |
virtual void | onMouseButtonDown (MouseEventArgs &e) |
Handler called when a mouse button has been depressed within this window's area. | |
virtual void | onMouseWheel (MouseEventArgs &e) |
Handler called when the mouse wheel (z-axis) position changes within this window's area. | |
virtual void | onMouseMove (MouseEventArgs &e) |
Handler called when the mouse cursor has been moved within this window's area. | |
Protected Attributes | |
bool | d_sorted |
true if tree is sorted | |
bool | d_multiselect |
true if multi-select is enabled | |
bool | d_forceVertScroll |
true if vertical scrollbar should always be displayed | |
bool | d_forceHorzScroll |
true if horizontal scrollbar should always be displayed | |
bool | d_itemTooltips |
true if each item should have an individual tooltip | |
Scrollbar * | d_vertScrollbar |
vertical scroll-bar widget | |
Scrollbar * | d_horzScrollbar |
horizontal scroll-bar widget | |
LBItemList | d_listItems |
list of items in the tree. | |
TreeItem * | d_lastSelected |
holds pointer to the last selected item (used in range selections) | |
const ImagerySection * | d_openButtonImagery |
const ImagerySection * | d_closeButtonImagery |
Friends | |
class | TreeItem |
Base class for standard Tree widget.
void CEGUI::Tree::addItem | ( | TreeItem * | item | ) |
virtual void CEGUI::Tree::cacheTreeBaseImagery | ( | ) | [inline, protected, virtual] |
Perform caching of the widget control frame and other 'static' areas. This method should not render the actual items. Note that the items are typically rendered to layer 3, other layers can be used for rendering imagery behind and infront of the items.
void CEGUI::Tree::clearAllSelections | ( | void | ) |
Clear the selected state for all items.
bool CEGUI::Tree::clearAllSelections_impl | ( | void | ) | [protected] |
Clear the selected state for all items (implementation)
virtual Scrollbar* CEGUI::Tree::createHorzScrollbar | ( | const String & | name | ) | const [inline, protected, virtual] |
virtual Scrollbar* CEGUI::Tree::createVertScrollbar | ( | const String & | name | ) | const [inline, protected, virtual] |
void CEGUI::Tree::ensureItemIsVisible | ( | const TreeItem * | item | ) |
Ensure the item at the specified index is visible within the tree.
item | Pointer to the TreeItem to be made visible in the tree. |
InvalidRequestException | thrown if item is not attached to this tree. |
TreeItem* CEGUI::Tree::findFirstItemWithID | ( | uint | searchID | ) |
Search the tree for an item with the specified text.
text | String object containing the text to be searched for. |
start_item | TreeItem where the search is to begin, the search will not include item. If item is 0, the search will begin from the first item in the tree. |
InvalidRequestException | thrown if item is not attached to this tree. |
TreeItem* CEGUI::Tree::findFirstItemWithText | ( | const String & | text | ) |
Search the tree for an item with the specified text.
text | String object containing the text to be searched for. |
start_item | TreeItem where the search is to begin, the search will not include item. If item is 0, the search will begin from the first item in the tree. |
InvalidRequestException | thrown if item is not attached to this tree. |
TreeItem* CEGUI::Tree::getFirstSelectedItem | ( | void | ) | const |
Return a pointer to the first selected item.
bool CEGUI::Tree::getHeightToItemInList | ( | const LBItemList & | itemList, |
const TreeItem * | treeItem, | ||
int | itemDepth, | ||
float * | height | ||
) | const [protected] |
Clear the selected state for all items (implementation)
TreeItem* CEGUI::Tree::getItemAtPoint | ( | const Vector2f & | pt | ) | const [protected] |
size_t CEGUI::Tree::getItemCount | ( | void | ) | const [inline] |
Return number of items attached to the tree.
TreeItem* CEGUI::Tree::getLastSelectedItem | ( | void | ) | const [inline] |
Return a pointer to the first selected item.
TreeItem* CEGUI::Tree::getNextSelected | ( | const TreeItem * | start_item | ) | const |
Return a pointer to the next selected item after item start_item.
start_item | Pointer to the TreeItem where the search for the next selected item is to begin. If this parameter is 0, the search will begin with the first item in the tree. |
InvalidRequestException | thrown if start_item is not attached to this tree. |
size_t CEGUI::Tree::getSelectedCount | ( | void | ) | const |
Return the number of selected items in the tree.
virtual Rectf CEGUI::Tree::getTreeRenderArea | ( | void | ) | const [inline, protected, virtual] |
void CEGUI::Tree::handleUpdatedItemData | ( | void | ) |
Causes the tree to update it's internal state after changes have been made to one or more attached TreeItem objects.
Client code must call this whenever it has made any changes to TreeItem objects already attached to the tree. If you are just adding items, or removed items to update them prior to re-adding them, there is no need to call this method.
virtual void CEGUI::Tree::initialise | ( | void | ) | [virtual] |
Initialise the Window based object ready for use.
void CEGUI::Tree::insertItem | ( | TreeItem * | item, |
const TreeItem * | position | ||
) |
Insert an item into the tree after a specified item already in the tree.
Note that if the tree is sorted, the item may not end up in the requested position.
item | Pointer to the TreeItem to be inserted. Note that it is the passed object that is added to the tree, a copy is not made. If this parameter is 0, nothing happens. |
position | Pointer to a TreeItem that item is to be inserted after. If this parameter is 0, the item is inserted at the start of the tree. |
InvalidRequestException | thrown if no TreeItem position is attached to this tree. |
bool CEGUI::Tree::isHorzScrollbarAlwaysShown | ( | void | ) | const |
Return whether the horizontal scroll bar is always shown.
bool CEGUI::Tree::isMultiselectEnabled | ( | void | ) | const [inline] |
return whether multi-select is enabled
bool CEGUI::Tree::isSortEnabled | ( | void | ) | const [inline] |
return whether tree sorting is enabled
bool CEGUI::Tree::isTreeItemInList | ( | const TreeItem * | item | ) | const |
bool CEGUI::Tree::isVertScrollbarAlwaysShown | ( | void | ) | const |
Return whether the vertical scroll bar is always shown.
virtual void CEGUI::Tree::onMouseButtonDown | ( | MouseEventArgs & | e | ) | [protected, virtual] |
Handler called when a mouse button has been depressed within this window's area.
e | MouseEventArgs object. All fields are valid. |
Reimplemented from CEGUI::Window.
virtual void CEGUI::Tree::onMouseMove | ( | MouseEventArgs & | e | ) | [protected, virtual] |
Handler called when the mouse cursor has been moved within this window's area.
e | MouseEventArgs object. All fields are valid. |
Reimplemented from CEGUI::Window.
virtual void CEGUI::Tree::onMouseWheel | ( | MouseEventArgs & | e | ) | [protected, virtual] |
Handler called when the mouse wheel (z-axis) position changes within this window's area.
e | MouseEventArgs object. All fields are valid. |
Reimplemented from CEGUI::Window.
virtual void CEGUI::Tree::onSized | ( | ElementEventArgs & | e | ) | [protected, virtual] |
Handler called when the window's size changes.
e | WindowEventArgs object whose 'window' pointer field is set to the window that triggered the event. For this event the trigger window is always 'this'. |
Reimplemented from CEGUI::Window.
virtual void CEGUI::Tree::populateGeometryBuffer | ( | ) | [protected, virtual] |
Update the rendering cache.
Populates the Window's GeometryBuffer ready for rendering.
Reimplemented from CEGUI::Window.
void CEGUI::Tree::removeItem | ( | const TreeItem * | item | ) |
Removes the given item from the tree. If the item is has the auto delete state set, the item will be deleted.
item | Pointer to the TreeItem that is to be removed. If item is not attached to this tree then nothing will happen. |
void CEGUI::Tree::resetList | ( | void | ) |
Remove all items from the tree.
Note that this will cause 'AutoDelete' items to be deleted.
bool CEGUI::Tree::resetList_impl | ( | void | ) | [protected] |
Remove all items from the tree.
void CEGUI::Tree::setItemSelectState | ( | TreeItem * | item, |
bool | state | ||
) |
Set the select state of an attached TreeItem.
This is the recommended way of selecting and deselecting items attached to a tree as it respects the multi-select mode setting. It is possible to modify the setting on TreeItems directly, but that approach does not respect the settings of the tree.
item | The TreeItem to be affected. This item must be attached to the tree. |
state |
|
InvalidRequestException | thrown if item is not attached to this tree. |
void CEGUI::Tree::setItemSelectState | ( | size_t | item_index, |
bool | state | ||
) |
Set the select state of an attached TreeItem.
This is the recommended way of selecting and deselecting items attached to a tree as it respects the multi-select mode setting. It is possible to modify the setting on TreeItems directly, but that approach does not respect the settings of the tree.
item_index | The zero based index of the TreeItem to be affected. This must be a valid index (0 <= index < getItemCount()) |
state |
|
InvalidRequestException | thrown if item_index is out of range for the tree |
virtual void CEGUI::Tree::setLookNFeel | ( | const String & | look | ) | [virtual] |
Set the LookNFeel that shoule be used for this window.
look | String object holding the name of the look to be assigned to the window. |
UnknownObjectException | thrown if the look'n'feel specified by look does not exist. |
Reimplemented from CEGUI::Window.
void CEGUI::Tree::setMultiselectEnabled | ( | bool | setting | ) |
Set whether the tree should allow multiple selections or just a single selection.
setting |
|
void CEGUI::Tree::setShowHorzScrollbar | ( | bool | setting | ) |
Set whether the horizontal scroll bar should always be shown.
setting |
|
void CEGUI::Tree::setShowVertScrollbar | ( | bool | setting | ) |
Set whether the vertical scroll bar should always be shown.
setting |
|
void CEGUI::Tree::setSortingEnabled | ( | bool | setting | ) |
Set whether the tree should be sorted.
setting |
|
const String CEGUI::Tree::EventBranchClosed [static] |
Event fired when a branch of the tree is closed by the user. Handlers are passed a const TreeEventArgs reference with WindowEventArgs::window set to the Tree containing the branch that has been closed and TreeEventArgs::treeItem set to the TreeItem at the head of the closed branch.
const String CEGUI::Tree::EventBranchOpened [static] |
Event fired when a branch of the tree is opened by the user. Handlers are passed a const TreeEventArgs reference with WindowEventArgs::window set to the Tree containing the branch that has been opened and TreeEventArgs::treeItem set to the TreeItem at the head of the opened branch.
const String CEGUI::Tree::EventHorzScrollbarModeChanged [static] |
Event fired when the mode setting that forces the display of the horizontal scroll bar for the tree is changed. Handlers are passed a const WindowEventArgs reference with WindowEventArgs::window set to the Tree whose horizontal scrollbar mode has been changed.
const String CEGUI::Tree::EventListContentsChanged [static] |
Event fired when the content of the tree is changed. Handlers are passed a const WindowEventArgs reference with WindowEventArgs::window set to the Tree whose content has changed.
const String CEGUI::Tree::EventMultiselectModeChanged [static] |
Event fired when the multi-select mode setting for the Tree changes. Handlers are passed a const TreeEventArgs reference with WindowEventArgs::window set to the Tree whose setting has changed. TreeEventArgs::treeItem is always set to 0.
const String CEGUI::Tree::EventSelectionChanged [static] |
Event fired when there is a change to the currently selected item(s). Handlers are passed a const TreeEventArgs reference with WindowEventArgs::window set to the Tree whose item selection has changed, and TreeEventArgs::treeItem is set to the (last) item to be selected, or 0 if none.
const String CEGUI::Tree::EventSortModeChanged [static] |
Event fired when the sort mode setting for the Tree is changed. Handlers are passed a const WindowEventArgs reference with WindowEventArgs::window set to the Tree whose sort mode has been changed.
const String CEGUI::Tree::EventVertScrollbarModeChanged [static] |
Event fired when the mode setting that forces the display of the vertical scroll bar for the tree is changed. Handlers are passed a const WindowEventArgs reference with WindowEventArgs::window set to the Tree whose vertical scrollbar mode has been changed.