Browse Source

Optimize LCD string/char printing

Scott Lahteine 8 years ago
parent
commit
f20b2b21eb
2 changed files with 48 additions and 50 deletions
  1. 34
    31
      Marlin/ultralcd_impl_DOGM.h
  2. 14
    19
      Marlin/ultralcd_impl_HD44780.h

+ 34
- 31
Marlin/ultralcd_impl_DOGM.h View File

189
   }
189
   }
190
 }
190
 }
191
 
191
 
192
-char lcd_print(char c) {
192
+void lcd_print(char c) {
193
+  if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
194
+    u8g.setFont(FONT_SPECIAL_NAME);
195
+    u8g.print(c);
196
+    lcd_setFont(currentfont);
197
+  }
198
+  else charset_mapper(c);
199
+}
200
+
201
+char lcd_print_and_count(char c) {
193
   if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
202
   if ((c > 0) && (c <= LCD_STR_SPECIAL_MAX)) {
194
     u8g.setFont(FONT_SPECIAL_NAME);
203
     u8g.setFont(FONT_SPECIAL_NAME);
195
     u8g.print(c);
204
     u8g.print(c);
196
     lcd_setFont(currentfont);
205
     lcd_setFont(currentfont);
197
     return 1;
206
     return 1;
198
-  } else {
199
-    return charset_mapper(c);
200
   }
207
   }
208
+  else return charset_mapper(c);
201
 }
209
 }
202
 
210
 
203
-char lcd_print(const char* str) {
204
-  int i = 0;
205
-  char c, n = 0;
206
-  while ((c = str[i++])) n += lcd_print(c);
207
-  return n;
211
+void lcd_print(const char* str) {
212
+  for (uint8_t i = 0; char c = str[i]; ++i) lcd_print(c);
208
 }
213
 }
209
 
214
 
210
-// Needed for Arduino < 1.0.0
211
-char lcd_printPGM(const char* str) {
212
-  char c, n = 0;
213
-  while ((c = pgm_read_byte(str++))) n += lcd_print(c);
214
-  return n;
215
+/* Arduino < 1.0.0 is missing a function to print PROGMEM strings, so we need to implement our own */
216
+void lcd_printPGM(const char* str) {
217
+  for (; char c = pgm_read_byte(str); ++str) lcd_print(c);
215
 }
218
 }
216
 
219
 
217
 // Initialize or re-initializw the LCD
220
 // Initialize or re-initializw the LCD
337
     lcd_printPGM(pstr);
340
     lcd_printPGM(pstr);
338
   else {
341
   else {
339
     if (!axis_homed[axis])
342
     if (!axis_homed[axis])
340
-      lcd_printPGM(PSTR("?"));
343
+      u8g.print('?');
341
     else {
344
     else {
342
       #if DISABLED(DISABLE_REDUCED_ACCURACY_WARNING)
345
       #if DISABLED(DISABLE_REDUCED_ACCURACY_WARNING)
343
         if (!axis_known_position[axis])
346
         if (!axis_known_position[axis])
344
-          lcd_printPGM(PSTR(" "));
347
+          u8g.print(' ');
345
         else
348
         else
346
       #endif
349
       #endif
347
       lcd_printPGM(pstr);
350
       lcd_printPGM(pstr);
421
     int per = ((fanSpeeds[0] + 1) * 100) / 256;
424
     int per = ((fanSpeeds[0] + 1) * 100) / 256;
422
     if (per) {
425
     if (per) {
423
       lcd_print(itostr3(per));
426
       lcd_print(itostr3(per));
424
-      lcd_print('%');
427
+      u8g.print('%');
425
     }
428
     }
426
   #endif
429
   #endif
427
 
430
 
463
   lcd_setFont(FONT_STATUSMENU);
466
   lcd_setFont(FONT_STATUSMENU);
464
   u8g.setPrintPos(12, 49);
467
   u8g.setPrintPos(12, 49);
465
   lcd_print(itostr3(feedrate_percentage));
468
   lcd_print(itostr3(feedrate_percentage));
466
-  lcd_print('%');
469
+  u8g.print('%');
467
 
470
 
468
   // Status line
471
   // Status line
469
   #if ENABLED(USE_SMALL_INFOFONT)
472
   #if ENABLED(USE_SMALL_INFOFONT)
482
       lcd_print(ftostr12ns(filament_width_meas));
485
       lcd_print(ftostr12ns(filament_width_meas));
483
       lcd_printPGM(PSTR(" factor:"));
486
       lcd_printPGM(PSTR(" factor:"));
484
       lcd_print(itostr3(100.0 * volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM]));
487
       lcd_print(itostr3(100.0 * volumetric_multiplier[FILAMENT_SENSOR_EXTRUDER_NUM]));
485
-      lcd_print('%');
488
+      u8g.print('%');
486
     }
489
     }
487
   #endif
490
   #endif
488
 }
