AbstractPainterRGB565
The AbstractPainterRGB565 class is an abstract class for creating a painter to draw on a RGB565 display using CanvasWidgetRenderer.
See: AbstractPainter
Inherits from: AbstractPainter
Inherited by: PainterRGB565, PainterRGB565Bitmap, PainterRGB565L8Bitmap
Public Functions
| AbstractPainterRGB565() | |
| FORCE_INLINE_FUNCTION uint16_t | mixColors(uint16_t newpix, uint16_t bufpix, uint8_t alpha) | 
| Mix colors from a new pixel and a buffer pixel with the given alpha applied to the new pixel, and the inverse alpha applied to the buffer pixel. | |
| FORCE_INLINE_FUNCTION uint16_t | mixColors(uint16_t R, uint16_t G, uint16_t B, uint16_t bufpix, uint8_t alpha) | 
| Mix colors from a new pixel and a buffer pixel with the given alpha applied to the new pixel, and the inverse alpha applied to the buffer pixel. | |
| virtual void | render(uint8_t ptr, int x, int xAdjust, int y, unsigned count, const uint8_t covers) | 
| Paint a designated part of the RenderingBuffer with respect to the amount of coverage of each pixel given by the parameter covers. | |
Protected Functions
| virtual bool | renderInit() | 
| Initialize rendering of a single scan line of pixels for the render. | |
| virtual bool | renderNext(uint8_t & red, uint8_t & green, uint8_t & blue, uint8_t & alpha) =0 | 
| Get the color of the next pixel in the scan line to blend into the framebuffer. | |
| virtual void | renderPixel(uint16_t * p, uint8_t red, uint8_t green, uint8_t blue) | 
| Renders (writes) the specified color into the framebuffer. | |
Public Attributes
| const uint16_t | BMASK | 
| Mask for blue (0000000000011111) | |
| const uint16_t | GMASK | 
| Mask for green (0000011111100000) | |
| const uint16_t | RMASK | 
| Mask for red (1111100000000000) | |
Protected Attributes
| int | currentX | 
| Current x coordinate relative to the widget. | |
| int | currentY | 
| Current y coordinate relative to the widget. | |
Additional inherited members
Public Functions inherited from AbstractPainter
| AbstractPainter() | |
| Initializes a new instance of the AbstractPainter class. | |
| void | setOffset(uint16_t offsetX, uint16_t offsetY) | 
| Sets the offset of the area being drawn. | |
| virtual | ~AbstractPainter() | 
| Finalizes an instance of the AbstractPainter class. | |
Protected Functions inherited from AbstractPainter
| void | setWidgetAlpha(const uint8_t alpha) | 
| Sets the widget alpha to allow an entire canvas widget to easily be faded without changing the painter of the widget. | |
| FORCE_INLINE_FUNCTION bool | compatibleFramebuffer(Bitmap::BitmapFormat format) | 
| Helper function to check if the provided bitmap format matches the current framebuffer format. | |
Protected Attributes inherited from AbstractPainter
| int16_t | areaOffsetX | 
| The offset x coordinate of the area being drawn. | |
| int16_t | areaOffsetY | 
| The offset y coordinate of the area being drawn. | |
| uint8_t | widgetAlpha | 
| The alpha of the widget using the painter. | |
Public Functions Documentation
AbstractPainterRGB565
mixColors
| FORCE_INLINE_FUNCTION uint16_t mixColors | ( | uint16_t | newpix , | ||
| uint16_t | bufpix , | ||||
| uint8_t | alpha | ||||
| ) | 
Mix colors from a new pixel and a buffer pixel with the given alpha applied to the new pixel, and the inverse alpha applied to the buffer pixel.
| newpix | The new pixel value. | 
| bufpix | The buffer pixel value. | 
| alpha | The alpha to apply to the new pixel. | 
The result of blending the two colors into a new color.
mixColors
| FORCE_INLINE_FUNCTION uint16_t mixColors | ( | uint16_t | R , | ||
| uint16_t | G , | ||||
| uint16_t | B , | ||||
| uint16_t | bufpix , | ||||
| uint8_t | alpha | ||||
| ) | 
Mix colors from a new pixel and a buffer pixel with the given alpha applied to the new pixel, and the inverse alpha applied to the buffer pixel.
| R | The red color (0-31 shifted into RMASK). | 
| G | The green color (0-63 shifted into GMASK). | 
| B | The blue color (0-31 shifted into BMASK). | 
| bufpix | The buffer pixel value. | 
| alpha | The alpha of the R,G,B. | 
The result of blending the two colors into a new color.
render
| virtual void render | ( | uint8_t * | ptr , | ||
| int | x , | ||||
| int | xAdjust , | ||||
| int | y , | ||||
| unsigned | count , | ||||
| const uint8_t * | covers | ||||
| ) | 
Paint a designated part of the RenderingBuffer with respect to the amount of coverage of each pixel given by the parameter covers.
The cover is the alpha for each pixel, which is what makes it possible to have smooth anti-aliased edges on the shapes drawn with CanvasWidgetRenderer.
| ptr | Pointer to the row in the RenderingBuffer. | 
| x | The x coordinate. | 
| xAdjust | The minor adjustment of x (used when a pixel is smaller than a byte to specify that the ptr should have been advanced "xAdjust" pixels futher into the byte). | 
| y | The y coordinate. | 
| count | Number of pixels to fill. | 
| covers | The coverage in of each pixel. | 
Note
The implementation of render() in the AbstractPainter classes is a generic (i.e. slow) implementation that should be completely implemented in subclasses of AbstractPainter for better performance.
Reimplements: touchgfx::AbstractPainter::render
Reimplemented by: touchgfx::PainterRGB565::render, touchgfx::PainterRGB565Bitmap::render, touchgfx::PainterRGB565L8Bitmap::render
Protected Functions Documentation
renderInit
| virtual bool renderInit | ( | ) | 
Initialize rendering of a single scan line of pixels for the render.
If renderInit returns false, the scanline will not be rendered.
true if it succeeds, false if it fails.
Reimplemented by: touchgfx::PainterRGB565Bitmap::renderInit, touchgfx::PainterRGB565L8Bitmap::renderInit
renderNext
| virtual bool renderNext | ( | uint8_t & | red , | =0 | |
| uint8_t & | green , | =0 | |||
| uint8_t & | blue , | =0 | |||
| uint8_t & | alpha | =0 | |||
| ) | =0 | 
Get the color of the next pixel in the scan line to blend into the framebuffer.
| red | The red. | 
| green | The green. | 
| blue | The blue. | 
| alpha | The alpha. | 
true if the pixel should be painted, false otherwise.
Reimplemented by: touchgfx::PainterRGB565::renderNext, touchgfx::PainterRGB565Bitmap::renderNext, touchgfx::PainterRGB565L8Bitmap::renderNext
renderPixel
| virtual void renderPixel | ( | uint16_t * | p , | ||
| uint8_t | red , | ||||
| uint8_t | green , | ||||
| uint8_t | blue | ||||
| ) | 
Renders (writes) the specified color into the framebuffer.
| p | pointer into the framebuffer where the given color should be written. | 
| red | The red color. | 
| green | The green color. | 
| blue | The blue color. | 
Public Attributes Documentation
BMASK
const uint16_t BMASK = 0x001F
Mask for blue (0000000000011111)
GMASK
const uint16_t GMASK = 0x07E0
Mask for green (0000011111100000)
RMASK
const uint16_t RMASK = 0xF800
Mask for red (1111100000000000)
Protected Attributes Documentation
currentX
int currentX
Current x coordinate relative to the widget.
currentY
int currentY
Current y coordinate relative to the widget.