mock: levels.txt automatisch generieren
[hackover2013-badge-firmware.git] / project / commands / drawing / cmd_rectangle.c
index 2750d1d..d35eafa 100644 (file)
@@ -43,8 +43,8 @@
 #include "project/commands.h"       // Generic helper functions
 
 #ifdef CFG_TFTLCD    
 #include "project/commands.h"       // Generic helper functions
 
 #ifdef CFG_TFTLCD    
-  #include "drivers/lcd/tft/lcd.h"    
-  #include "drivers/lcd/tft/drawing.h"  
+  #include "drivers/displays/tft/lcd.h"    
+  #include "drivers/displays/tft/drawing.h"  
 
 /**************************************************************************/
 /*! 
 
 /**************************************************************************/
 /*! 
@@ -101,7 +101,8 @@ void cmd_rectangle(uint8_t argc, char **argv)
 /**************************************************************************/
 void cmd_rectangleround(uint8_t argc, char **argv)
 {
 /**************************************************************************/
 void cmd_rectangleround(uint8_t argc, char **argv)
 {
-  int32_t x1, y1, x2, y2, c, radius, corners;
+  int32_t x1, y1, x2, y2, c, radius, corners, filled, border;
+  filled = 0;
 
   // Convert supplied parameters
   getNumber (argv[0], &x1);
 
   // Convert supplied parameters
   getNumber (argv[0], &x1);
@@ -111,6 +112,19 @@ void cmd_rectangleround(uint8_t argc, char **argv)
   getNumber (argv[4], &c);
   getNumber (argv[5], &radius);
   getNumber (argv[6], &corners);
   getNumber (argv[4], &c);
   getNumber (argv[5], &radius);
   getNumber (argv[6], &corners);
+  if (argc >= 8)
+  {
+    getNumber (argv[7], &filled);
+  }
+  if (argc == 9)
+  {
+    getNumber (argv[8], &border);
+    if (border < 0 || border > 0xFFFF)
+    {
+      printf("Invalid Border Color%s", CFG_PRINTF_NEWLINE);
+      return;
+    }
+  }
 
   // ToDo: Validate data!
   if (c < 0 || c > 0xFFFF)
 
   // ToDo: Validate data!
   if (c < 0 || c > 0xFFFF)
@@ -119,13 +133,15 @@ void cmd_rectangleround(uint8_t argc, char **argv)
     return;
   }
 
     return;
   }
 
-  if ((radius == 0) || (corners == 0) || (corners > 5))
-  {
-    drawRectangleFilled(x1, y1, x2, y2, (uint16_t)c);
-  }
+  if (filled)
+    drawRoundedRectangleFilled(x1, y1, x2, y2, (uint16_t)c, radius, corners);
   else
   else
+    drawRoundedRectangle(x1, y1, x2, y2, (uint16_t)c, radius, corners);
+
+  // Draw border if it's not the same color
+  if (argc == 9)
   {
   {
-    drawRectangleRounded(x1, y1, x2, y2, (uint16_t)c, radius, corners);
+    drawRoundedRectangle(x1, y1, x2, y2, (uint16_t)border, radius, corners);
   }
 }
 
   }
 }
 
This page took 0.024557 seconds and 4 git commands to generate.