491
 }
514
 
517
 
515
       if (center && !valstr) {
518
       if (center && !valstr) {
516
         int8_t pad = (LCD_WIDTH - lcd_strlen_P(pstr)) / 2;
519
         int8_t pad = (LCD_WIDTH - lcd_strlen_P(pstr)) / 2;
517
-        while (--pad >= 0) { lcd_print(' '); n--; }
520
+        while (--pad >= 0) { u8g.print(' '); n--; }
518
       }
521
       }
519
       while (n > 0 && (c = pgm_read_byte(pstr))) {
522
       while (n > 0 && (c = pgm_read_byte(pstr))) {
520
-        n -= lcd_print(c);
523
+        n -= lcd_print_and_count(c);
521
         pstr++;
524
         pstr++;
522
       }
525
       }
523
       if (valstr) while (n > 0 && (c = *valstr)) {
526
       if (valstr) while (n > 0 && (c = *valstr)) {
524
-        n -= lcd_print(c);
527
+        n -= lcd_print_and_count(c);
525
         valstr++;
528
         valstr++;
526
       }
529
       }
527
-      while (n-- > 0) lcd_print(' ');
530
+      while (n-- > 0) u8g.print(' ');
528
     }
531
     }
529
 
532
 
530
   #endif // LCD_INFO_MENU || FILAMENT_CHANGE_FEATURE
533
   #endif // LCD_INFO_MENU || FILAMENT_CHANGE_FEATURE
539
     lcd_implementation_mark_as_selected(row, isSelected);
542
     lcd_implementation_mark_as_selected(row, isSelected);
540
 
543
 
541
     while (c = pgm_read_byte(pstr)) {
544
     while (c = pgm_read_byte(pstr)) {
542
-      n -= lcd_print(c);
545
+      n -= lcd_print_and_count(c);
543
       pstr++;
546
       pstr++;
544
     }
547
     }
545
-    while (n--) lcd_print(' ');
548
+    while (n--) u8g.print(' ');
546
     u8g.setPrintPos(LCD_PIXEL_WIDTH - (DOG_CHAR_WIDTH), (row + 1) * (DOG_CHAR_HEIGHT));
549
     u8g.setPrintPos(LCD_PIXEL_WIDTH - (DOG_CHAR_WIDTH), (row + 1) * (DOG_CHAR_HEIGHT));
547
     lcd_print(post_char);
550
     lcd_print(post_char);
548
-    lcd_print(' ');
551
+    u8g.print(' ');
549
   }
552
   }
550
 
553
 
551
   // Macros for specific types of menu items
554
   // Macros for specific types of menu items
563
     lcd_implementation_mark_as_selected(row, isSelected);
566
     lcd_implementation_mark_as_selected(row, isSelected);
564
 
567
 
565
     while (c = pgm_read_byte(pstr)) {
568
     while (c = pgm_read_byte(pstr)) {
566
-      n -= lcd_print(c);
569
+      n -= lcd_print_and_count(c);
567
       pstr++;
570
       pstr++;
568
     }
571
     }
569
-    lcd_print(':');
570
-    while (n--) lcd_print(' ');
572
+    u8g.print(':');
573
+    while (n--) u8g.print(' ');
571
     u8g.setPrintPos(LCD_PIXEL_WIDTH - (DOG_CHAR_WIDTH) * vallen, (row + 1) * (DOG_CHAR_HEIGHT));
