Browse Source

Merge pull request #3936 from thinkyhead/rc_sav_mk1

Support for SAV_3DGLCD OLED LCD controller
Scott Lahteine 8 years ago
parent
commit
1a01a44a94

+ 6
- 12
Marlin/Conditionals.h View File

@@ -74,13 +74,13 @@
74 74
     #define ENCODER_STEPS_PER_MENU_ITEM 1
75 75
   #endif
76 76
 
77
-  // Generic support for SSD1306 OLED based LCDs.
78
-  #if ENABLED(U8GLIB_SSD1306)
77
+  // Generic support for SSD1306 / SH1106 OLED based LCDs.
78
+  #if ENABLED(U8GLIB_SSD1306) || ENABLED(U8GLIB_SH1106)
79 79
     #define ULTRA_LCD  //general LCD support, also 16x2
80
-    #define DOGLCD  // Support for I2C LCD 128x64 (Controller SSD1306 graphic Display Family)
80
+    #define DOGLCD  // Support for I2C LCD 128x64 (Controller SSD1306 / SH1106 graphic Display Family)
81 81
   #endif
82 82
 
83
-  #if ENABLED(PANEL_ONE)
83
+  #if ENABLED(PANEL_ONE) || ENABLED(U8GLIB_SH1106)
84 84
     #define ULTIMAKERCONTROLLER
85 85
   #endif
86 86
 
@@ -245,16 +245,10 @@
245 245
    * Default LCD contrast for dogm-like LCD displays
246 246
    */
247 247
   #if ENABLED(DOGLCD)
248
-    #if !defined(DEFAULT_LCD_CONTRAST)
248
+    #define HAS_LCD_CONTRAST (DISABLED(U8GLIB_ST7920) && DISABLED(U8GLIB_SSD1306) && DISABLED(U8GLIB_SH1106))
249
+    #if HAS_LCD_CONTRAST && !defined(DEFAULT_LCD_CONTRAST)
249 250
       #define DEFAULT_LCD_CONTRAST 32
250 251
     #endif
251
-    #define HAS_LCD_CONTRAST
252
-    #if ENABLED(U8GLIB_ST7920)
253
-      #undef HAS_LCD_CONTRAST
254
-    #endif
255
-    #if ENABLED(U8GLIB_SSD1306)
256
-      #undef HAS_LCD_CONTRAST
257
-    #endif
258 252
   #endif
259 253
 
260 254
 #else // CONFIGURATION_LCD

+ 7
- 0
Marlin/Configuration.h View File

@@ -1063,6 +1063,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1063 1063
 //
1064 1064
 //#define U8GLIB_SSD1306
1065 1065
 
1066
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1067
+//#define SAV_3DGLCD
1068
+#if ENABLED(SAV_3DGLCD)
1069
+  //#define U8GLIB_SSD1306
1070
+  #define U8GLIB_SH1106
1071
+#endif
1072
+
1066 1073
 //
1067 1074
 // CONTROLLER TYPE: Shift register panels
1068 1075
 //

+ 2
- 2
Marlin/Marlin_main.cpp View File

