cprogressbar.hxx 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. /****************************************************************************
  2. * apps/include/graphics/nxwidgets/cprogressbar.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_CPROGRESSBAR_HXX
  56. #define __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CPROGRESSBAR_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/cnxwidget.hxx"
  65. /****************************************************************************
  66. * Pre-Processor Definitions
  67. ****************************************************************************/
  68. /****************************************************************************
  69. * Implementation Classes
  70. ****************************************************************************/
  71. #if defined(__cplusplus)
  72. namespace NXWidgets
  73. {
  74. /**
  75. * Forward references
  76. */
  77. class CWidgetControl;
  78. /**
  79. * Widget providing a horizontal progress bar.
  80. */
  81. class CProgressBar : public CNxWidget
  82. {
  83. protected:
  84. int16_t m_minimumValue; /**< Minimum value that the grip can represent. */
  85. int16_t m_maximumValue; /**< Maximum value that the grip can represent. */
  86. int16_t m_value; /**< Value of the progress bar. */
  87. bool m_showPercentageText; /**< If true, completion percentage is drawn
  88. over the bar. */
  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. * Copy constructor is protected to prevent usage.
  107. */
  108. inline CProgressBar(const CProgressBar &progressBar) : CNxWidget(progressBar) { }
  109. public:
  110. /**
  111. * Constructor.
  112. *
  113. * @param pWidgetControl The widget control for the display.
  114. * @param x The x coordinate of the progress bar, relative to its parent.
  115. * @param y The y coordinate of the progress bar, relative to its parent.
  116. * @param width The width of the progress bar.
  117. * @param height The height of the progress bar.
  118. */
  119. CProgressBar(CWidgetControl *pWidgetControl,
  120. nxgl_coord_t x, nxgl_coord_t y,
  121. nxgl_coord_t width, nxgl_coord_t height);
  122. /**
  123. * Destructor.
  124. */
  125. virtual inline ~CProgressBar(void) { }
  126. /**
  127. * Get the smallest value that the progress bar can represent.
  128. *
  129. * @return The smallest value.
  130. */
  131. inline const int16_t getMinimumValue(void) const
  132. {
  133. return m_minimumValue;
  134. }
  135. /**
  136. * Get the largest value that the progress bar can represent.
  137. *
  138. * @return The largest value.
  139. */
  140. inline const int16_t getMaximumValue(void) const
  141. {
  142. return m_maximumValue;
  143. }
  144. /**
  145. * Get the current value of the progress bar.
  146. * return The current progress bar value.
  147. */
  148. inline const int16_t getValue(void) const
  149. {
  150. return m_value;
  151. }
  152. /**
  153. * Set the smallest value that the progress bar can represent.
  154. *
  155. * @param value The smallest value.
  156. */
  157. inline void setMinimumValue(const int16_t value)
  158. {
  159. m_minimumValue = value;
  160. }
  161. /**
  162. * Set the largest value that the progress bar can represent.
  163. *
  164. * @param value The largest value.
  165. */
  166. inline void setMaximumValue(const int16_t value)
  167. {
  168. m_maximumValue = value;
  169. }
  170. /**
  171. * Set the value that of the progress bar.
  172. *
  173. * @param value The new value.
  174. */
  175. void setValue(const int16_t value);
  176. /**
  177. * Shows the percentage text over the bar.
  178. */
  179. inline void showPercentageText(void)
  180. {
  181. m_showPercentageText = true;
  182. redraw();
  183. }
  184. /**
  185. * Hides the percentage text over the bar.
  186. */
  187. inline void hidePercentageText(void)
  188. {
  189. m_showPercentageText = false;
  190. redraw();
  191. }
  192. };
  193. }
  194. #endif // __cplusplus
  195. #endif // __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CPROGRESSBAR_HXX