Added ability to use printf directly
Fork of LCD_DISCO_F429ZI by
LCD_DISCO_F429ZI.h
- Committer:
- bcostm
- Date:
- 2015-12-17
- Revision:
- 0:dc55a068bc1a
- Child:
- 1:45d79100d676
File content as of revision 0:dc55a068bc1a:
/* Copyright (c) 2010-2011 mbed.org, MIT License * * Permission is hereby granted, free of charge, to any person obtaining a copy of this software * and associated documentation files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all copies or * substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __LCD_DISCO_F429ZI_H #define __LCD_DISCO_F429ZI_H #ifdef TARGET_DISCO_F429ZI #include "mbed.h" #include "stm32f429i_discovery_lcd.h" /* This class drives the LCD display (ILI9341 240x320) present on DISCO_F429ZI board. Usage: #include "mbed.h" #include "LCD_DISCO_F429ZI.h" LCD_DISCO_F429ZI lcd; int main() { lcd.Clear(LCD_COLOR_BLUE); lcd.SetBackColor(LCD_COLOR_BLUE); lcd.SetTextColor(LCD_COLOR_WHITE); lcd.DisplayStringAt(0, LINE(5), (uint8_t *)"HELLO", CENTER_MODE); while(1) { } } */ class LCD_DISCO_F429ZI { public: //! Constructor LCD_DISCO_F429ZI(); //! Destructor ~LCD_DISCO_F429ZI(); /** * @brief Initializes the LCD. * @param None * @retval LCD state */ uint8_t Init(void); /** * @brief Gets the LCD X size. * @param None * @retval The used LCD X size */ uint32_t GetXSize(void); /** * @brief Gets the LCD Y size. * @param None * @retval The used LCD Y size */ uint32_t GetYSize(void); /** * @brief Initializes the LCD layers. * @param LayerIndex: the layer foreground or background. * @param FB_Address: the layer frame buffer. * @retval None */ void LayerDefaultInit(uint16_t LayerIndex, uint32_t FB_Address); /** * @brief Selects the LCD Layer. * @param LayerIndex: the Layer foreground or background. * @retval None */ void SelectLayer(uint32_t LayerIndex); /** * @brief Sets a LCD Layer visible. * @param LayerIndex: the visible Layer. * @param state: new state of the specified layer. * This parameter can be: ENABLE or DISABLE. * @retval None */ void SetLayerVisible(uint32_t LayerIndex, FunctionalState state); /** * @brief Configures the Transparency. * @param LayerIndex: the Layer foreground or background. * @param Transparency: the Transparency, * This parameter must range from 0x00 to 0xFF. * @retval None */ void SetTransparency(uint32_t LayerIndex, uint8_t Transparency); /** * @brief Sets a LCD layer frame buffer address. * @param LayerIndex: specifies the Layer foreground or background * @param Address: new LCD frame buffer value * @retval None */ void SetLayerAddress(uint32_t LayerIndex, uint32_t Address); /** * @brief Sets the Display window. * @param LayerIndex: layer index * @param Xpos: LCD X position * @param Ypos: LCD Y position * @param Width: LCD window width * @param Height: LCD window height * @retval None */ void SetLayerWindow(uint16_t LayerIndex, uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height); /** * @brief Configures and sets the color Keying. * @param LayerIndex: the Layer foreground or background * @param RGBValue: the Color reference * @retval None */ void SetColorKeying(uint32_t LayerIndex, uint32_t RGBValue); /** * @brief Disables the color Keying. * @param LayerIndex: the Layer foreground or background * @retval None */ void ResetColorKeying(uint32_t LayerIndex); /** * @brief Gets the LCD Text color. * @param None * @retval Text color */ uint32_t GetTextColor(void); /** * @brief Gets the LCD Background color. * @param None * @retval Background color */ uint32_t GetBackColor(void); /** * @brief Sets the Text color. * @param Color: the Text color code ARGB(8-8-8-8); * @retval None */ void SetTextColor(uint32_t Color); /** * @brief Sets the Background color. * @param Color: the layer Background color code ARGB(8-8-8-8); * @retval None */ void SetBackColor(uint32_t Color); /** * @brief Sets the Text Font. * @param pFonts: the layer font to be used * @retval None */ void SetFont(sFONT *pFonts); /** * @brief Gets the Text Font. * @param None * @retval Layer font */ sFONT *GetFont(void); /** * @brief Reads Pixel. * @param Xpos: the X position * @param Ypos: the Y position * @retval RGB pixel color */ uint32_t ReadPixel(uint16_t Xpos, uint16_t Ypos); /** * @brief Clears the hole LCD. * @param Color: the color of the background * @retval None */ void Clear(uint32_t Color); /** * @brief Clears the selected line. * @param Line: the line to be cleared * @retval None */ void ClearStringLine(uint32_t Line); /** * @brief Displays one character. * @param Xpos: start column address * @param Ypos: the Line where to display the character shape * @param Ascii: character ascii code, must be between 0x20 and 0x7E * @retval None */ void DisplayChar(uint16_t Xpos, uint16_t Ypos, uint8_t Ascii); /** * @brief Displays a maximum of 60 char on the LCD. * @param X: pointer to x position (in pixel); * @param Y: pointer to y position (in pixel); * @param pText: pointer to string to display on LCD * @param mode: The display mode * This parameter can be one of the following values: * @arg CENTER_MODE * @arg RIGHT_MODE * @arg LEFT_MODE * @retval None */ void DisplayStringAt(uint16_t X, uint16_t Y, uint8_t *pText, Text_AlignModeTypdef mode); /** * @brief Displays a maximum of 20 char on the LCD. * @param Line: the Line where to display the character shape * @param ptr: pointer to string to display on LCD * @retval None */ void DisplayStringAtLine(uint16_t Line, uint8_t *ptr); /** * @brief Displays an horizontal line. * @param Xpos: the X position * @param Ypos: the Y position * @param Length: line length * @retval None */ void DrawHLine(uint16_t Xpos, uint16_t Ypos, uint16_t Length); /** * @brief Displays a vertical line. * @param Xpos: the X position * @param Ypos: the Y position * @param Length: line length * @retval None */ void DrawVLine(uint16_t Xpos, uint16_t Ypos, uint16_t Length); /** * @brief Displays an uni-line (between two points);. * @param X1: the point 1 X position * @param Y1: the point 1 Y position * @param X2: the point 2 X position * @param Y2: the point 2 Y position * @retval None */ void DrawLine(uint16_t X1, uint16_t Y1, uint16_t X2, uint16_t Y2); /** * @brief Displays a rectangle. * @param Xpos: the X position * @param Ypos: the Y position * @param Height: display rectangle height * @param Width: display rectangle width * @retval None */ void DrawRect(uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height); /** * @brief Displays a circle. * @param Xpos: the X position * @param Ypos: the Y position * @param Radius: the circle radius * @retval None */ void DrawCircle(uint16_t Xpos, uint16_t Ypos, uint16_t Radius); /** * @brief Displays an poly-line (between many points);. * @param Points: pointer to the points array * @param PointCount: Number of points * @retval None */ void DrawPolygon(pPoint Points, uint16_t PointCount); /** * @brief Displays an Ellipse. * @param Xpos: the X position * @param Ypos: the Y position * @param XRadius: the X radius of ellipse * @param YRadius: the Y radius of ellipse * @retval None */ void DrawEllipse(int Xpos, int Ypos, int XRadius, int YRadius); /** * @brief Displays a bitmap picture loaded in the internal Flash (32 bpp);. * @param X: the bmp x position in the LCD * @param Y: the bmp Y position in the LCD * @param pBmp: Bmp picture address in the internal Flash * @retval None */ void DrawBitmap(uint32_t X, uint32_t Y, uint8_t *pBmp); /** * @brief Displays a full rectangle. * @param Xpos: the X position * @param Ypos: the Y position * @param Height: rectangle height * @param Width: rectangle width * @retval None */ void FillRect(uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height); /** * @brief Displays a full circle. * @param Xpos: the X position * @param Ypos: the Y position * @param Radius: the circle radius * @retval None */ void FillCircle(uint16_t Xpos, uint16_t Ypos, uint16_t Radius); /** * @brief Fill triangle. * @param X1: the point 1 x position * @param Y1: the point 1 y position * @param X2: the point 2 x position * @param Y2: the point 2 y position * @param X3: the point 3 x position * @param Y3: the point 3 y position * @retval None */ void FillTriangle(uint16_t X1, uint16_t X2, uint16_t X3, uint16_t Y1, uint16_t Y2, uint16_t Y3); /** * @brief Displays a full poly-line (between many points);. * @param Points: pointer to the points array * @param PointCount: Number of points * @retval None */ void FillPolygon(pPoint Points, uint16_t PointCount); /** * @brief Draw a full ellipse. * @param Xpos: the X position * @param Ypos: the Y position * @param XRadius: X radius of ellipse * @param YRadius: Y radius of ellipse. * @retval None */ void FillEllipse(int Xpos, int Ypos, int XRadius, int YRadius); /** * @brief Enables the Display. * @param None * @retval None */ void DisplayOn(void); /** * @brief Disables the Display. * @param None * @retval None */ void DisplayOff(void); /** * @brief Writes Pixel. * @param Xpos: the X position * @param Ypos: the Y position * @param RGB_Code: the pixel color in ARGB mode (8-8-8-8); * @retval None */ void DrawPixel(uint16_t Xpos, uint16_t Ypos, uint32_t RGB_Code); private: }; #else #error "This class must be used with DISCO_F429ZI board only." #endif // TARGET_DISCO_F429ZI #endif