574
     u8g.setPrintPos(LCD_PIXEL_WIDTH - (DOG_CHAR_WIDTH) * vallen, (row + 1) * (DOG_CHAR_HEIGHT));
572
     if (pgm)  lcd_printPGM(data);  else  lcd_print((char*)data);
575
     if (pgm)  lcd_printPGM(data);  else  lcd_print((char*)data);
573
   }
576
   }
621
     u8g.setPrintPos(0, rowHeight + kHalfChar);
624
     u8g.setPrintPos(0, rowHeight + kHalfChar);
622
     lcd_printPGM(pstr);
625
     lcd_printPGM(pstr);
623
     if (value != NULL) {
626
     if (value != NULL) {
624
-      lcd_print(':');
627
+      u8g.print(':');
625
       u8g.setPrintPos((lcd_width - 1 - vallen) * char_width, rows * rowHeight + kHalfChar);
628
       u8g.setPrintPos((lcd_width - 1 - vallen) * char_width, rows * rowHeight + kHalfChar);
626
       lcd_print(value);
629
       lcd_print(value);
627
     }
630
     }
643
 
646
 
644
       if (isDir) lcd_print(LCD_STR_FOLDER[0]);
647
       if (isDir) lcd_print(LCD_STR_FOLDER[0]);
645
       while ((c = *filename)) {
648
       while ((c = *filename)) {
646
-        n -= lcd_print(c);
649
+        n -= lcd_print_and_count(c);
647
         filename++;
650
         filename++;
648
       }
651
       }
649
-      while (n--) lcd_print(' ');
652
+      while (n--) u8g.print(' ');
650
     }
653
     }
651
 
654
 
652
     #define lcd_implementation_drawmenu_sdfile(sel, row, pstr, filename, longFilename) _drawmenu_sd(sel, row, pstr, filename, longFilename, false)
655
     #define lcd_implementation_drawmenu_sdfile(sel, row, pstr, filename, longFilename) _drawmenu_sd(sel, row, pstr, filename, longFilename, false)

+ 14
- 19
Marlin/ultralcd_impl_HD44780.h View File

375
 static void lcd_implementation_clear() { lcd.clear(); }
375
 static void lcd_implementation_clear() { lcd.clear(); }
376
 
376
 
377
 /* Arduino < 1.0.0 is missing a function to print PROGMEM strings, so we need to implement our own */
377
 /* Arduino < 1.0.0 is missing a function to print PROGMEM strings, so we need to implement our own */
378
-char lcd_printPGM(const char* str) {
379
-  char c, n = 0;
380
-  while ((c = pgm_read_byte(str++))) n += charset_mapper(c);
381
-  return n;
378
+void lcd_printPGM(const char *str) {
379
+  for (; char c = pgm_read_byte(str); ++str) charset_mapper(c);
382
 }
380
 }
383
 
381
 
384
-char lcd_print(const char* str) {
385
-  char c, n = 0;
386
-  unsigned char i = 0;
387
-  while ((c = str[i++])) n += charset_mapper(c);
388
-  return n;
382
+void lcd_print(const char* str) {
383
+  for (uint8_t i = 0; char c = str[i]; ++i) charset_mapper(c);
389
 }
384
 }
390
 
385
 
391
-unsigned lcd_print(char c) { return charset_mapper(c); }
386
+void lcd_print(char c) { charset_mapper(c); }
392
 
387
 
393
 #if ENABLED(SHOW_BOOTSCREEN)
388
 #if ENABLED(SHOW_BOOTSCREEN)
394
 
389
 
556
     lcd_printPGM(pstr);
551
     lcd_printPGM(pstr);
