cstickybutton.hxx 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /****************************************************************************
  2. * apps/include/graphics/nxwidgets/cstickybutton.hxx
  3. *
  4. * Licensed to the Apache Software Foundation (ASF) under one or more
  5. * contributor license agreements. See the NOTICE file distributed with
  6. * this work for additional information regarding copyright ownership. The
  7. * ASF licenses this file to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance with the
  9. * License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing, software
  14. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  15. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  16. * License for the specific language governing permissions and limitations
  17. * under the License.
  18. *
  19. ****************************************************************************/
  20. /****************************************************************************
  21. *
  22. * Portions of this package derive from Woopsi (http://woopsi.org/) and
  23. * portions are original efforts. It is difficult to determine at this
  24. * point what parts are original efforts and which parts derive from Woopsi.
  25. * However, in any event, the work of Antony Dzeryn will be acknowledged
  26. * in most NxWidget files. Thanks Antony!
  27. *
  28. * Copyright (c) 2007-2011, Antony Dzeryn
  29. * All rights reserved.
  30. *
  31. * Redistribution and use in source and binary forms, with or without
  32. * modification, are permitted provided that the following conditions are met:
  33. *
  34. * * Redistributions of source code must retain the above copyright
  35. * notice, this list of conditions and the following disclaimer.
  36. * * Redistributions in binary form must reproduce the above copyright
  37. * notice, this list of conditions and the following disclaimer in the
  38. * documentation and/or other materials provided with the distribution.
  39. * * Neither the names "Woopsi", "Simian Zombie" nor the
  40. * names of its contributors may be used to endorse or promote products
  41. * derived from this software without specific prior written permission.
  42. *
  43. * THIS SOFTWARE IS PROVIDED BY Antony Dzeryn ``AS IS'' AND ANY
  44. * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  45. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  46. * DISCLAIMED. IN NO EVENT SHALL Antony Dzeryn BE LIABLE FOR ANY
  47. * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  48. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  49. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  50. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  51. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  52. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  53. *
  54. ****************************************************************************/
  55. #ifndef __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CSTICKYBUTTON_HXX
  56. #define __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CSTICKYBUTTON_HXX
  57. /****************************************************************************
  58. * Included Files
  59. ****************************************************************************/
  60. #include <nuttx/config.h>
  61. #include <stdint.h>
  62. #include <stdbool.h>
  63. #include <nuttx/nx/nxglib.h>
  64. #include "graphics/nxwidgets/cbutton.hxx"
  65. #include "graphics/nxwidgets/cwidgetstyle.hxx"
  66. /****************************************************************************
  67. * Pre-Processor Definitions
  68. ****************************************************************************/
  69. /****************************************************************************
  70. * Implementation Classes
  71. ****************************************************************************/
  72. #if defined(__cplusplus)
  73. namespace NXWidgets
  74. {
  75. class CWidgetControl;
  76. /**
  77. * CButton that sticks down when clicked.
  78. */
  79. class CStickyButton : public CButton
  80. {
  81. protected:
  82. bool m_isStuckDown; /**< True if the key is stuck down */
  83. /**
  84. * Draws the outline of the button.
  85. *
  86. * @param port Graphics port to draw to.
  87. */
  88. virtual void drawOutline(CGraphicsPort *port);
  89. /**
  90. * Draw the area of this widget that falls within the clipping region.
  91. * Called by the redraw() function to draw all visible regions.
  92. *
  93. * @param port The CGraphicsPort to draw to.
  94. * @see redraw()
  95. */
  96. virtual void drawContents(CGraphicsPort *port);
  97. /**
  98. * Draw the area of this widget that falls within the clipping region.
  99. * Called by the redraw() function to draw all visible regions.
  100. *
  101. * @param port The CGraphicsPort to draw to.
  102. * @see redraw()
  103. */
  104. virtual void drawBorder(CGraphicsPort *port);
  105. /**
  106. * Don't redraw on button press events. The button display is
  107. * completely controlled by the externally controlled stuck state.
  108. *
  109. * @param x The x coordinate of the click.
  110. * @param y The y coordinate of the click.
  111. */
  112. virtual void onClick(nxgl_coord_t x, nxgl_coord_t y) {}
  113. /**
  114. * Don't redraw on button release events. The button display is
  115. * completely controlled by the externally controlled stuck state.
  116. *
  117. * @param x The x coordinate of the mouse.
  118. * @param y The y coordinate of the mouse.
  119. */
  120. virtual void onRelease(nxgl_coord_t x, nxgl_coord_t y) { }
  121. /**
  122. * Don't redraw on button release events. The button display is
  123. * completely controlled by the externally controlled stuck state.
  124. *
  125. * @param x The x coordinate of the mouse.
  126. * @param y The y coordinate of the mouse.
  127. */
  128. virtual void onReleaseOutside(nxgl_coord_t x, nxgl_coord_t y) { }
  129. /**
  130. * Copy constructor is protected to prevent usage. The button display is
  131. * completely controlled by the externally controlled stuck state.
  132. */
  133. inline CStickyButton(const CStickyButton &button) : CButton(button) { }
  134. public:
  135. /**
  136. * Constructor for buttons that display a string.
  137. *
  138. * @param pWidgetControl The controlling widget for the display.
  139. * @param x The x coordinate of the button, relative to its parent.
  140. * @param y The y coordinate of the button, relative to its parent.
  141. * @param width The width of the button.
  142. * @param height The height of the button.
  143. * @param text The text for the button to display.
  144. * @param style The style that the button should use. If this is not
  145. * specified, the button will use the global default widget
  146. * style.
  147. */
  148. CStickyButton(CWidgetControl *pWidgetControl,
  149. nxgl_coord_t x, nxgl_coord_t y,
  150. nxgl_coord_t width, nxgl_coord_t height,
  151. const CNxString &text,
  152. CWidgetStyle *style = (CWidgetStyle *)NULL);
  153. /**
  154. * Destructor.
  155. */
  156. virtual inline ~CStickyButton(void) { }
  157. /**
  158. * Sets the key's stuck down state. If this is true, the key has a
  159. * inwards-bevelled border when drawn. If it is false, the key has
  160. * an outwards-bevelled border.
  161. *
  162. * @param stuckDown The new stuck down state.
  163. */
  164. void setStuckDown(bool stuckDown);
  165. /**
  166. * Toggles the key's stuck down state.
  167. */
  168. inline void toggleStuckDown(void)
  169. {
  170. setStuckDown(!m_isStuckDown);
  171. }
  172. /**
  173. * Returns the stuck down state.
  174. *
  175. * @return True is the button is in the stuck down state.
  176. */
  177. inline const bool isStuckDown(void) const
  178. {
  179. return m_isStuckDown;
  180. }
  181. };
  182. }
  183. #endif // __cplusplus
  184. #endif // __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CSTICKYBUTTON_HXX