summaryrefslogtreecommitdiff
path: root/NxWidgets/libnxwidgets/include/cscaledbitmap.hxx
blob: 48afd5306b174caec107c74b94d28ff01d91c049 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
/****************************************************************************
 * NxWidgets/libnxwidgets/include/cscaledbitmap.hxx
 *
 *   Copyright (C) 2013 Gregory Nutt. All rights reserved.
 *   Author: Gregory Nutt <gnutt@nuttx.org>
 *
 * 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.
 *
 ****************************************************************************/

#ifndef __INCLUDE_CSCALEDBITMAP_HXX
#define __INCLUDE_CSCALEDBITMAP_HXX

/****************************************************************************
 * Included Files
 ****************************************************************************/

#include <nuttx/config.h>

#include <stdint.h>
#include <stdbool.h>
#include <fixedmath.h>
#include <debug.h>

#include <nuttx/video/rgbcolors.h>
#include <nuttx/nx/nxglib.h>

#include "nxconfig.hxx"
#include "ibitmap.hxx"

/****************************************************************************
 * Pre-Processor Definitions
 ****************************************************************************/

/****************************************************************************
 * Implementation Classes
 ****************************************************************************/

#if defined(__cplusplus)

namespace NXWidgets
{
  /**
   * Class for scaling layer for any bitmap that inherits from IBitMap
   */

  class CScaledBitmap : public IBitmap
  {
  protected:
    FAR IBitmap       *m_bitmap;      /**< The bitmap that is being scaled */
    struct nxgl_size_s m_size;        /**< Scaled size of the image */
    FAR uint8_t       *m_rowCache[2]; /**< Two cached rows of the image */
    int                m_row;         /**< Row number of the first cached row */
    b16_t              m_xScale;      /**< X scale factor */
    b16_t              m_yScale;      /**< Y scale factor */

    /**
     * Read two rows into the row cache
     *
     * @param row - The row number of the first row to cache
     */

    bool cacheRows(unsigned int row);

    /**
     * Given an two RGB colors and a fractional value, return the scaled
     * value between the two colors.
     *
     * @param incolor1 - The first color to be used
     * @param incolor2 - The second color to be used
     * @param fraction - The fractional value
     * @param outcolor - The returned, scaled color
     */

    bool scaleColor(FAR const struct rgbcolor_s &incolor1,
                    FAR const struct rgbcolor_s &incolor2,
                    b16_t fraction, FAR struct rgbcolor_s &outcolor);

    /**
     * Given an image row and a non-integer column offset, return the
     * interpolated RGB color value corresponding to that position
     *
     * @param row - The pointer to the row in the row cache to use
     * @param column - The non-integer column offset
     * @param outcolor - The returned, interpolated color
     * 
     */

    bool rowColor(FAR uint8_t *row, b16_t column,
                  FAR struct rgbcolor_s &outcolor);

    /**
     * Copy constructor is protected to prevent usage.
     */

    inline CScaledBitmap(const CScaledBitmap &bitmap) { }

  public:

    /**
     * Constructor.
     *
     * @param bitmap The bitmap structure being scaled.
     * @newSize The new, scaled size of the image
     */

    CScaledBitmap(IBitmap *bitmap, struct nxgl_size_s &newSize);

    /**
     * Destructor.
     */

    ~CScaledBitmap(void);

    /**
     * Get the bitmap's color format.
     *
     * @return The bitmap's color format.
     */

    const uint8_t getColorFormat(void) const;

    /**
     * Get the bitmap's color format.
     *
     * @return The bitmap's pixel depth.
     */

    const uint8_t getBitsPerPixel(void) const;

    /**
     * Get the bitmap's width (in pixels/columns).
     *
     * @return The bitmap's width (in pixels/columns).
     */

    const nxgl_coord_t getWidth(void) const;

    /**
     * Get the bitmap's height (in rows).
     *
     * @return The bitmap's height (in rows).
     */

    const nxgl_coord_t getHeight(void) const;

    /**
     * Get the bitmap's width (in bytes).
     *
     * @return The bitmap's width (in bytes).
     */

    const size_t getStride(void) const;

    /**
     * Use the colors associated with a selected image.
     *
     * @param selected.  true: Use colors for a selected widget,
     *   false: Use normal (default) colors.
     */

    inline void setSelected(bool selected) {}

    /**
     * Get one row from the bit map image.
     *
     * @param x The offset into the row to get
     * @param y The row number to get
     * @param width The number of pixels to get from the row
     * @param data The memory location provided by the caller
     *   in which to return the data.  This should be at least
     *   (getWidth()*getBitsPerPixl() + 7)/8 bytes in length
     *   and properly aligned for the pixel color format.
     * @param True if the run was returned successfully.
     */

    bool getRun(nxgl_coord_t x, nxgl_coord_t y, nxgl_coord_t width,
                FAR void *data);
  };
}

#endif // __cplusplus

#endif // __INCLUDE_CSCALEDBITMAP_HXX