ibitmap.hxx 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. /****************************************************************************
  2. * apps/include/graphics/nxwidgets/ibitmap.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_IBITMAP_HXX
  56. #define __APPS_INCLUDE_GRAPHICS_NXWIDGETS_IBITMAP_HXX
  57. /****************************************************************************
  58. * Included Files
  59. ****************************************************************************/
  60. #include <nuttx/config.h>
  61. #include <sys/types.h>
  62. #include <stdint.h>
  63. #include <stdbool.h>
  64. #include <nuttx/nx/nxglib.h>
  65. /****************************************************************************
  66. * Pre-Processor Definitions
  67. ****************************************************************************/
  68. /****************************************************************************
  69. * Implementation Classes
  70. ****************************************************************************/
  71. #if defined(__cplusplus)
  72. namespace NXWidgets
  73. {
  74. /**
  75. * Abstract class defining the basic properties of a source bitmap. The
  76. * primary intent of this class is two support a variety of sources of
  77. * bitmap data with various kinds of compression.
  78. */
  79. class IBitmap
  80. {
  81. public:
  82. /**
  83. * A virtual destructor is required in order to override the IBitmap
  84. * destructor. We do this because if we delete IBitmap, we want the
  85. * destructor of the class that inherits from IBitmap to run, not this
  86. * one.
  87. */
  88. virtual ~IBitmap(void) { }
  89. /**
  90. * Get the bitmap's color format.
  91. *
  92. * @return The bitmap's color format.
  93. */
  94. virtual const uint8_t getColorFormat(void) const = 0;
  95. /**
  96. * Get the bitmap's color format.
  97. *
  98. * @return The bitmap's color format.
  99. */
  100. virtual const uint8_t getBitsPerPixel(void) const = 0;
  101. /**
  102. * Get the bitmap's width (in pixels/columns).
  103. *
  104. * @return The bitmap's width (in pixels/columns).
  105. */
  106. virtual const nxgl_coord_t getWidth(void) const = 0;
  107. /**
  108. * Get the bitmap's height (in rows).
  109. *
  110. * @return The bitmap's height (in rows).
  111. */
  112. virtual const nxgl_coord_t getHeight(void) const = 0;
  113. /**
  114. * Get the bitmap's width (in bytes).
  115. *
  116. * @return The bitmap's width.
  117. */
  118. virtual const size_t getStride(void) const = 0;
  119. /**
  120. * Use the colors associated with a selected image.
  121. *
  122. * @param selected. true: Use colors for a selected widget,
  123. * false: Use normal (default) colors.
  124. */
  125. virtual void setSelected(bool selected) = 0;
  126. /**
  127. * Get one row from the bit map image using the selected colors.
  128. *
  129. * @param x The offset into the row to get
  130. * @param y The row number to get
  131. * @param width The number of pixels to get from the row
  132. * @param data The memory location provided by the caller
  133. * in which to return the data. This should be at least
  134. * (getWidth()*getBitsPerPixl() + 7)/8 bytes in length
  135. * and properly aligned for the pixel color format.
  136. * @param True if the run was returned successfully.
  137. */
  138. virtual bool getRun(nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t width,
  139. FAR void *data) = 0;
  140. };
  141. }
  142. #endif // __cplusplus
  143. #endif // __APPS_INCLUDE_GRAPHICS_NXWIDGETS_IBITMAP_HXX