Krzysztof Miskowicz, MBED cz. 1

Dependents:   EMBEED_I_zad_2d_II

Files at this revision

API Documentation at this revision

Comitter:
krzysiek99
Date:
Fri May 08 19:03:38 2020 +0000
Parent:
0:dc55a068bc1a
Commit message:
a

Changed in this revision

LCD_DISCO_F429ZI.cpp Show diff for this revision Revisions of this file
LCD_DISCO_F429ZI.h Show diff for this revision Revisions of this file
Led_Lcd.cpp Show annotated file Show diff for this revision Revisions of this file
Led_Lcd.h Show annotated file Show diff for this revision Revisions of this file
--- a/LCD_DISCO_F429ZI.cpp	Thu Dec 17 10:26:56 2015 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,248 +0,0 @@
-/* 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.
-*/
-
-#include "LCD_DISCO_F429ZI.h"
-
-#define LCD_FRAME_BUFFER_LAYER0                  (LCD_FRAME_BUFFER+0x130000)
-#define LCD_FRAME_BUFFER_LAYER1                  LCD_FRAME_BUFFER
-#define CONVERTED_FRAME_BUFFER                   (LCD_FRAME_BUFFER+0x260000)
-
-// Constructor
-LCD_DISCO_F429ZI::LCD_DISCO_F429ZI()
-{
-  BSP_LCD_Init();  
-  BSP_LCD_LayerDefaultInit(1, LCD_FRAME_BUFFER_LAYER1);
-  BSP_LCD_SelectLayer(1);
-  BSP_LCD_Clear(LCD_COLOR_WHITE);  
-  BSP_LCD_SetColorKeying(1, LCD_COLOR_WHITE);
-  BSP_LCD_SetLayerVisible(1, DISABLE);
-  BSP_LCD_LayerDefaultInit(0, LCD_FRAME_BUFFER_LAYER0);
-  BSP_LCD_SelectLayer(0);
-  BSP_LCD_SetFont(&Font16);
-  BSP_LCD_DisplayOn();
-  BSP_LCD_Clear(LCD_COLOR_WHITE);  
-}
-
-// Destructor
-LCD_DISCO_F429ZI::~LCD_DISCO_F429ZI()
-{
-
-}
-
-//=================================================================================================================
-// Public methods
-//=================================================================================================================
-
-uint8_t LCD_DISCO_F429ZI::Init(void)
-{
-  return BSP_LCD_Init();
-}
-
-uint32_t LCD_DISCO_F429ZI::GetXSize(void)
-{
-  return BSP_LCD_GetXSize();
-}
-
-uint32_t LCD_DISCO_F429ZI::GetYSize(void)
-{
-  return BSP_LCD_GetYSize();
-}
-
-void LCD_DISCO_F429ZI::LayerDefaultInit(uint16_t LayerIndex, uint32_t FB_Address)
-{
-  BSP_LCD_LayerDefaultInit(LayerIndex, FB_Address);
-}
-
-void LCD_DISCO_F429ZI::SelectLayer(uint32_t LayerIndex)
-{
-  BSP_LCD_SelectLayer(LayerIndex);
-}
-
-void LCD_DISCO_F429ZI::SetLayerVisible(uint32_t LayerIndex, FunctionalState state)
-{
-  BSP_LCD_SetLayerVisible(LayerIndex, state);
-}
-
-void LCD_DISCO_F429ZI::SetTransparency(uint32_t LayerIndex, uint8_t Transparency)
-{
-  BSP_LCD_SetTransparency(LayerIndex, Transparency);
-}
-
-void LCD_DISCO_F429ZI::SetLayerAddress(uint32_t LayerIndex, uint32_t Address)
-{
-  BSP_LCD_SetLayerAddress(LayerIndex, Address);
-}
-
-void LCD_DISCO_F429ZI::SetLayerWindow(uint16_t LayerIndex, uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height)
-{
-  BSP_LCD_SetLayerWindow(LayerIndex, Xpos, Ypos, Width, Height);
-}
-
-void LCD_DISCO_F429ZI::SetColorKeying(uint32_t LayerIndex, uint32_t RGBValue)
-{
-  BSP_LCD_SetColorKeying(LayerIndex, RGBValue);
-}
-
-void LCD_DISCO_F429ZI::ResetColorKeying(uint32_t LayerIndex)
-{
-  BSP_LCD_ResetColorKeying(LayerIndex);
-}
-
-uint32_t LCD_DISCO_F429ZI::GetTextColor(void)
-{
-  return BSP_LCD_GetTextColor();
-}
-
-uint32_t LCD_DISCO_F429ZI::GetBackColor(void)
-{
-  return BSP_LCD_GetBackColor();
-}
-
-void LCD_DISCO_F429ZI::SetTextColor(uint32_t Color)
-{
-  BSP_LCD_SetTextColor(Color);
-}
-
-void LCD_DISCO_F429ZI::SetBackColor(uint32_t Color)
-{
-  BSP_LCD_SetBackColor(Color);
-}
-
-void LCD_DISCO_F429ZI::SetFont(sFONT *pFonts)
-{
-  BSP_LCD_SetFont(pFonts);
-}
-
-sFONT *LCD_DISCO_F429ZI::GetFont(void)
-{
-  return BSP_LCD_GetFont();
-}
-
-uint32_t LCD_DISCO_F429ZI::ReadPixel(uint16_t Xpos, uint16_t Ypos)
-{
-  return BSP_LCD_ReadPixel(Xpos, Ypos);
-}
-
-void LCD_DISCO_F429ZI::Clear(uint32_t Color)
-{
-  BSP_LCD_Clear(Color);
-}
-
-void LCD_DISCO_F429ZI::ClearStringLine(uint32_t Line)
-{
-  BSP_LCD_ClearStringLine(Line);
-}
-
-void LCD_DISCO_F429ZI::DisplayChar(uint16_t Xpos, uint16_t Ypos, uint8_t Ascii)
-{
-  BSP_LCD_DisplayChar(Xpos, Ypos, Ascii);
-}
-
-void LCD_DISCO_F429ZI::DisplayStringAt(uint16_t X, uint16_t Y, uint8_t *pText, Text_AlignModeTypdef mode)
-{
-  BSP_LCD_DisplayStringAt(X, Y, pText, mode);
-}
-
-void LCD_DISCO_F429ZI::DisplayStringAtLine(uint16_t Line, uint8_t *ptr)
-{
-  BSP_LCD_DisplayStringAtLine(Line, ptr);
-}
-
-void LCD_DISCO_F429ZI::DrawHLine(uint16_t Xpos, uint16_t Ypos, uint16_t Length)
-{
-  BSP_LCD_DrawHLine(Xpos, Ypos, Length);
-}
-
-void LCD_DISCO_F429ZI::DrawVLine(uint16_t Xpos, uint16_t Ypos, uint16_t Length)
-{
-  BSP_LCD_DrawVLine(Xpos, Ypos, Length);
-}
-
-void LCD_DISCO_F429ZI::DrawLine(uint16_t X1, uint16_t Y1, uint16_t X2, uint16_t Y2)
-{
-  BSP_LCD_DrawLine(X1, Y1, X2, Y2);
-}
-
-void LCD_DISCO_F429ZI::DrawRect(uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height)
-{
-  BSP_LCD_DrawRect(Xpos, Ypos, Width, Height);
-}
-
-void LCD_DISCO_F429ZI::DrawCircle(uint16_t Xpos, uint16_t Ypos, uint16_t Radius)
-{
-  BSP_LCD_DrawCircle(Xpos, Ypos, Radius);
-}
-
-void LCD_DISCO_F429ZI::DrawPolygon(pPoint Points, uint16_t PointCount)
-{
-  BSP_LCD_DrawPolygon(Points, PointCount);
-}
-
-void LCD_DISCO_F429ZI::DrawEllipse(int Xpos, int Ypos, int XRadius, int YRadius)
-{
-  BSP_LCD_DrawEllipse(Xpos, Ypos, XRadius, YRadius);
-}
-
-void LCD_DISCO_F429ZI::DrawBitmap(uint32_t X, uint32_t Y, uint8_t *pBmp)
-{
-  BSP_LCD_DrawBitmap(X, Y, pBmp);
-}
-
-void LCD_DISCO_F429ZI::FillRect(uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height)
-{
-  BSP_LCD_FillRect(Xpos, Ypos, Width, Height);
-}
-
-void LCD_DISCO_F429ZI::FillCircle(uint16_t Xpos, uint16_t Ypos, uint16_t Radius)
-{
-  BSP_LCD_FillCircle(Xpos, Ypos, Radius);
-}
-
-void LCD_DISCO_F429ZI::FillTriangle(uint16_t X1, uint16_t X2, uint16_t X3, uint16_t Y1, uint16_t Y2, uint16_t Y3)
-{
-  BSP_LCD_FillTriangle(X1, X2, X3, Y1, Y2, Y3);
-}
-
-void LCD_DISCO_F429ZI::FillPolygon(pPoint Points, uint16_t PointCount)
-{
-  BSP_LCD_FillPolygon(Points, PointCount);
-}
-
-void LCD_DISCO_F429ZI::FillEllipse(int Xpos, int Ypos, int XRadius, int YRadius)
-{
-  BSP_LCD_FillEllipse(Xpos, Ypos, XRadius, YRadius);
-}
-
-void LCD_DISCO_F429ZI::DisplayOn(void)
-{
-  BSP_LCD_DisplayOn();
-}
-
-void LCD_DISCO_F429ZI::DisplayOff(void)
-{
-  BSP_LCD_DisplayOff();
-}
-
-void LCD_DISCO_F429ZI::DrawPixel(uint16_t Xpos, uint16_t Ypos, uint32_t RGB_Code)
-{
-  BSP_LCD_DrawPixel(Xpos, Ypos, RGB_Code);
-}
-
-//=================================================================================================================
-// Private methods
-//=================================================================================================================
--- a/LCD_DISCO_F429ZI.h	Thu Dec 17 10:26:56 2015 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,395 +0,0 @@
-/* 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
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Led_Lcd.cpp	Fri May 08 19:03:38 2020 +0000
@@ -0,0 +1,29 @@
+#include "Led_Lcd.h"
+
+LedLcd::LedLcd(unsigned char ucMode)
+{
+    lcd.Clear(LCD_COLOR_BLACK);
+    lcd.SetFont(&Font24);
+    ucButtonsColumn = 80*ucMode;
+}
+
+void LedLcd::On(unsigned char ucLedNumber)
+{
+    for(unsigned char ucCounter = 0; ucCounter < 4; ucCounter++)
+    {
+        lcd.SetTextColor(LCD_COLOR_GREEN);
+        lcd.DrawRect(ucButtonsColumn, 80*ucCounter, 80, 80);
+        if(ucLedNumber == ucCounter)
+            lcd.SetTextColor(LCD_COLOR_YELLOW);
+        else
+            lcd.SetTextColor(LCD_COLOR_BLUE);
+        
+        lcd.FillRect(ucButtonsColumn+1, 80*ucCounter+1, 78, 78);
+    } 
+    lcd.SetTextColor(LCD_COLOR_WHITE);
+    lcd.SetBackColor(LCD_COLOR_RED);
+    lcd.DisplayStringAt(ucButtonsColumn+1, LINE(0), (uint8_t *)"1", LEFT_MODE);
+    lcd.DisplayStringAt(ucButtonsColumn+1, LINE(3.35), (uint8_t *)"2", LEFT_MODE);
+    lcd.DisplayStringAt(ucButtonsColumn+1, LINE(6.7), (uint8_t *)"3", LEFT_MODE);
+    lcd.DisplayStringAt(ucButtonsColumn+1, LINE(10), (uint8_t *)"4", LEFT_MODE);
+}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Led_Lcd.h	Fri May 08 19:03:38 2020 +0000
@@ -0,0 +1,15 @@
+#ifndef LED_LCD_H
+    #define LED_LCD_H
+    #include "LCD_DISCO_F429ZI.h"
+    class LedLcd
+    {
+        public:
+            LedLcd(unsigned char ucMode);   
+            void On(unsigned char ucLedNumber);
+        private:
+            LCD_DISCO_F429ZI lcd;
+            unsigned  char ucButtonsColumn;
+    };
+#else
+    #error "This class was definied previously"
+#endif