557
   else {
552
   else {
558
     if (!axis_homed[axis])
553
     if (!axis_homed[axis])
559
-      lcd_printPGM(PSTR("?"));
554
+      lcd.print('?');
560
     else {
555
     else {
561
       #if DISABLED(DISABLE_REDUCED_ACCURACY_WARNING)
556
       #if DISABLED(DISABLE_REDUCED_ACCURACY_WARNING)
562
         if (!axis_known_position[axis])
557
         if (!axis_known_position[axis])
563
-          lcd_printPGM(PSTR(" "));
558
+          lcd.print(' ');
564
         else
559
         else
565
       #endif
560
       #endif
566
       lcd_printPGM(pstr);
561
       lcd_printPGM(pstr);
694
         _draw_axis_label(X_AXIS, PSTR(MSG_X), blink);
689
         _draw_axis_label(X_AXIS, PSTR(MSG_X), blink);
695
         lcd.print(ftostr4sign(current_position[X_AXIS]));
690
         lcd.print(ftostr4sign(current_position[X_AXIS]));
696
 
691
 
697
-        lcd_printPGM(PSTR(" "));
692
+        lcd.print(' ');
698
 
693
 
699
         _draw_axis_label(Y_AXIS, PSTR(MSG_Y), blink);
694
         _draw_axis_label(Y_AXIS, PSTR(MSG_Y), blink);
700
         lcd.print(ftostr4sign(current_position[Y_AXIS]));
695
         lcd.print(ftostr4sign(current_position[Y_AXIS]));
803
         while (--pad >= 0) { lcd.print(' '); n--; }
798
         while (--pad >= 0) { lcd.print(' '); n--; }
804
       }
799
       }
805
       while (n > 0 && (c = pgm_read_byte(pstr))) {
800
       while (n > 0 && (c = pgm_read_byte(pstr))) {
806
-        n -= lcd_print(c);
801
+        n -= charset_mapper(c);
807
         pstr++;
802
         pstr++;
808
       }
803
       }
809
       if (valstr) while (n > 0 && (c = *valstr)) {
804
       if (valstr) while (n > 0 && (c = *valstr)) {
810
-        n -= lcd_print(c);
805
+        n -= charset_mapper(c);
811
         valstr++;
806
         valstr++;
812
       }
807
       }
813
       while (n-- > 0) lcd.print(' ');
808
       while (n-- > 0) lcd.print(' ');
821
     lcd.setCursor(0, row);
816
     lcd.setCursor(0, row);
822
     lcd.print(sel ? pre_char : ' ');
817
     lcd.print(sel ? pre_char : ' ');
823
     while ((c = pgm_read_byte(pstr)) && n > 0) {
818
     while ((c = pgm_read_byte(pstr)) && n > 0) {
824
-      n -= lcd_print(c);
819
+      n -= charset_mapper(c);
825
       pstr++;
820
       pstr++;
826
     }
821
     }
827
     while (n--) lcd.print(' ');
822
     while (n--) lcd.print(' ');
834
     lcd.setCursor(0, row);
829
     lcd.setCursor(0, row);
835
     lcd.print(sel ? pre_char : ' ');
830
     lcd.print(sel ? pre_char : ' ');
836
     while ((c = pgm_read_byte(pstr)) && n > 0) {
831
     while ((c = pgm_read_byte(pstr)) && n > 0) {
837
-      n -= lcd_print(c);
832
+      n -= charset_mapper(c);
838
       pstr++;
833
       pstr++;
839
     }
834
     }
840
     lcd.print(':');
835
     lcd.print(':');
847
     lcd.setCursor(0, row);
842
     lcd.setCursor(0, row);
848
     lcd.print(sel ? pre_char : ' ');
843
     lcd.print(sel ? pre_char : ' ');
849
     while ((c = pgm_read_byte(pstr)) && n > 0) {
844
     while ((c = pgm_read_byte(pstr)) && n > 0) {
850
-      n -= lcd_print(c);
845
+      n -= charset_mapper(c);
851
       pstr++;
846
       pstr++;
852
     }
847
     }
853
     lcd.print(':');
848
     lcd.print(':');
899
         longFilename[n] = '\0';
894
         longFilename[n] = '\0';
900
       }
895
       }
901
       while ((c = *filename) && n > 0) {
896
       while ((c = *filename) && n > 0) {
902
-        n -= lcd_print(c);
897
+        n -= charset_mapper(c);
903
         filename++;
898
         filename++;
904
       }
899
       }
905
       while (n--) lcd.print(' ');
900
       while (n--) lcd.print(' ');

Loading…
Cancel
Save