@@ -5628,7 +5628,7 @@ inline void gcode_M226() {
5628 5628
 
5629 5629
 #endif // CHDK || PHOTOGRAPH_PIN
5630 5630
 
5631
-#if ENABLED(HAS_LCD_CONTRAST)
5631
+#if HAS_LCD_CONTRAST
5632 5632
 
5633 5633
   /**
5634 5634
    * M250: Read and optionally set the LCD contrast
@@ -6979,7 +6979,7 @@ void process_next_command() {
6979 6979
           break;
6980 6980
       #endif // CHDK || PHOTOGRAPH_PIN
6981 6981
 
6982
-      #if ENABLED(HAS_LCD_CONTRAST)
6982
+      #if HAS_LCD_CONTRAST
6983 6983
         case 250: // M250  Set LCD contrast value: C<value> (value 0..63)
6984 6984
           gcode_M250();
6985 6985
           break;

+ 4
- 4
Marlin/configuration_store.cpp View File

@@ -282,7 +282,7 @@ void Config_StoreSettings()  {
282 282
     EEPROM_WRITE_VAR(i, thermalManager.bedKd);
283 283
   #endif
284 284
 
285
-  #if DISABLED(HAS_LCD_CONTRAST)
285
+  #if !HAS_LCD_CONTRAST
286 286
     const int lcd_contrast = 32;
287 287
   #endif
288 288
   EEPROM_WRITE_VAR(i, lcd_contrast);
@@ -462,7 +462,7 @@ void Config_RetrieveSettings() {
462 462
       for (uint8_t q=3; q--;) EEPROM_READ_VAR(i, dummy); // bedKp, bedKi, bedKd
463 463
     #endif
464 464
 
465
-    #if DISABLED(HAS_LCD_CONTRAST)
465
+    #if !HAS_LCD_CONTRAST
466 466
       int lcd_contrast;
467 467
     #endif
468 468
     EEPROM_READ_VAR(i, lcd_contrast);
@@ -579,7 +579,7 @@ void Config_ResetDefault() {
579 579
     absPreheatFanSpeed = ABS_PREHEAT_FAN_SPEED;
580 580
   #endif
581 581
 
582
-  #if ENABLED(HAS_LCD_CONTRAST)
582
+  #if HAS_LCD_CONTRAST
583 583
     lcd_contrast = DEFAULT_LCD_CONTRAST;
584 584
   #endif
585 585
 
@@ -842,7 +842,7 @@ void Config_PrintSettings(bool forReplay) {
842 842
 
843 843
   #endif // PIDTEMP || PIDTEMPBED
844 844
 
845
-  #if ENABLED(HAS_LCD_CONTRAST)
845
+  #if HAS_LCD_CONTRAST
846 846
     CONFIG_ECHO_START;
847 847
     if (!forReplay) {
848 848
       SERIAL_ECHOLNPGM("LCD Contrast:");

+ 4
- 1
Marlin/dogm_lcd_implementation.h View File

@@ -150,7 +150,10 @@
150 150
   U8GLIB_LM6059 u8g(DOGLCD_CS, DOGLCD_A0);
151 151
 #elif ENABLED(U8GLIB_SSD1306)
152 152
   // Generic support for SSD1306 OLED I2C LCDs
153
-  U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NONE);
153
+  U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NONE | U8G_I2C_OPT_FAST);
154
+#elif ENABLED(U8GLIB_SH1106)
155
+  // Generic support for SH1106 OLED I2C LCDs
156
+  U8GLIB_SH1106_128X64 u8g(U8G_I2C_OPT_NONE | U8G_I2C_OPT_FAST);
154 157
 #elif ENABLED(MINIPANEL)
155 158
   // The MINIPanel display
156 159
   U8GLIB_MINI12864 u8g(DOGLCD_CS, DOGLCD_A0);

+ 7
- 0
Marlin/example_configurations/Felix/Configuration.h View File

@@ -1046,6 +1046,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1046 1046
 //
1047 1047
 //#define U8GLIB_SSD1306
1048 1048
 
1049
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1050
+//#define SAV_3DGLCD
1051
+#if ENABLED(SAV_3DGLCD)
1052
+  //#define U8GLIB_SSD1306
1053
+  #define U8GLIB_SH1106
1054
+#endif
1055
+
1049 1056
 //
1050 1057
 // CONTROLLER TYPE: Shift register panels
1051 1058
 //

+ 7
- 0
Marlin/example_configurations/Felix/DUAL/Configuration.h View File

@@ -1044,6 +1044,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1044 1044
 //
1045 1045
 //#define U8GLIB_SSD1306
1046 1046
 
1047
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1048
+//#define SAV_3DGLCD
1049
+#if ENABLED(SAV_3DGLCD)
1050
+  //#define U8GLIB_SSD1306
1051
+  #define U8GLIB_SH1106
1052
+#endif
1053
+
1047 1054
 //
1048 1055
 // CONTROLLER TYPE: Shift register panels
1049 1056
 //

+ 7
- 0
Marlin/example_configurations/Hephestos/Configuration.h View File

@@ -1055,6 +1055,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = true; // set to true to invert the lo
1055 1055
 //
1056 1056
 //#define U8GLIB_SSD1306
1057 1057
 
1058
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1059
+//#define SAV_3DGLCD
1060
+#if ENABLED(SAV_3DGLCD)
1061
+  //#define U8GLIB_SSD1306
1062
+  #define U8GLIB_SH1106
1063
+#endif
1064
+
1058 1065
 //
1059 1066
 // CONTROLLER TYPE: Shift register panels
1060 1067
 //

+ 7
- 0
Marlin/example_configurations/Hephestos_2/Configuration.h View File

@@ -1057,6 +1057,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1057 1057
 //
1058 1058
 //#define U8GLIB_SSD1306
1059 1059
 
1060
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1061
+//#define SAV_3DGLCD
1062
+#if ENABLED(SAV_3DGLCD)
1063
+  //#define U8GLIB_SSD1306
1064
+  #define U8GLIB_SH1106
1065
+#endif
1066
+
1060 1067
 //
1061 1068
 // CONTROLLER TYPE: Shift register panels
1062 1069
 //

+ 7
- 0
Marlin/example_configurations/K8200/Configuration.h View File

@@ -1080,6 +1080,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1080 1080
 //
1081 1081
 //#define U8GLIB_SSD1306
1082 1082
 
1083
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1084
+//#define SAV_3DGLCD
1085
+#if ENABLED(SAV_3DGLCD)
1086
+  //#define U8GLIB_SSD1306
1087
+  #define U8GLIB_SH1106
1088
+#endif
1089
+
1083 1090
 //
1084 1091
 // CONTROLLER TYPE: Shift register panels
1085 1092
 //

+ 7
- 0
Marlin/example_configurations/RepRapWorld/Megatronics/Configuration.h View File

@@ -1063,6 +1063,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1063 1063
 //
1064 1064
 //#define U8GLIB_SSD1306
1065 1065
 
1066
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1067
+//#define SAV_3DGLCD
1068
+#if ENABLED(SAV_3DGLCD)
1069
+  //#define U8GLIB_SSD1306
1070
+  #define U8GLIB_SH1106
1071
+#endif
1072
+
1066 1073
 //
1067 1074
 // CONTROLLER TYPE: Shift register panels
1068 1075
 //

+ 7
- 0
Marlin/example_configurations/RigidBot/Configuration.h View File

@@ -1060,6 +1060,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1060 1060
 //
1061 1061
 //#define U8GLIB_SSD1306
1062 1062
 
1063
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1064
+//#define SAV_3DGLCD
1065
+#if ENABLED(SAV_3DGLCD)
1066
+  //#define U8GLIB_SSD1306
1067
+  #define U8GLIB_SH1106
1068
+#endif
1069
+
1063 1070
 //
1064 1071
 // CONTROLLER TYPE: Shift register panels
1065 1072
 //

+ 7
- 0
Marlin/example_configurations/SCARA/Configuration.h View File

@@ -1071,6 +1071,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1071 1071
 //
1072 1072
 //#define U8GLIB_SSD1306
1073 1073
 
1074
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1075
+//#define SAV_3DGLCD
1076
+#if ENABLED(SAV_3DGLCD)
1077
+  //#define U8GLIB_SSD1306
1078
+  #define U8GLIB_SH1106
1079
+#endif
1080
+
1074 1081
 //
1075 1082
 // CONTROLLER TYPE: Shift register panels
1076 1083
 //

+ 7
- 0
Marlin/example_configurations/TAZ4/Configuration.h View File

@@ -1084,6 +1084,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1084 1084
 //
1085 1085
 //#define U8GLIB_SSD1306
1086 1086
 
1087
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1088
+//#define SAV_3DGLCD
1089
+#if ENABLED(SAV_3DGLCD)
1090
+  //#define U8GLIB_SSD1306
1091
+  #define U8GLIB_SH1106
1092
+#endif
1093
+
1087 1094
 //
1088 1095
 // CONTROLLER TYPE: Shift register panels
1089 1096
 //

+ 7
- 0
Marlin/example_configurations/WITBOX/Configuration.h View File

@@ -1055,6 +1055,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = true; // set to true to invert the lo
1055 1055
 //
1056 1056
 //#define U8GLIB_SSD1306
1057 1057
 
1058
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1059
+//#define SAV_3DGLCD
1060
+#if ENABLED(SAV_3DGLCD)
1061
+  //#define U8GLIB_SSD1306
1062
+  #define U8GLIB_SH1106
1063
+#endif
1064
+
1058 1065
 //
1059 1066
 // CONTROLLER TYPE: Shift register panels
1060 1067
 //

+ 7
- 0
Marlin/example_configurations/adafruit/ST7565/Configuration.h View File

@@ -1063,6 +1063,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1063 1063
 //
1064 1064
 //#define U8GLIB_SSD1306
1065 1065
 
1066
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1067
+//#define SAV_3DGLCD
1068
+#if ENABLED(SAV_3DGLCD)
1069
+  //#define U8GLIB_SSD1306
1070
+  #define U8GLIB_SH1106
1071
+#endif
1072
+
1066 1073
 //
1067 1074
 // CONTROLLER TYPE: Shift register panels
1068 1075
 //

+ 7
- 0
Marlin/example_configurations/delta/biv2.5/Configuration.h View File

@@ -1192,6 +1192,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = true; // set to true to invert the lo
1192 1192
 //
1193 1193
 //#define U8GLIB_SSD1306
1194 1194
 
1195
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1196
+//#define SAV_3DGLCD
1197
+#if ENABLED(SAV_3DGLCD)
1198
+  //#define U8GLIB_SSD1306
1199
+  #define U8GLIB_SH1106
1200
+#endif
1201
+
1195 1202
 //
1196 1203
 // CONTROLLER TYPE: Shift register panels
1197 1204
 //

+ 7
- 0
Marlin/example_configurations/delta/generic/Configuration.h View File

@@ -1192,6 +1192,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = true; // set to true to invert the lo
1192 1192
 //
1193 1193
 //#define U8GLIB_SSD1306
1194 1194
 
1195
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1196
+//#define SAV_3DGLCD
1197
+#if ENABLED(SAV_3DGLCD)
1198
+  //#define U8GLIB_SSD1306
1199
+  #define U8GLIB_SH1106
1200
+#endif
1201
+
1195 1202
 //
1196 1203
 // CONTROLLER TYPE: Shift register panels
1197 1204
 //

+ 7
- 0
Marlin/example_configurations/delta/kossel_mini/Configuration.h View File

@@ -1196,6 +1196,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1196 1196
 //
1197 1197
 //#define U8GLIB_SSD1306
1198 1198
 
1199
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1200
+//#define SAV_3DGLCD
1201
+#if ENABLED(SAV_3DGLCD)
1202
+  //#define U8GLIB_SSD1306
1203
+  #define U8GLIB_SH1106
1204
+#endif
1205
+
1199 1206
 //
1200 1207
 // CONTROLLER TYPE: Shift register panels
1201 1208
 //

+ 7
- 0
Marlin/example_configurations/delta/kossel_pro/Configuration.h View File

@@ -1189,6 +1189,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1189 1189
 //
1190 1190
 //#define U8GLIB_SSD1306
1191 1191
 
1192
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1193
+//#define SAV_3DGLCD
1194
+#if ENABLED(SAV_3DGLCD)
1195
+  //#define U8GLIB_SSD1306
1196
+  #define U8GLIB_SH1106
1197
+#endif
1198
+
1192 1199
 //
1193 1200
 // CONTROLLER TYPE: Shift register panels
1194 1201
 //

+ 7
- 0
Marlin/example_configurations/delta/kossel_xl/Configuration.h View File

@@ -1197,6 +1197,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1197 1197
 //
1198 1198
 //#define U8GLIB_SSD1306
1199 1199
 
1200
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1201
+//#define SAV_3DGLCD
1202
+#if ENABLED(SAV_3DGLCD)
1203
+  //#define U8GLIB_SSD1306
1204
+  #define U8GLIB_SH1106
1205
+#endif
1206
+
1200 1207
 //
1201 1208
 // CONTROLLER TYPE: Shift register panels
1202 1209
 //

+ 7
- 0
Marlin/example_configurations/makibox/Configuration.h View File

@@ -1066,6 +1066,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = false; // set to true to invert the l
1066 1066
 //
1067 1067
 //#define U8GLIB_SSD1306
1068 1068
 
1069
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1070
+//#define SAV_3DGLCD
1071
+#if ENABLED(SAV_3DGLCD)
1072
+  //#define U8GLIB_SSD1306
1073
+  #define U8GLIB_SH1106
1074
+#endif
1075
+
1069 1076
 //
1070 1077
 // CONTROLLER TYPE: Shift register panels
1071 1078
 //

+ 7
- 0
Marlin/example_configurations/tvrrug/Round2/Configuration.h View File

@@ -1057,6 +1057,13 @@ const bool Z_MIN_PROBE_ENDSTOP_INVERTING = true; // set to true to invert the lo
1057 1057
 //
1058 1058
 //#define U8GLIB_SSD1306
1059 1059
 
1060
+// SAV OLEd LCD module support using either SSD1306 or SH1106 based LCD modules
1061
+//#define SAV_3DGLCD
1062
+#if ENABLED(SAV_3DGLCD)
1063
+  //#define U8GLIB_SSD1306
1064
+  #define U8GLIB_SH1106
1065
+#endif
1066
+
1060 1067
 //
1061 1068
 // CONTROLLER TYPE: Shift register panels
1062 1069
 //

+ 4
- 4
Marlin/ultralcd.cpp View File

@@ -97,7 +97,7 @@ static void lcd_status_screen();
97 97
   static void lcd_control_motion_menu();
98 98
   static void lcd_control_volumetric_menu();
99 99
 
100
-  #if ENABLED(HAS_LCD_CONTRAST)
100
+  #if HAS_LCD_CONTRAST
101 101
     static void lcd_set_contrast();
102 102
   #endif
103 103
 
@@ -1352,7 +1352,7 @@ static void lcd_control_menu() {
1352 1352
   MENU_ITEM(submenu, MSG_MOTION, lcd_control_motion_menu);
1353 1353
   MENU_ITEM(submenu, MSG_VOLUMETRIC, lcd_control_volumetric_menu);
1354 1354
 
1355
-  #if ENABLED(HAS_LCD_CONTRAST)
1355
+  #if HAS_LCD_CONTRAST
1356 1356
     //MENU_ITEM_EDIT(int3, MSG_CONTRAST, &lcd_contrast, 0, 63);
1357 1357
     MENU_ITEM(submenu, MSG_CONTRAST, lcd_set_contrast);
1358 1358
   #endif
@@ -1712,7 +1712,7 @@ static void lcd_control_volumetric_menu() {
1712 1712
  * "Control" > "Contrast" submenu
1713 1713
  *
1714 1714
  */
1715
-#if ENABLED(HAS_LCD_CONTRAST)
1715
+#if HAS_LCD_CONTRAST
1716 1716
   static void lcd_set_contrast() {
1717 1717
     ENCODER_DIRECTION_NORMAL();
1718 1718
     if (encoderPosition) {
@@ -2383,7 +2383,7 @@ void lcd_setalertstatuspgm(const char* message) {
2383 2383
 
2384 2384
 void lcd_reset_alert_level() { lcd_status_message_level = 0; }
2385 2385
 
2386
-#if ENABLED(HAS_LCD_CONTRAST)
2386
+#if HAS_LCD_CONTRAST
2387 2387
   void lcd_setcontrast(uint8_t value) {
2388 2388
     lcd_contrast = value & 0x3F;
2389 2389
     u8g.setContrast(lcd_contrast);

Loading…
Cancel
Save