/**************************************************************************** * apps/include/graphics/nxwidgets/cscaledbitmap.hxx * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. The * ASF licenses this file to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance with the * License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. * ****************************************************************************/ #ifndef __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CSCALEDBITMAP_HXX #define __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CSCALEDBITMAP_HXX /**************************************************************************** * Included Files ****************************************************************************/ #include #include #include #include #include #include #include #include "graphics/nxwidgets/nxconfig.hxx" #include "graphics/nxwidgets/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 */ unsigned 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 // __APPS_INCLUDE_GRAPHICS_NXWIDGETS_CSCALEDBITMAP_HXX