/**************************************************************************** * include/cnxwidget.hxx * NxWidgets/libnxwidgets/ * * Copyright (C) 2012 Gregory Nutt. All rights reserved. * Author: Gregory Nutt * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * 3. Neither the name NuttX, NxWidgets, nor the names of its contributors * me be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * **************************************************************************** * * Portions of this package derive from Woopsi (http://woopsi.org/) and * portions are original efforts. It is difficult to determine at this * point what parts are original efforts and which parts derive from Woopsi. * However, in any event, the work of Antony Dzeryn will be acknowledged * in most NxWidget files. Thanks Antony! * * Copyright (c) 2007-2011, Antony Dzeryn * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * Neither the names "Woopsi", "Simian Zombie" nor the * names of its contributors may be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY Antony Dzeryn ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL Antony Dzeryn BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************/ #ifndef __INCLUDE_CNXWIDGET_HXX #define __INCLUDE_CNXWIDGET_HXX /**************************************************************************** * Included Files ****************************************************************************/ #include #include #include #include #include #include "cnxstring.hxx" #include "cnxfont.hxx" #include "crect.hxx" #include "cwidgetstyle.hxx" #include "cwidgeteventargs.hxx" #include "cwidgeteventhandler.hxx" #include "cwidgeteventhandlerlist.hxx" #include "tnxarray.hxx" /**************************************************************************** * Pre-Processor Definitions ****************************************************************************/ /**************************************************************************** * Implementation Classes ****************************************************************************/ #if defined(__cplusplus) namespace NXWidgets { /** * Forward references */ class CWidgetControl; class CGraphicsPort; class CNxFont; class CRectCache; class CWidgetEventHandlerList; /** * Class providing all the basic functionality of a NxWidget. All other * widgets must must inherit from this class. */ class CNxWidget { public: /** * Enum describing the way other widgets should behave when they try to * close this widget. */ enum CloseType { CLOSE_TYPE_CLOSE = 0, /**< Widgets should call the close() method */ CLOSE_TYPE_HIDE = 1, /**< Widgets should call the hide() method */ CLOSE_TYPE_SHELVE = 2 /**< Widgets should call the shelve() method */ }; /** * Enum listing flags that can be set in the constructor's "flags" parameter. */ enum WidgetFlagType { WIDGET_BORDERLESS = 0x0001, /**< Widget has no border */ WIDGET_DRAGGABLE = 0x0002, /**< Widget can be dragged by the user */ WIDGET_PERMEABLE = 0x0004, /**< Widget's children can exceed this widget's edges */ WIDGET_DOUBLE_CLICKABLE = 0x0008, /**< Widget can be double-clicked */ WIDGET_NO_RAISE_EVENTS = 0x0010, /**< Widget does not raise events */ }; /** * Struct describing some basic properties of a widget. */ typedef struct { uint8_t clicked : 1; /**< True if the widget is currently clicked. */ uint8_t hasFocus : 1; /**< True if the widget has focus. */ uint8_t dragging : 1; /**< True if the widget is being dragged. */ uint8_t deleted : 1; /**< True if the widget has been deleted. */ uint8_t shelved : 1; /**< True if the widget has been shelved. */ uint8_t borderless : 1; /**< True if the widget is borderless. */ uint8_t draggable : 1; /**< True if the widget can be dragged. */ uint8_t drawingEnabled : 1; /**< True if the widget can be drawn. */ uint8_t enabled : 1; /**< True if the widget is enabled. */ uint8_t permeable : 1; /**< True if the widget's children can exceed its dimensions. */ uint8_t erased : 1; /**< True if the widget is currently erased from the frame buffer. */ uint8_t visibleRegionCacheInvalid : 1; /**< True if the region cache is invalid. */ uint8_t hidden : 1; /**< True if the widget is hidden. */ uint8_t doubleClickable : 1; /**< True if the widget can be double-clicked. */ uint8_t modal : 1; /**< True if the widget is modal. */ } Flags; /** * Struct describing the size of all four borders of a widget. */ typedef struct { uint8_t top; /**< Height of the top border. */ uint8_t right; /**< Width of the right border. */ uint8_t bottom; /**< Height of the bottom border. */ uint8_t left; /**< Width of the left border. */ } WidgetBorderSize; protected: CWidgetControl *m_widgetControl; /**< The controlling widget for the display */ CRect m_rect; /**< Rectange bounding the widget. */ uint32_t m_refcon; /**< Identifying number of the widget. */ // Dragging variables nxgl_coord_t m_grabPointX; /**< Physical space x coordinate where dragging began. */ nxgl_coord_t m_grabPointY; /**< Physical space y coordinate where dragging began. */ nxgl_coord_t m_newX; /**< Physical x coordinate where widget is being dragged to. */ nxgl_coord_t m_newY; /**< Physical y coordinate where widget is being dragged to. */ // Style CWidgetStyle m_style; /**< All style information used by a widget. */ // Status Flags m_flags; /**< Flags struct. */ // Event handling CWidgetEventHandlerList *m_widgetEventHandlers; /**< List of event handlers. */ // Double-clicking struct timespec m_lastClickTime; /**< System timer when last clicked. */ nxgl_coord_t m_lastClickX; /**< X coordinate of last click. */ nxgl_coord_t m_lastClickY; /**< Y coordinate of last click. */ int m_doubleClickBounds; /**< Area in which a click is assumed to be a double-click. */ // Hierarchy control CNxWidget *m_parent; /**< Pointer to the widget's parent. */ CNxWidget *m_focusedChild; /**< Pointer to the child widget that has focus. */ TNxArray m_children; /**< List of child widgets. */ TNxArray m_shelvedWidgets; /**< List of shelved child widgets. */ // Visible regions CRectCache *m_rectCache; /**< List of the widget's visible regions. */ CloseType m_closeType; /**< Type of close method that should be called for the widget. */ WidgetBorderSize m_borderSize; /**< Size of the widget borders. */ /** * Use the provided widget style */ void useWidgetStyle(const CWidgetStyle *style); /** * Draw the area of this widget that falls within the clipping region. * Called by the redraw() function to draw all visible regions. * * @param port The CGraphicsPort to draw to. * @see redraw(). */ virtual inline void drawContents(CGraphicsPort* port) { } /** * Draw the area of this widget that falls within the clipping region. * Called by the redraw() function to draw all visible regions. * * @param port The CGraphicsPort to draw to. * @see redraw(). */ virtual void drawBorder(CGraphicsPort* port) { } /** * Checks if the supplied coordinates collide with a portion of this widget * that is not obscured by its siblings, but that may be obscured by * its children. * * @param x X coordinate of the click. * @param y Y coordinate of the click. * @return True if a collision occurred; false if not. */ bool checkCollisionWithForegroundRects(nxgl_coord_t x, nxgl_coord_t y) const; /** * Draw all visible regions of this widget's children. */ void drawChildren(void); /** * Erase and remove the supplied child widget from this widget and * send it to the deletion queue. * * @param widget The widget to close. * @see close(). */ void closeChild(CNxWidget *widget); /** * Erase the supplied child widget and move it out of the main child * list into the shelved list. The widget remains in memory and can * be restored by calling "unshelve()" on the widget. * * @param widget The widget to hide. */ void shelveChild(CNxWidget *widget); /** * Redraws all regions of child widgets that fall within the invalidRects * regions. * * @param invalidRects List of invalid regions that need to be redrawn. * @param sender Pointer to the widget that initiated the redraw. */ void redrawDirtyChildren(TNxArray* invalidRects, CNxWidget *sender); /** * Get the index of the next visible widget higher up the z-order. * * @param startIndex The starting index. * @return The index of the next highest visible widget. */ const int getHigherVisibleWidget(const int startIndex) const; /** * Get the index of the next visible widget lower down the z-order. * * @param startIndex The starting index. * @return The index of the next lowest visible widget. */ const int getLowerVisibleWidget(const int startIndex) const; /** * Notify this widget that it is being dragged, and set its drag point. * * @param x The x coordinate of the drag position relative to this widget. * @param y The y coordinate of the drag position relative to this widget. */ void startDragging(nxgl_coord_t x, nxgl_coord_t y); /** * Notify this widget that it is no longer being dragged. */ void stopDragging(nxgl_coord_t x, nxgl_coord_t y); /** * Copy constructor is protected to prevent usage. */ inline CNxWidget(const CNxWidget &widget) { } /** * Called when the widget is clicked. Override this when creating new * widgets if the widget should exhibit additional behaviour when it is * clicked. * * @param x The x coordinate of the click. * @param y The y coordinate of the click. */ virtual inline void onClick(nxgl_coord_t x, nxgl_coord_t y) { } /** * Called when the widget is double-clicked. Override this when * creating new widgets if the widget should exhibit additional * behaviour when it is double-clicked. To change the conditions that * apply in detecting a double-click, override the isDoubleClicked() * method. * * @param x The x coordinate of the click. * @param y The y coordinate of the click. */ virtual inline void onDoubleClick(nxgl_coord_t x, nxgl_coord_t y) { } /** * Called when the widget is released. Override this when * creating new widgets if the widget should exhibit additional * behaviour when it is released. * * @param x The x coordinate of the mouse when released. * @param y The y coordinate of the mouse when released. */ virtual inline void onRelease(nxgl_coord_t x, nxgl_coord_t y) { } /** * Called when the widget is released outside of its boundaries. * Override this when creating new widgets if the widget should exhibit * additional behaviour when it is released outside of its boundaries. * * @param x The x coordinate of the mouse when released. * @param y The y coordinate of the mouse when released. */ virtual inline void onReleaseOutside(nxgl_coord_t x, nxgl_coord_t y) { } /** * Called when the widget is dragged. Override this when creating new * widgets if the widget should exhibit additional behaviour when it is * dragged. * * @param x The x coordinate of the mouse. * @param y The y coordinate of the mouse. * @param vX X distance dragged. * @param vY Y distance dragged. */ virtual inline void onDrag(nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t vX, nxgl_coord_t vY) { } /** * Called when the widget starts being dragged. Override this when * creating new widgets if the widget should exhibit additional * behaviour when dragging starts. */ virtual inline void onDragStart(void) { } /** * Called when the widget stops being dragged. Override this when * creating new widgets if the widget should exhibit additional * behaviour when dragging stops. */ virtual inline void onDragStop(void) { } /** * Called when the widget gains focus. Override this when creating new * widgets if the widget should exhibit additional behaviour when * gaining focus. */ virtual inline void onFocus(void) { } /** * Called when the widget loses focus. Override this when creating new * widgets if the widget should exhibit additional behaviour when * losing focus. */ virtual inline void onBlur(void) { } /** * Called when the widget is enabled. Override this when creating new * widgets if the widget should exhibit additional behaviour when * enabled. */ virtual inline void onEnable(void) { } /** * Called when the widget is disabled. Override this when creating new * widgets if the widget should exhibit additional behaviour when * disabled. */ virtual inline void onDisable(void) { } /** * Called when the widget is resized. Override this when creating new * widgets if the widget should exhibit additional behaviour when * resized. * * @param width The new width. * @param height The new height. */ virtual inline void onResize(nxgl_coord_t width, nxgl_coord_t height) { } public: /** * CNxWidget constructor. * * @param pWidgetControl The controllwing widget for the display * @param x The x coordinate of the widget. * @param y The y coordinate of the widget. * @param width The width of the widget. * @param height The height of the widget. * @param flags Bitmask specifying some set-up values for the widget. * @param style The style that the button should use. If this is not * specified, the button will use the global default widget * style. * @see WidgetFlagType. */ CNxWidget(CWidgetControl *pWidgetControl, nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t width, nxgl_coord_t height, uint32_t flags, FAR const CWidgetStyle *style = (FAR const CWidgetStyle *)NULL); /** * Destructor. */ virtual ~CNxWidget(void); /** * Get the x coordinate of the widget in "Widget space". * * @return Widget space x coordinate. */ const nxgl_coord_t getX(void) const; /** * Get the y coordinate of the widget in "Widget space". * * @return Widget space y coordinate. */ const nxgl_coord_t getY(void) const; /** * Get the x coordinate of the widget relative to its parent. * * @return Parent-space x coordinate. */ const nxgl_coord_t getRelativeX(void) const; /** * Get the y coordinate of the widget relative to its parent. * * @return Parent-space y coordinate. */ const nxgl_coord_t getRelativeY(void) const; /** * Get the reference constant for this widget. * @return The reference constant. */ inline const uint32_t getRefcon(void) const { return m_refcon; } /** * Get the type of close routine that should be called by other widgets * interacting with this widget. * * @return The close type of this widget. */ inline const CloseType getCloseType(void) { return m_closeType; } /** * Is the widget active? * A value of true indicates that this widget has focus or is an ancestor * of the widget with focus. * * @return True if active. */ inline const bool hasFocus(void) const { return m_flags.hasFocus; } /** * Has the widget been marked for deletion? This function recurses up the widget * hierarchy and only returns true if all of the widgets in the ancestor * chain are not deleted. * * Widgets marked for deletion are automatically deleted and should not be * interacted with. * * @return True if marked for deletion. */ const bool isDeleted(void) const; /** * Is the widget allowed to draw? This function recurses up the widget * hierarchy and only returns true if all of the widgets in the ancestor * chain are visible. * * @return True if drawing is enabled. */ const bool isDrawingEnabled(void) const; /** * Is the widget hidden? This function recurses up the widget * hierarchy and returns true if any of the widgets in the ancestor * chain are hidden. * * @return True if hidden. */ const bool isHidden(void) const; /** * Is the widget enabled? This function recurses up the widget * hierarchy and only returns true if all of the widgets in the ancestor * chain are enabled. * * @return True if enabled. */ const bool isEnabled(void) const; /** * Are the widget's edges permeable or solid? * Permeable widgets do not enforce their dimensions on the * coordinates and dimensions of child widgets. * * @return True if permeable. */ inline const bool isPermeable(void) const { return m_flags.permeable; } /** * IS the widget double-clickable? * @return True if the widget watches for double-clicks. */ inline const bool isDoubleClickable(void) const { return m_flags.doubleClickable; } /** * Does the widget have a border? * * @return True if the widget does not have a border. */ inline const bool isBorderless(void) const { return m_flags.borderless; } /** * Is the widget clicked? * * @return True if the widget is currently clicked. */ inline const bool isClicked(void) const { return m_flags.clicked; } /** * Is the widget being dragged? * * @return True if the widget is currently being dragged. */ inline const bool isBeingDragged(void) const { return m_flags.dragging; } /** * Is the widget shelved? * * @return True if the widget is shelved. */ inline const bool isShelved(void) const { return m_flags.shelved; } /** * Is the widget modal? Only true if the Widget singleton is also modal. * * @return True if the widget is modal. */ const bool isModal(void) const; /** * Get the width of the widget. * * @return The widget width. */ inline nxgl_coord_t getWidth(void) const { return m_rect.getWidth(); } /** * Get the height of the widget. * * @return The widget height. */ inline nxgl_coord_t getHeight(void) const { return m_rect.getHeight(); } /** * Get the dimensions of the border * */ inline void getBorderSize(WidgetBorderSize &borderSize) { borderSize.top = m_borderSize.top; borderSize.left = m_borderSize.left; borderSize.bottom = m_borderSize.bottom; borderSize.right = m_borderSize.right; } /** * Get a pointer to this widget's parent. * * @return This widget's parent. */ inline CNxWidget *getParent(void) const { return m_parent; } /** * Get a pointer to this widget's focused child. * * @return This widget's focused child. */ inline CNxWidget *getFocusedWidget(void) { return m_focusedChild; } /** * Check if this widget raises events or not. * * @return True if events are enabled. */ inline const bool raisesEvents(void) const { return m_widgetEventHandlers->isEnabled(); } /** * Insert the dimensions that this widget wants to have into the rect * passed in as a parameter. All coordinates are relative to the widget's * parent. * * @param rect Reference to a rect to populate with data. */ virtual void getPreferredDimensions(CRect &rect) const; /** * Insert the properties of the space within this widget that is * available for children into the rect passed in as a parameter. * All coordinates are relative to this widget. * * @param rect Reference to a rect to populate with data. */ void getClientRect(CRect &rect) const; /** * Insert the properties of the space within this widget that is * available for children into the rect passed in as a parameter. * Identical to getClientRect() except that all coordinates are * absolute positions within the window. * * @param rect Reference to a rect to populate with data. */ void getRect(CRect &rect) const; /** * Clips the supplied rect to the boundaries defined by this widget and * this widget's parents. * * @param rect Reference to a rect to populate with data. */ void getRectClippedToHierarchy(CRect &rect) const; /** * Gets a pointer to the vector of all of the visible regions of this widget, * including any covered by children. * * @return A pointer to a vector of all visible regions. */ TNxArray *getForegroundRegions(void); /** * Gets a pointer to the widget's font. * * @return A pointer to the widget's font. */ inline CNxFont *getFont(void) const { return m_style.font; } /** * Gets the color used for the normal background fill. * * @return Background fill color. */ inline const nxgl_mxpixel_t getBackgroundColor(void) const { return m_style.colors.background; } /** * Gets the color used for the background fill when the widget is selected. * * @return Dark color. */ inline const nxgl_mxpixel_t getSelectedBackgroundColor(void) const { return m_style.colors.selectedBackground; } /** * Gets the color used as the light edge in bevelled boxes. * * @return Shine color. */ inline const nxgl_mxpixel_t getShineEdgeColor(void) const { return m_style.colors.shineEdge; } /** * Gets the color used as the dark edge in bevelled boxes. * * @return Shadow color. */ inline const nxgl_mxpixel_t getShadowEdgeColor(void) const { return m_style.colors.shadowEdge; } /** * Gets the color used as the fill in focused window borders. * * @return Highlight color. */ inline const nxgl_mxpixel_t getHighlightColor(void) const { return m_style.colors.highlight; } /** * Gets the color used for text in a disabled widget. * * @return Disabled text color. */ inline const nxgl_mxpixel_t getDisabledTextColor(void) const { return m_style.colors.disabledText; } /** * Gets the color used for text in a enabled widget. * * @return Enabled text color. */ inline const nxgl_mxpixel_t getEnabledTextColor(void) const { return m_style.colors.enabledText; } /** * Gets the color used for text in a clicked widget. * * @return Selected text color. */ inline const nxgl_mxpixel_t getSelectedTextColor(void) const { return m_style.colors.selectedText; } /** * Sets this widget's reference constant. This should be unique, * at least amongst this widget's siblings. * * @param refcon The reference constant. */ uint32_t setRefcon(uint32_t refcon); /** * Sets this widget's border state. * * @param isBorderless The border state. */ void setBorderless(bool isBorderless); /** * Sets whether or not this widget can be dragged. * * @param isDraggable The draggable state. */ inline void setDraggable(const bool isDraggable) { m_flags.draggable = isDraggable; } /** * Sets whether or not child widgets can exceed this widget's dimensions. * * @param permeable The permeable state. */ inline void setPermeable(const bool permeable) { m_flags.permeable = permeable; } /** * Sets whether or not the widgets processes double-clicks. * * @param doubleClickable The double-clickable state. */ inline void setDoubleClickable(const bool doubleClickable) { m_flags.doubleClickable = doubleClickable; } /** * Adds a widget event handler. The event handler will receive * all events raised by this widget. * * @param eventHandler A pointer to the event handler. */ inline void addWidgetEventHandler(CWidgetEventHandler *eventHandler) { m_widgetEventHandlers->addWidgetEventHandler(eventHandler); } /** * Remove a widget event handler. * * @param eventHandler A pointer to the event handler to remove. */ inline void removeWidgetEventHandler(CWidgetEventHandler* eventHandler) { m_widgetEventHandlers->removeWidgetEventHandler(eventHandler); } /** * Enables or disables event firing for this widget. * * @param raises True to enable events, false to disable. */ inline void setRaisesEvents(const bool raises) { raises ? m_widgetEventHandlers->enable() : m_widgetEventHandlers->disable(); } /** * Disabled drawing of this widget. Widgets hidden using this method will still * be processed. */ inline void disableDrawing(void) { m_flags.drawingEnabled = false; } /** * Enables drawing of this widget. */ inline void enableDrawing(void) { m_flags.drawingEnabled = true; } /** * Sets the normal background color. * * @param color The new background color. */ inline void setBackgroundColor(const nxgl_mxpixel_t color) { m_style.colors.background = color; } /** * Sets the background color for a selected widget. * * @param color The new selected background color. */ inline void setSelectedBackgroundColor(const nxgl_mxpixel_t color) { m_style.colors.selectedBackground = color; } /** * Sets the shiny edge color. * * @param color The new shine edge color. */ inline void setShineEdgeColor(const nxgl_mxpixel_t color) { m_style.colors.shineEdge = color; } /** * Sets the shadow edge color. * * @param color The new shadow edge color. */ inline void setShadowEdgeColor(const nxgl_mxpixel_t color) { m_style.colors.shadowEdge = color; } /** * Sets the highlight color. * * @param color The new highlight color. */ inline void setHighlightColor(const nxgl_mxpixel_t color) { m_style.colors.highlight = color; } /** * Sets the text color to use when the widget is disabled. * * @param color The new text color. */ inline void setDisabledTextColor(const nxgl_mxpixel_t color) { m_style.colors.disabledText = color; } /** * Sets the text color to use when the widget is enabled. * * @param color The new text color. */ inline void setEnabledTextColor(const nxgl_mxpixel_t color) { m_style.colors.enabledText = color; } /** * Sets the text color to use when the widget is highlighted or clicked. * * @param color The new selected text color. */ inline void setSelectedTextColor(const nxgl_mxpixel_t color) { m_style.colors.selectedText = color; } /** * Sets the close type other widgets should use when closing this widget. * * @param closeType The close type to use. */ inline void setCloseType(const CloseType closeType) { m_closeType = closeType; } /** * Sets the font. * * @param font A pointer to the font to use. */ virtual void setFont(CNxFont *font); /** * Draws the visible regions of the widget and the widget's child widgets. */ void redraw(void); /** * Erases the visible regions of the widget by redrawing the widgets * behind it. */ void erase(void); /** * Enables the widget. * * @return True if the widget was enabled. */ bool enable(void); /** * Disabled the widget. * * @return True if the widget was disabled. */ bool disable(void); /** * Erases the widget, marks it as deleted, and moves it to the CNxWidget * deletion queue. Widgets are automatically deleted by the framework and * should not be deleted externally. */ void close(void); /** * Erases the widget, removes it from the main hierarchy and sets it to * invisible. Widgets hidden in this way will be partioned off from * other widgets and will no longer be processed. * * @return True if the widget was shelved. * @see unshelve() */ bool shelve(void); /** * Moves the widget back into the hierarchy and redraws it. Widgets shown * in this way will be unpartioned and will be processed again. * * @return True if the widget was unshelved. * @see shelve() */ bool unshelve(void); /** * Draws the widget and makes it visible. * Does not steal focus from other widgets. * * @return True if the widget was shown. * @see hide() */ bool show(void); /** * Erases the widget and makes it invisible. * Does not re-assign focus to another widget. * * @return True if the widget was hidden. * @see show() */ bool hide(void); /** * Click this widget at the supplied coordinates. This should only be * overridden in subclasses if the default click behaviour needs to be changed. * If the subclassed widget should just respond to a standard click, * the onClick() method should be overridden instead. * * @param x X coordinate of the click. * @param y Y coordinate of the click. * @return True if the click was successful. */ bool click(nxgl_coord_t x, nxgl_coord_t y); /** * Check if the click is a double-click. * * @param x X coordinate of the click. * @param y Y coordinate of the click. * @return True if the click is a double-click. */ virtual bool isDoubleClick(nxgl_coord_t x, nxgl_coord_t y); /** * Double-click this widget at the supplied coordinates. This * should only be overridden in subclasses if the default * double-click behaviour needs to be changed. If the subclassed * widget should just respond to a standard double-click, the * onDoubleClick() method should be overridden instead. * * @param x X coordinate of the click. * @param y Y coordinate of the click. * @return True if the click was successful. */ bool doubleClick(nxgl_coord_t x, nxgl_coord_t y); /** * Release this widget at the supplied coordinates. This * should only be overridden in subclasses if the default * release behaviour needs to be changed. If the subclassed * widget should just respond to a standard release, the * onRelease() method should be overridden instead. * * @param x X coordinate of the release. * @param y Y coordinate of the release. * @return True if the release was successful. */ bool release(nxgl_coord_t x, nxgl_coord_t y); /** * Drag the widget to the supplied coordinates. * * @param x The x coordinate of the mouse. * @param y The y coordinate of the mouse. * @param vX The horizontal distance that the mouse was dragged. * @param vY The vertical distance that the mouse was dragged. * @return True if the drag was successful. */ bool drag(nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t vX, nxgl_coord_t vY); /** * Send a keypress to the widget. * * @param key The keycode to send to the widget. * @return True if the keypress was processed. */ bool keyPress(nxwidget_char_t key); /** * Send a cursor control event to the widget. * * @param control The cursor control code to send to the widget. * @return True if the cursor control was processed. */ bool cursorControl(ECursorControl control); /** * Give the widget focus. * * @return True if the widget received focus correctly. */ bool focus(void); /** * Remove focus from the widget. * * @return True if the widget lost focus correctly. */ bool blur(void); /** * Move the widget to the new coordinates. * Co-ordinates are relative to the parent widget. * * @param x The new x coordinate. * @param y The new y coordinate. * @return True if the move was successful. */ bool moveTo(nxgl_coord_t x, nxgl_coord_t y); /** * Resize the widget to the new dimensions. * * @param width The new width. * @param height The new height. * @return True if the resize was successful. */ bool resize(nxgl_coord_t width, nxgl_coord_t height); /** * Resize and move the widget in one operation. * Only performs one redraw so it is faster than calling the * two separate functions. * * @param x The new x coordinate. * @param y The new y coordinate. * @param width The new width. * @param height The new height. * @return True if the widget was adjusted successfully. */ bool changeDimensions(nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t width, nxgl_coord_t height); /** * Raises the widget to the top of its parent's widget stack. * * @return True if the raise was successful. */ bool raiseToTop(void); /** * Lowers the widget to the bottom of its parent's widget stack. * * @return True if the lower was successful. */ bool lowerToBottom(void); /** * Raises the supplied widget to the top of this widget's child stack. * The supplied widget pointer must be a child of this widget. * * @param widget A pointer to the child widget to raise. * @return True if the raise was successful. */ bool raiseWidgetToTop(CNxWidget *widget); /** * Lowers the supplied widget to the bottom of this widget's child stack. * The supplied widget pointer must be a child of this widget. * * @param widget A pointer to the child widget to lower. * @return True if the lower was successful. */ bool lowerWidgetToBottom(CNxWidget *widget); /** * Moves the supplied child widget to the deletion queue. * For framework use only. * * @param widget A pointer to the child widget. */ void moveChildToDeleteQueue(CNxWidget *widget); /** * Moves the supplied child widget to the shelved widget list. * For framework use only. * * @param widget A pointer to the child widget. * @return True if the widget was moved successfully. * @see moveShelvedToChildList() * @see hide() */ bool moveChildToShelvedList(CNxWidget *widget); /** * Moves the supplied child widget from the shelved list back * to the child widget list. * For framework use only. * * @param widget A pointer to the shelved widget. * @return True if the widget was moved successfully. * @see moveChildtoShelvedList() * @see show() */ bool moveShelvedToChildList(CNxWidget *widget); /** * Sets the supplied widget as the focused child. The widget must * be a child of this widget. * * @param widget A pointer to the child widget. * @see getFocusedWidget() */ void setFocusedWidget(CNxWidget *widget); /** * Checks if the supplied coordinates collide with this widget. * * @param x The x coordinate to check. * @param y The y coordinate to check. * @return True if a collision occurred. */ bool checkCollision(nxgl_coord_t x, nxgl_coord_t y) const; /** * Checks if the supplied rectangle definition collides with this widget. * * @param x The x coordinate of the rectangle to check. * @param y The y coordinate of the rectangle to check. * @param width The width of the rectangle to check. * @param height The height of the rectangle to check. * @return True if a collision occurred. */ bool checkCollision(nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t width, nxgl_coord_t height) const; /** * Checks if the supplied widget collides with this widget. * * @param widget A pointer to another widget to check for collisions with. * @return True if a collision occurred. */ bool checkCollision(CNxWidget *widget) const; /** * Invalidate the visible region cache for all widgets below the supplied * widget in this widget's child stack. This will cause those widgets to * * recalculate their visible regions next time they try to draw themselves. * @param widget A pointer to a child widget. */ void invalidateLowerWidgetsVisibleRectCache(CNxWidget *widget); /** * Adds a widget to this widget's child stack. The widget is added to the * top of the stack. Note that the widget can only be added if it is not * already a child of another widget. * * @param widget A pointer to the widget to add to the child list. * @see insertWidget() */ void addWidget(CNxWidget *widget); /** * Inserts a widget into this widget's child stack at the bottom of the * stack. Note that the widget can only be added if it is not already * a child of another widget. * * @param widget A pointer to the widget to add to the child list. * @see addWidget() */ void insertWidget(CNxWidget *widget); /** * Set the widget's parent to the widget passed in as a parameter. * Called automatically when a widget is added as a child. * * @param parent A pointer to the parent widget. */ inline void setParent(CNxWidget *parent) { m_parent = parent; } /** * Rebuild the list of this widget's visible regions */ void cacheVisibleRects(void) const; /** * Mark this widget's visible region cache as invalid, and do the same * to its child widgets. */ void invalidateVisibleRectCache(void); /** * Erase a child widget by drawing the widgets behind it. * * @param widget The child widget to erase. */ void eraseWidget(CNxWidget *widget); /** * Redraw any visible regions of this widget that have become corrupted. * * @param invalidRects A list of corrupt regions. * @param sender A pointer to the widget that corrupted the regions. */ void redrawDirty(TNxArray* invalidRects, CNxWidget *sender); /** * Clips a rectangular region to the dimensions of this widget and its ancestors. * * @param rect The region that needs to be clipped. */ void clipRectToHierarchy(CRect &rect) const; /** * Swaps the depth of the supplied child widget. * * @param widget A pointer to the child widget that needs to swap depths. * @return True if the swap was successful. */ virtual bool swapWidgetDepth(CNxWidget *widget); /** * Swap the depth of this widget. * * @return True if the swap was successful. */ bool swapDepth(void); /** * Delete this widget. This should never be called in user code; widget * deletion is handled internally. */ inline void destroy(void) { delete this; } /** * Remove this widget from the widget hierarchy. Returns * responsibility for deleting the widget back to the developer. * Does not unregister the widget from the VBL system. * Does not erase the widget from the display. * * @return True if the widget was successfully removed. */ bool remove(void); /** * Remove a child widget from the widget hierarchy. Returns * responsibility for deleting the widget back to the developer. * Does not unregister the widget from the VBL system. * Does not erase the widget from the display. * * @param widget Pointer to the widget to remove from the hierarchy. * @return True if the widget was succesfully removed. */ bool removeChild(CNxWidget *widget); /** * Run the widget modally. */ void goModal(void); /** * Stop the widget running modally. */ inline void stopModal(void) { m_flags.modal = false; } /** * Get the index of the specified child widget. * * @param widget The widget to get the index of. * @return The index of the widget. -1 if the widget is not found. */ const int getWidgetIndex(const CNxWidget *widget) const; /** * Get the child widget at the specified index. * * @param index Index of the child to retrieve. * @return Pointer to the child at the specified index. */ const CNxWidget *getChild(int index) const; /** * Get the number of child widgets. * * @return The number of child widgets belonging to this widget. */ const int getChildCount(void) const { return m_children.size(); } /** * Get a pointer to the cache of visible rects. * * @return A pointer to the cache of visible rects. */ inline CRectCache *getCRectCache(void) const { return m_rectCache; } /** * Sets the border size. The border cannot be drawn over in the * drawContents() method. * * @param borderSize The new border size. */ void setBorderSize(const WidgetBorderSize &borderSize); }; } #endif // __cplusplus #endif // __INCLUDE_CNXWIDGET_HXX