Neil Darlow 10 years ago
parent
commit
64139f5e5a

+ 14
- 0
.travis.yml View File

1
+---
2
+language: c
3
+
4
+before_install:
5
+  - sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
6
+  - sudo apt-get update -qq
7
+install:
8
+  - sudo apt-get install -qq gcc-avr binutils-avr avr-libc gcc-4.8 g++-4.8 arduino
9
+  - sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.8 90
10
+  - sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.8 90
11
+  - gcc --version
12
+  - g++ --version
13
+
14
+script: "cd Marlin && make HARDWARE_MOTHERBOARD=70 ARDUINO_INSTALL_DIR=/usr/share/arduino"

+ 3
- 1
Marlin/Configuration.h View File

777
  * 301 - Rambo  - uses Analog input 3
777
  * 301 - Rambo  - uses Analog input 3
778
  * Note may require analog pins to be defined for different motherboards
778
  * Note may require analog pins to be defined for different motherboards
779
  **********************************************************************/
779
  **********************************************************************/
780
-#define FILAMENT_SENSOR
780
+// Uncomment below to enable
781
+//#define FILAMENT_SENSOR
782
+
781
 #define FILAMENT_SENSOR_EXTRUDER_NUM	0  //The number of the extruder that has the filament sensor (0,1,2)
783
 #define FILAMENT_SENSOR_EXTRUDER_NUM	0  //The number of the extruder that has the filament sensor (0,1,2)
782
 #define MEASUREMENT_DELAY_CM			14  //measurement delay in cm.  This is the distance from filament sensor to middle of barrel
784
 #define MEASUREMENT_DELAY_CM			14  //measurement delay in cm.  This is the distance from filament sensor to middle of barrel
783
 
785
 

+ 4
- 2
Marlin/Configuration_adv.h View File

219
 //#define QUICK_HOME  //if this is defined, if both x and y are to be homed, a diagonal move will be performed initially.
219
 //#define QUICK_HOME  //if this is defined, if both x and y are to be homed, a diagonal move will be performed initially.
220
 
220
 
221
 #define AXIS_RELATIVE_MODES {false, false, false, false}
221
 #define AXIS_RELATIVE_MODES {false, false, false, false}
222
-
222
+#ifdef CONFIG_STEPPERS_TOSHIBA
223
+#define MAX_STEP_FREQUENCY 10000 // Max step frequency for Toshiba Stepper Controllers
224
+#else
223
 #define MAX_STEP_FREQUENCY 40000 // Max step frequency for Ultimaker (5000 pps / half step)
225
 #define MAX_STEP_FREQUENCY 40000 // Max step frequency for Ultimaker (5000 pps / half step)
224
-
226
+#endif
225
 //By default pololu step drivers require an active high signal. However, some high power drivers require an active low signal as step.
227
 //By default pololu step drivers require an active high signal. However, some high power drivers require an active low signal as step.
226
 #define INVERT_X_STEP_PIN false
228
 #define INVERT_X_STEP_PIN false
227
 #define INVERT_Y_STEP_PIN false
229
 #define INVERT_Y_STEP_PIN false

+ 156
- 48
Marlin/DOGMbitmaps.h View File

68
 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xF0
68
 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xF0
69
 };
69
 };
70
 
70
 
71
-#define STATUS_SCREENWIDTH 		115	//Width in pixels
72
-#define STATUS_SCREENHEIGHT 	19	//Height in pixels
73
-#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
74
-const unsigned char status_screen0_bmp[] PROGMEM = { //AVR-GCC, WinAVR
75
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
76
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
77
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x63,0x0C,0x60,
78
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x47,0x0E,0x20,
79
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x4F,0x0F,0x20,
80
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5F,0x0F,0xA0,
81
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5E,0x07,0xA0,
82
-0x7F,0x80,0x00,0x3F,0xC0,0x00,0x3F,0xC0,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
83
-0xFB,0xC0,0x00,0x79,0xE0,0x00,0x79,0xE0,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
84
-0xF3,0xC0,0x00,0x76,0xE0,0x00,0x76,0xE0,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
85
-0xEB,0xC0,0x00,0x7E,0xE0,0x00,0x7E,0xE0,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
86
-0x7B,0x80,0x00,0x3D,0xC0,0x00,0x39,0xC0,0x00,0x82,0x08,0x00,0x5E,0x07,0xA0,
87
-0x7B,0x80,0x00,0x3B,0xC0,0x00,0x3E,0xC0,0x01,0x04,0x10,0x00,0x5F,0x0F,0xA0,
88
-0xFB,0xC0,0x00,0x77,0xE0,0x00,0x76,0xE0,0x01,0x04,0x10,0x00,0x4F,0x0F,0x20,
89
-0xFB,0xC0,0x00,0x70,0xE0,0x00,0x79,0xE0,0x00,0x82,0x08,0x00,0x47,0x0E,0x20,
90
-0xFF,0xC0,0x00,0x7F,0xE0,0x00,0x7F,0xE0,0x00,0x41,0x04,0x00,0x63,0x0C,0x60,
91
-0x3F,0x00,0x00,0x1F,0x80,0x00,0x1F,0x80,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
92
-0x1E,0x00,0x00,0x0F,0x00,0x00,0x0F,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
93
-0x0C,0x00,0x00,0x06,0x00,0x00,0x06,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
94
-};
71
+// Here comes a compile-time operation to match the extruder symbols 
72
+// on the info screen to the set number of extruders in configuration.h
73
+// 
74
+// When only one extruder is selected, the "1" on the symbol will not 
75
+// be displayed.
95
 
76
 
96
-#define STATUS_SCREENWIDTH 		115	//Width in pixels
97
-#define STATUS_SCREENHEIGHT 	19	//Height in pixels
98
-#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
99
-const unsigned char status_screen1_bmp[] PROGMEM = { //AVR-GCC, WinAVR
100
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
101
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
102
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x61,0xF8,0x60,
103
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0xF8,0x20,
104
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0xF0,0x20,
105
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0x60,0x20,
106
-0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x58,0x01,0xA0,
107
-0x7F,0x80,0x00,0x3F,0xC0,0x00,0x3F,0xC0,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
108
-0xFB,0xC0,0x00,0x79,0xE0,0x00,0x79,0xE0,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
109
-0xF3,0xC0,0x00,0x76,0xE0,0x00,0x76,0xE0,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
110
-0xEB,0xC0,0x00,0x7E,0xE0,0x00,0x7E,0xE0,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
111
-0x7B,0x80,0x00,0x3D,0xC0,0x00,0x39,0xC0,0x00,0x82,0x08,0x00,0x58,0x01,0xA0,
112
-0x7B,0x80,0x00,0x3B,0xC0,0x00,0x3E,0xC0,0x01,0x04,0x10,0x00,0x40,0x60,0x20,
113
-0xFB,0xC0,0x00,0x77,0xE0,0x00,0x76,0xE0,0x01,0x04,0x10,0x00,0x40,0xF0,0x20,
114
-0xFB,0xC0,0x00,0x70,0xE0,0x00,0x79,0xE0,0x00,0x82,0x08,0x00,0x41,0xF8,0x20,
115
-0xFF,0xC0,0x00,0x7F,0xE0,0x00,0x7F,0xE0,0x00,0x41,0x04,0x00,0x61,0xF8,0x60,
116
-0x3F,0x00,0x00,0x1F,0x80,0x00,0x1F,0x80,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
117
-0x1E,0x00,0x00,0x0F,0x00,0x00,0x0F,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
118
-0x0C,0x00,0x00,0x06,0x00,0x00,0x06,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
119
-};
77
+#if EXTRUDERS == 1
78
+	#define STATUS_SCREENWIDTH 		115	//Width in pixels
79
+	#define STATUS_SCREENHEIGHT 	19	//Height in pixels
80
+	#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
81
+	const unsigned char status_screen0_bmp[] PROGMEM = { //AVR-GCC, WinAVR
82
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
83
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
84
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x63,0x0C,0x60,
85
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x47,0x0E,0x20,
86
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x4F,0x0F,0x20,
87
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5F,0x0F,0xA0,
88
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5E,0x07,0xA0,
89
+	0x7F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
90
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
91
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
92
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
93
+	0x7F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x5E,0x07,0xA0,
94
+	0x7F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x5F,0x0F,0xA0,
95
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x4F,0x0F,0x20,
96
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x47,0x0E,0x20,
97
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x63,0x0C,0x60,
98
+	0x3F,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
99
+	0x1E,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
100
+	0x0C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
101
+	};
102
+
103
+	#define STATUS_SCREENWIDTH 		115	//Width in pixels
104
+	#define STATUS_SCREENHEIGHT 	19	//Height in pixels
105
+	#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
106
+	const unsigned char status_screen1_bmp[] PROGMEM = { //AVR-GCC, WinAVR
107
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
108
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
109
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x61,0xF8,0x60,
110
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0xF8,0x20,
111
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0xF0,0x20,
112
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0x60,0x20,
113
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x58,0x01,0xA0,
114
+	0x7F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
115
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
116
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
117
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
118
+	0x7F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x58,0x01,0xA0,
119
+	0x7F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x40,0x60,0x20,
120
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x40,0xF0,0x20,
121
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x41,0xF8,0x20,
122
+	0xFF,0xC0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x61,0xF8,0x60,
123
+	0x3F,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
124
+	0x1E,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
125
+	0x0C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
126
+	};
127
+#elif EXTRUDERS == 2
128
+	#define STATUS_SCREENWIDTH 		115	//Width in pixels
129
+	#define STATUS_SCREENHEIGHT 	19	//Height in pixels
130
+	#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
131
+	const unsigned char status_screen0_bmp[] PROGMEM = { //AVR-GCC, WinAVR
132
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
133
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
134
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x63,0x0C,0x60,
135
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x47,0x0E,0x20,
136
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x4F,0x0F,0x20,
137
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5F,0x0F,0xA0,
138
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5E,0x07,0xA0,
139
+	0x7F,0x80,0x00,0x3F,0xC0,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
140
+	0xFB,0xC0,0x00,0x79,0xE0,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
141
+	0xF3,0xC0,0x00,0x76,0xE0,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
142
+	0xEB,0xC0,0x00,0x7E,0xE0,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
143
+	0x7B,0x80,0x00,0x3D,0xC0,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x5E,0x07,0xA0,
144
+	0x7B,0x80,0x00,0x3B,0xC0,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x5F,0x0F,0xA0,
145
+	0xFB,0xC0,0x00,0x77,0xE0,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x4F,0x0F,0x20,
146
+	0xFB,0xC0,0x00,0x70,0xE0,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x47,0x0E,0x20,
147
+	0xFF,0xC0,0x00,0x7F,0xE0,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x63,0x0C,0x60,
148
+	0x3F,0x00,0x00,0x1F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
149
+	0x1E,0x00,0x00,0x0F,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
150
+	0x0C,0x00,0x00,0x06,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
151
+	};
152
+
153
+	#define STATUS_SCREENWIDTH 		115	//Width in pixels
154
+	#define STATUS_SCREENHEIGHT 	19	//Height in pixels
155
+	#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
156
+	const unsigned char status_screen1_bmp[] PROGMEM = { //AVR-GCC, WinAVR
157
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
158
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
159
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x61,0xF8,0x60,
160
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0xF8,0x20,
161
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0xF0,0x20,
162
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0x60,0x20,
163
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x58,0x01,0xA0,
164
+	0x7F,0x80,0x00,0x3F,0xC0,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
165
+	0xFB,0xC0,0x00,0x79,0xE0,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
166
+	0xF3,0xC0,0x00,0x76,0xE0,0x00,0x00,0x00,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
167
+	0xEB,0xC0,0x00,0x7E,0xE0,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
168
+	0x7B,0x80,0x00,0x3D,0xC0,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x58,0x01,0xA0,
169
+	0x7B,0x80,0x00,0x3B,0xC0,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x40,0x60,0x20,
170
+	0xFB,0xC0,0x00,0x77,0xE0,0x00,0x00,0x00,0x01,0x04,0x10,0x00,0x40,0xF0,0x20,
171
+	0xFB,0xC0,0x00,0x70,0xE0,0x00,0x00,0x00,0x00,0x82,0x08,0x00,0x41,0xF8,0x20,
172
+	0xFF,0xC0,0x00,0x7F,0xE0,0x00,0x00,0x00,0x00,0x41,0x04,0x00,0x61,0xF8,0x60,
173
+	0x3F,0x00,0x00,0x1F,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
174
+	0x1E,0x00,0x00,0x0F,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
175
+	0x0C,0x00,0x00,0x06,0x00,0x00,0x00,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
176
+	};
177
+#else
178
+	#define STATUS_SCREENWIDTH 		115	//Width in pixels
179
+	#define STATUS_SCREENHEIGHT 	19	//Height in pixels
180
+	#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
181
+	const unsigned char status_screen0_bmp[] PROGMEM = { //AVR-GCC, WinAVR
182
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
183
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
184
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x63,0x0C,0x60,
185
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x47,0x0E,0x20,
186
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x4F,0x0F,0x20,
187
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5F,0x0F,0xA0,
188
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x5E,0x07,0xA0,
189
+	0x7F,0x80,0x00,0x3F,0xC0,0x00,0x3F,0xC0,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
190
+	0xFB,0xC0,0x00,0x79,0xE0,0x00,0x79,0xE0,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
191
+	0xF3,0xC0,0x00,0x76,0xE0,0x00,0x76,0xE0,0x00,0x20,0x82,0x00,0x40,0xF0,0x20,
192
+	0xEB,0xC0,0x00,0x7E,0xE0,0x00,0x7E,0xE0,0x00,0x41,0x04,0x00,0x40,0x60,0x20,
193
+	0x7B,0x80,0x00,0x3D,0xC0,0x00,0x39,0xC0,0x00,0x82,0x08,0x00,0x5E,0x07,0xA0,
194
+	0x7B,0x80,0x00,0x3B,0xC0,0x00,0x3E,0xC0,0x01,0x04,0x10,0x00,0x5F,0x0F,0xA0,
195
+	0xFB,0xC0,0x00,0x77,0xE0,0x00,0x76,0xE0,0x01,0x04,0x10,0x00,0x4F,0x0F,0x20,
196
+	0xFB,0xC0,0x00,0x70,0xE0,0x00,0x79,0xE0,0x00,0x82,0x08,0x00,0x47,0x0E,0x20,
197
+	0xFF,0xC0,0x00,0x7F,0xE0,0x00,0x7F,0xE0,0x00,0x41,0x04,0x00,0x63,0x0C,0x60,
198
+	0x3F,0x00,0x00,0x1F,0x80,0x00,0x1F,0x80,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
199
+	0x1E,0x00,0x00,0x0F,0x00,0x00,0x0F,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
200
+	0x0C,0x00,0x00,0x06,0x00,0x00,0x06,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
201
+	};
202
+
203
+	#define STATUS_SCREENWIDTH 		115	//Width in pixels
204
+	#define STATUS_SCREENHEIGHT 	19	//Height in pixels
205
+	#define STATUS_SCREENBYTEWIDTH 	15	//Width in bytes
206
+	const unsigned char status_screen1_bmp[] PROGMEM = { //AVR-GCC, WinAVR
207
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x7F,0xFF,0xE0,
208
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
209
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x61,0xF8,0x60,
210
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x41,0xF8,0x20,
211
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0xF0,0x20,
212
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x40,0x60,0x20,
213
+	0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x58,0x01,0xA0,
214
+	0x7F,0x80,0x00,0x3F,0xC0,0x00,0x3F,0xC0,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
215
+	0xFB,0xC0,0x00,0x79,0xE0,0x00,0x79,0xE0,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
216
+	0xF3,0xC0,0x00,0x76,0xE0,0x00,0x76,0xE0,0x00,0x20,0x82,0x00,0x5E,0xF7,0xA0,
217
+	0xEB,0xC0,0x00,0x7E,0xE0,0x00,0x7E,0xE0,0x00,0x41,0x04,0x00,0x5C,0x63,0xA0,
218
+	0x7B,0x80,0x00,0x3D,0xC0,0x00,0x39,0xC0,0x00,0x82,0x08,0x00,0x58,0x01,0xA0,
219
+	0x7B,0x80,0x00,0x3B,0xC0,0x00,0x3E,0xC0,0x01,0x04,0x10,0x00,0x40,0x60,0x20,
220
+	0xFB,0xC0,0x00,0x77,0xE0,0x00,0x76,0xE0,0x01,0x04,0x10,0x00,0x40,0xF0,0x20,
221
+	0xFB,0xC0,0x00,0x70,0xE0,0x00,0x79,0xE0,0x00,0x82,0x08,0x00,0x41,0xF8,0x20,
222
+	0xFF,0xC0,0x00,0x7F,0xE0,0x00,0x7F,0xE0,0x00,0x41,0x04,0x00,0x61,0xF8,0x60,
223
+	0x3F,0x00,0x00,0x1F,0x80,0x00,0x1F,0x80,0x00,0x00,0x00,0x00,0x70,0x00,0xE0,
224
+	0x1E,0x00,0x00,0x0F,0x00,0x00,0x0F,0x00,0x01,0xFF,0xFF,0x80,0x7F,0xFF,0xE0,
225
+	0x0C,0x00,0x00,0x06,0x00,0x00,0x06,0x00,0x01,0xFF,0xFF,0x80,0x00,0x00,0x00
226
+	};
227
+#endif // Extruders 
120
 
228
 
121
 
229
 

+ 28
- 7
Marlin/Marlin_main.cpp View File

1385
       st_synchronize();
1385
       st_synchronize();
1386
       codenum += millis();  // keep track of when we started waiting
1386
       codenum += millis();  // keep track of when we started waiting
1387
       previous_millis_cmd = millis();
1387
       previous_millis_cmd = millis();
1388
-      while(millis()  < codenum ){
1388
+      while(millis() < codenum) {
1389
         manage_heater();
1389
         manage_heater();
1390
         manage_inactivity();
1390
         manage_inactivity();
1391
         lcd_update();
1391
         lcd_update();
1413
       plan_bed_level_matrix.set_to_identity();  //Reset the plane ("erase" all leveling data)
1413
       plan_bed_level_matrix.set_to_identity();  //Reset the plane ("erase" all leveling data)
1414
 #endif //ENABLE_AUTO_BED_LEVELING
1414
 #endif //ENABLE_AUTO_BED_LEVELING
1415
 
1415
 
1416
-
1417
       saved_feedrate = feedrate;
1416
       saved_feedrate = feedrate;
1418
       saved_feedmultiply = feedmultiply;
1417
       saved_feedmultiply = feedmultiply;
1419
       feedmultiply = 100;
1418
       feedmultiply = 100;
1863
     case 0: // M0 - Unconditional stop - Wait for user button press on LCD
1862
     case 0: // M0 - Unconditional stop - Wait for user button press on LCD
1864
     case 1: // M1 - Conditional stop - Wait for user button press on LCD
1863
     case 1: // M1 - Conditional stop - Wait for user button press on LCD
1865
     {
1864
     {
1866
-      LCD_MESSAGEPGM(MSG_USERWAIT);
1865
+      char *src = strchr_pointer + 2;
1866
+
1867
       codenum = 0;
1867
       codenum = 0;
1868
-      if(code_seen('P')) codenum = code_value(); // milliseconds to wait
1869
-      if(code_seen('S')) codenum = code_value() * 1000; // seconds to wait
1870
 
1868
 
1869
+      bool hasP = false, hasS = false;
1870
+      if (code_seen('P')) {
1871
+        codenum = code_value(); // milliseconds to wait
1872
+        hasP = codenum > 0;
1873
+      }
1874
+      if (code_seen('S')) {
1875
+        codenum = code_value() * 1000; // seconds to wait
1876
+        hasS = codenum > 0;
1877
+      }
1878
+      starpos = strchr(src, '*');
1879
+      if (starpos != NULL) *(starpos) = '\0';
1880
+      while (*src == ' ') ++src;
1881
+      if (!hasP && !hasS && *src != '\0') {
1882
+        lcd_setstatus(src);
1883
+      } else {
1884
+        LCD_MESSAGEPGM(MSG_USERWAIT);
1885
+      }
1886
+
1887
+      lcd_ignore_click();
1871
       st_synchronize();
1888
       st_synchronize();
1872
       previous_millis_cmd = millis();
1889
       previous_millis_cmd = millis();
1873
       if (codenum > 0){
1890
       if (codenum > 0){
1874
         codenum += millis();  // keep track of when we started waiting
1891
         codenum += millis();  // keep track of when we started waiting
1875
-        while(millis()  < codenum && !lcd_clicked()){
1892
+        while(millis() < codenum && !lcd_clicked()){
1876
           manage_heater();
1893
           manage_heater();
1877
           manage_inactivity();
1894
           manage_inactivity();
1878
           lcd_update();
1895
           lcd_update();
1879
         }
1896
         }
1897
+        lcd_ignore_click(false);
1880
       }else{
1898
       }else{
1881
           if (!lcd_detected())
1899
           if (!lcd_detected())
1882
             break;
1900
             break;
1886
           lcd_update();
1904
           lcd_update();
1887
         }
1905
         }
1888
       }
1906
       }
1889
-      LCD_MESSAGEPGM(MSG_RESUMING);
1907
+      if (IS_SD_PRINTING)
1908
+        LCD_MESSAGEPGM(MSG_RESUMING);
1909
+      else
1910
+        LCD_MESSAGEPGM(WELCOME_MSG);
1890
     }
1911
     }
1891
     break;
1912
     break;
1892
 #endif
1913
 #endif

+ 0
- 6
Marlin/dogm_lcd_implementation.h View File

245
 		 u8g.drawBox(38,17,2,2);
245
 		 u8g.drawBox(38,17,2,2);
246
 		 u8g.setColorIndex(1);	// black on white
246
 		 u8g.setColorIndex(1);	// black on white
247
 		}
247
 		}
248
- #else
249
- u8g.setPrintPos(31,27);
250
- u8g.print("---");
251
  #endif
248
  #endif
252
  
249
  
253
  // Extruder 3
250
  // Extruder 3
266
 		 u8g.drawBox(62,17,2,2);
263
 		 u8g.drawBox(62,17,2,2);
267
 		 u8g.setColorIndex(1);	// black on white
264
 		 u8g.setColorIndex(1);	// black on white
268
 		}
265
 		}
269
- #else
270
- u8g.setPrintPos(55,27);
271
- u8g.print("---");
272
  #endif
266
  #endif
273
  
267
  
274
  // Heatbed
268
  // Heatbed

+ 154
- 9
Marlin/example_configurations/delta/Configuration.h View File

41
 // 33 = RAMPS 1.3 / 1.4 (Power outputs: Extruder, Fan, Bed)
41
 // 33 = RAMPS 1.3 / 1.4 (Power outputs: Extruder, Fan, Bed)
42
 // 34 = RAMPS 1.3 / 1.4 (Power outputs: Extruder0, Extruder1, Bed)
42
 // 34 = RAMPS 1.3 / 1.4 (Power outputs: Extruder0, Extruder1, Bed)
43
 // 35 = RAMPS 1.3 / 1.4 (Power outputs: Extruder, Fan, Fan)
43
 // 35 = RAMPS 1.3 / 1.4 (Power outputs: Extruder, Fan, Fan)
44
+// 36 = RAMPS 1.3 / 1.4 (Power outputs: Extruder0, Extruder1, Fan)
44
 // 4  = Duemilanove w/ ATMega328P pin assignment
45
 // 4  = Duemilanove w/ ATMega328P pin assignment
45
 // 5  = Gen6
46
 // 5  = Gen6
46
 // 51 = Gen6 deluxe
47
 // 51 = Gen6 deluxe
54
 // 68 = Azteeg X3 Pro
55
 // 68 = Azteeg X3 Pro
55
 // 7  = Ultimaker
56
 // 7  = Ultimaker
56
 // 71 = Ultimaker (Older electronics. Pre 1.5.4. This is rare)
57
 // 71 = Ultimaker (Older electronics. Pre 1.5.4. This is rare)
58
+// 72 = Ultimainboard 2.x (Uses TEMP_SENSOR 20)
57
 // 77 = 3Drag Controller
59
 // 77 = 3Drag Controller
58
 // 8  = Teensylu
60
 // 8  = Teensylu
59
 // 80 = Rumba
61
 // 80 = Rumba
60
 // 81 = Printrboard (AT90USB1286)
62
 // 81 = Printrboard (AT90USB1286)
61
 // 82 = Brainwave (AT90USB646)
63
 // 82 = Brainwave (AT90USB646)
62
 // 83 = SAV Mk-I (AT90USB1286)
64
 // 83 = SAV Mk-I (AT90USB1286)
65
+// 84 = Teensy++2.0 (AT90USB1286) // CLI compile: DEFINES=AT90USBxx_TEENSYPP_ASSIGNMENTS HARDWARE_MOTHERBOARD=84  make
63
 // 9  = Gen3+
66
 // 9  = Gen3+
64
 // 70 = Megatronics
67
 // 70 = Megatronics
65
 // 701= Megatronics v2.0
68
 // 701= Megatronics v2.0
68
 // 91 = Final OMCA board
71
 // 91 = Final OMCA board
69
 // 301= Rambo
72
 // 301= Rambo
70
 // 21 = Elefu Ra Board (v3)
73
 // 21 = Elefu Ra Board (v3)
74
+// 88 = 5DPrint D8 Driver Board
75
+// 999 = Leapfrog
71
 
76
 
72
 #ifndef MOTHERBOARD
77
 #ifndef MOTHERBOARD
73
 #define MOTHERBOARD 33
78
 #define MOTHERBOARD 33
141
 // 8 is 100k 0603 SMD Vishay NTCS0603E3104FXT (4.7k pullup)
146
 // 8 is 100k 0603 SMD Vishay NTCS0603E3104FXT (4.7k pullup)
142
 // 9 is 100k GE Sensing AL03006-58.2K-97-G1 (4.7k pullup)
147
 // 9 is 100k GE Sensing AL03006-58.2K-97-G1 (4.7k pullup)
143
 // 10 is 100k RS thermistor 198-961 (4.7k pullup)
148
 // 10 is 100k RS thermistor 198-961 (4.7k pullup)
144
-// 60 is 100k Maker's Tool Works Kapton Bed Thermistor
149
+// 11 is 100k beta 3950 1% thermistor (4.7k pullup)
150
+// 12 is 100k 0603 SMD Vishay NTCS0603E3104FXT (4.7k pullup) (calibrated for Makibox hot bed)
151
+// 13 is 100k Hisens 3950  1% up to 300°C for hotend "Simple ONE " & "Hotend "All In ONE" 
152
+// 20 is the PT100 circuit found in the Ultimainboard V2.x
153
+// 60 is 100k Maker's Tool Works Kapton Bed Thermistor beta=3950
145
 //
154
 //
146
 //    1k ohm pullup tables - This is not normal, you would have to have changed out your 4.7k for 1k
155
 //    1k ohm pullup tables - This is not normal, you would have to have changed out your 4.7k for 1k
147
 //                          (but gives greater accuracy and more stable PID)
156
 //                          (but gives greater accuracy and more stable PID)
205
                                   // is more then PID_FUNCTIONAL_RANGE then the PID will be shut off and the heater will be set to min/max.
214
                                   // is more then PID_FUNCTIONAL_RANGE then the PID will be shut off and the heater will be set to min/max.
206
   #define PID_INTEGRAL_DRIVE_MAX 255  //limit for the integral term
215
   #define PID_INTEGRAL_DRIVE_MAX 255  //limit for the integral term
207
   #define K1 0.95 //smoothing factor within the PID
216
   #define K1 0.95 //smoothing factor within the PID
208
-  #define PID_dT ((16.0 * 8.0)/(F_CPU / 64.0 / 256.0)) //sampling period of the temperature routine
217
+  #define PID_dT ((OVERSAMPLENR * 10.0)/(F_CPU / 64.0 / 256.0)) //sampling period of the temperature routine
209
 
218
 
210
 // If you are using a pre-configured hotend then you can use one of the value sets by uncommenting it
219
 // If you are using a pre-configured hotend then you can use one of the value sets by uncommenting it
211
 // Ultimaker
220
 // Ultimaker
271
 #define EXTRUDE_MINTEMP 170
280
 #define EXTRUDE_MINTEMP 170
272
 #define EXTRUDE_MAXLENGTH (X_MAX_LENGTH+Y_MAX_LENGTH) //prevent extrusion of very large distances.
281
 #define EXTRUDE_MAXLENGTH (X_MAX_LENGTH+Y_MAX_LENGTH) //prevent extrusion of very large distances.
273
 
282
 
283
+/*================== Thermal Runaway Protection ==============================
284
+This is a feature to protect your printer from burn up in flames if it has
285
+a thermistor coming off place (this happened to a friend of mine recently and
286
+motivated me writing this feature).
287
+
288
+The issue: If a thermistor come off, it will read a lower temperature than actual.
289
+The system will turn the heater on forever, burning up the filament and anything
290
+else around.
291
+
292
+After the temperature reaches the target for the first time, this feature will 
293
+start measuring for how long the current temperature stays below the target 
294
+minus _HYSTERESIS (set_temperature - THERMAL_RUNAWAY_PROTECTION_HYSTERESIS).
295
+
296
+If it stays longer than _PERIOD, it means the thermistor temperature
297
+cannot catch up with the target, so something *may be* wrong. Then, to be on the
298
+safe side, the system will he halt.
299
+
300
+Bear in mind the count down will just start AFTER the first time the 
301
+thermistor temperature is over the target, so you will have no problem if
302
+your extruder heater takes 2 minutes to hit the target on heating.
303
+
304
+*/
305
+// If you want to enable this feature for all your extruder heaters,
306
+// uncomment the 2 defines below:
307
+
308
+// Parameters for all extruder heaters
309
+//#define THERMAL_RUNAWAY_PROTECTION_PERIOD 40 //in seconds
310
+//#define THERMAL_RUNAWAY_PROTECTION_HYSTERESIS 4 // in degree Celsius
311
+
312
+// If you want to enable this feature for your bed heater,
313
+// uncomment the 2 defines below:
314
+
315
+// Parameters for the bed heater
316
+//#define THERMAL_RUNAWAY_PROTECTION_BED_PERIOD 20 //in seconds
317
+//#define THERMAL_RUNAWAY_PROTECTION_BED_HYSTERESIS 2 // in degree Celsius
318
+//===========================================================================
319
+
320
+
274
 //===========================================================================
321
 //===========================================================================
275
 //=============================Mechanical Settings===========================
322
 //=============================Mechanical Settings===========================
276
 //===========================================================================
323
 //===========================================================================
326
 #define DISABLE_Y false
373
 #define DISABLE_Y false
327
 #define DISABLE_Z false
374
 #define DISABLE_Z false
328
 #define DISABLE_E false // For all extruders
375
 #define DISABLE_E false // For all extruders
376
+#define DISABLE_INACTIVE_EXTRUDER true //disable only inactive extruders and keep active extruder enabled
329
 
377
 
330
 #define INVERT_X_DIR false // DELTA does not invert
378
 #define INVERT_X_DIR false // DELTA does not invert
331
 #define INVERT_Y_DIR false
379
 #define INVERT_Y_DIR false
359
 //============================= Bed Auto Leveling ===========================
407
 //============================= Bed Auto Leveling ===========================
360
 
408
 
361
 //#define ENABLE_AUTO_BED_LEVELING // Delete the comment to enable (remove // at the start of the line)
409
 //#define ENABLE_AUTO_BED_LEVELING // Delete the comment to enable (remove // at the start of the line)
410
+#define Z_PROBE_REPEATABILITY_TEST  // If not commented out, Z-Probe Repeatability test will be included if Auto Bed Leveling is Enabled.
362
 
411
 
363
 #ifdef ENABLE_AUTO_BED_LEVELING
412
 #ifdef ENABLE_AUTO_BED_LEVELING
364
 
413
 
365
-  // these are the positions on the bed to do the probing
366
-  #define LEFT_PROBE_BED_POSITION 15
367
-  #define RIGHT_PROBE_BED_POSITION 170
368
-  #define BACK_PROBE_BED_POSITION 180
369
-  #define FRONT_PROBE_BED_POSITION 20
414
+// There are 2 different ways to pick the X and Y locations to probe:
415
+
416
+//  - "grid" mode
417
+//    Probe every point in a rectangular grid
418
+//    You must specify the rectangle, and the density of sample points
419
+//    This mode is preferred because there are more measurements.
420
+//    It used to be called ACCURATE_BED_LEVELING but "grid" is more descriptive
421
+
422
+//  - "3-point" mode
423
+//    Probe 3 arbitrary points on the bed (that aren't colinear)
424
+//    You must specify the X & Y coordinates of all 3 points
425
+
426
+  #define AUTO_BED_LEVELING_GRID
427
+  // with AUTO_BED_LEVELING_GRID, the bed is sampled in a
428
+  // AUTO_BED_LEVELING_GRID_POINTSxAUTO_BED_LEVELING_GRID_POINTS grid
429
+  // and least squares solution is calculated
430
+  // Note: this feature occupies 10'206 byte
431
+  #ifdef AUTO_BED_LEVELING_GRID
432
+
433
+    // set the rectangle in which to probe
434
+    #define LEFT_PROBE_BED_POSITION 15
435
+    #define RIGHT_PROBE_BED_POSITION 170
436
+    #define BACK_PROBE_BED_POSITION 180
437
+    #define FRONT_PROBE_BED_POSITION 20
438
+
439
+     // set the number of grid points per dimension
440
+     // I wouldn't see a reason to go above 3 (=9 probing points on the bed)
441
+    #define AUTO_BED_LEVELING_GRID_POINTS 2
442
+
443
+
444
+  #else  // not AUTO_BED_LEVELING_GRID
445
+    // with no grid, just probe 3 arbitrary points.  A simple cross-product
446
+    // is used to esimate the plane of the print bed
447
+
448
+      #define ABL_PROBE_PT_1_X 15
449
+      #define ABL_PROBE_PT_1_Y 180
450
+      #define ABL_PROBE_PT_2_X 15
451
+      #define ABL_PROBE_PT_2_Y 20
452
+      #define ABL_PROBE_PT_3_X 170
453
+      #define ABL_PROBE_PT_3_Y 20
454
+
455
+  #endif // AUTO_BED_LEVELING_GRID
456
+
370
 
457
 
371
   // these are the offsets to the probe relative to the extruder tip (Hotend - Probe)
458
   // these are the offsets to the probe relative to the extruder tip (Hotend - Probe)
372
   #define X_PROBE_OFFSET_FROM_EXTRUDER -25
459
   #define X_PROBE_OFFSET_FROM_EXTRUDER -25
381
   #define Z_RAISE_BEFORE_PROBING 15    //How much the extruder will be raised before traveling to the first probing point.
468
   #define Z_RAISE_BEFORE_PROBING 15    //How much the extruder will be raised before traveling to the first probing point.
382
   #define Z_RAISE_BETWEEN_PROBINGS 5  //How much the extruder will be raised when traveling from between next probing points
469
   #define Z_RAISE_BETWEEN_PROBINGS 5  //How much the extruder will be raised when traveling from between next probing points
383
 
470
 
471
+  //#define Z_PROBE_SLED // turn on if you have a z-probe mounted on a sled like those designed by Charles Bell
472
+  //#define SLED_DOCKING_OFFSET 5 // the extra distance the X axis must travel to pickup the sled. 0 should be fine but you can push it further if you'd like.
384
 
473
 
385
   //If defined, the Probe servo will be turned on only during movement and then turned off to avoid jerk
474
   //If defined, the Probe servo will be turned on only during movement and then turned off to avoid jerk
386
   //The value is the delay to turn the servo off after powered on - depends on the servo speed; 300ms is good value, but you can try lower it.
475
   //The value is the delay to turn the servo off after powered on - depends on the servo speed; 300ms is good value, but you can try lower it.
406
 
495
 
407
   #endif
496
   #endif
408
 
497
 
409
-#endif
498
+#endif // ENABLE_AUTO_BED_LEVELING
410
 
499
 
411
 
500
 
412
 // The position of the homing switches
501
 // The position of the homing switches
451
 //=============================Additional Features===========================
540
 //=============================Additional Features===========================
452
 //===========================================================================
541
 //===========================================================================
453
 
542
 
543
+// Custom M code points
544
+#define CUSTOM_M_CODES
545
+#ifdef CUSTOM_M_CODES
546
+  #define CUSTOM_M_CODE_SET_Z_PROBE_OFFSET 851
547
+  #define Z_PROBE_OFFSET_RANGE_MIN -15
548
+  #define Z_PROBE_OFFSET_RANGE_MAX -5
549
+#endif
550
+
551
+
454
 // EEPROM
552
 // EEPROM
455
 // The microcontroller can store settings in the EEPROM, e.g. max velocity...
553
 // The microcontroller can store settings in the EEPROM, e.g. max velocity...
456
 // M500 - stores parameters in EEPROM
554
 // M500 - stores parameters in EEPROM
476
 //#define DOGLCD  // Support for SPI LCD 128x64 (Controller ST7565R graphic Display Family)
574
 //#define DOGLCD  // Support for SPI LCD 128x64 (Controller ST7565R graphic Display Family)
477
 //#define SDSUPPORT // Enable SD Card Support in Hardware Console
575
 //#define SDSUPPORT // Enable SD Card Support in Hardware Console
478
 //#define SDSLOW // Use slower SD transfer mode (not normally needed - uncomment if you're getting volume init error)
576
 //#define SDSLOW // Use slower SD transfer mode (not normally needed - uncomment if you're getting volume init error)
577
+//#define SD_CHECK_AND_RETRY // Use CRC checks and retries on the SD communication
479
 //#define ENCODER_PULSES_PER_STEP 1 // Increase if you have a high resolution encoder
578
 //#define ENCODER_PULSES_PER_STEP 1 // Increase if you have a high resolution encoder
480
 //#define ENCODER_STEPS_PER_MENU_ITEM 5 // Set according to ENCODER_PULSES_PER_STEP or your liking
579
 //#define ENCODER_STEPS_PER_MENU_ITEM 5 // Set according to ENCODER_PULSES_PER_STEP or your liking
481
 //#define ULTIMAKERCONTROLLER //as available from the Ultimaker online store.
580
 //#define ULTIMAKERCONTROLLER //as available from the Ultimaker online store.
482
 //#define ULTIPANEL  //the UltiPanel as on Thingiverse
581
 //#define ULTIPANEL  //the UltiPanel as on Thingiverse
582
+//#define LCD_FEEDBACK_FREQUENCY_HZ 1000	// this is the tone frequency the buzzer plays when on UI feedback. ie Screen Click
583
+//#define LCD_FEEDBACK_FREQUENCY_DURATION_MS 100 // the duration the buzzer plays the UI feedback sound. ie Screen Click
483
 
584
 
484
 // The MaKr3d Makr-Panel with graphic controller and SD support
585
 // The MaKr3d Makr-Panel with graphic controller and SD support
485
 // http://reprap.org/wiki/MaKr3d_MaKrPanel
586
 // http://reprap.org/wiki/MaKr3d_MaKrPanel
565
   #define LCD_USE_I2C_BUZZER //comment out to disable buzzer on LCD
666
   #define LCD_USE_I2C_BUZZER //comment out to disable buzzer on LCD
566
   #define NEWPANEL
667
   #define NEWPANEL
567
   #define ULTIPANEL
668
   #define ULTIPANEL
669
+
670
+  #ifndef ENCODER_PULSES_PER_STEP
671
+	#define ENCODER_PULSES_PER_STEP 4
672
+  #endif
673
+
674
+  #ifndef ENCODER_STEPS_PER_MENU_ITEM
675
+	#define ENCODER_STEPS_PER_MENU_ITEM 1
676
+  #endif
677
+
678
+
679
+  #ifdef LCD_USE_I2C_BUZZER
680
+	#define LCD_FEEDBACK_FREQUENCY_HZ 1000
681
+	#define LCD_FEEDBACK_FREQUENCY_DURATION_MS 100
682
+  #endif
683
+
568
 #endif
684
 #endif
569
 
685
 
570
 // Panucatt VIKI LCD with status LEDs, integrated click & L/R/U/P buttons, separate encoder inputs
686
 // Panucatt VIKI LCD with status LEDs, integrated click & L/R/U/P buttons, separate encoder inputs
587
 // https://bitbucket.org/fmalpartida/new-liquidcrystal/wiki/schematics#!shiftregister-connection
703
 // https://bitbucket.org/fmalpartida/new-liquidcrystal/wiki/schematics#!shiftregister-connection
588
 //#define SR_LCD
704
 //#define SR_LCD
589
 #ifdef SR_LCD
705
 #ifdef SR_LCD
590
-   #define SR_LCD_2W_NL    // Non latching 2 wire shiftregister
706
+   #define SR_LCD_2W_NL    // Non latching 2 wire shift register
591
    //#define NEWPANEL
707
    //#define NEWPANEL
592
 #endif
708
 #endif
593
 
709
 
676
 //#define SERVO_ENDSTOPS {-1, -1, 0} // Servo index for X, Y, Z. Disable with -1
792
 //#define SERVO_ENDSTOPS {-1, -1, 0} // Servo index for X, Y, Z. Disable with -1
677
 //#define SERVO_ENDSTOP_ANGLES {0,0, 0,0, 70,0} // X,Y,Z Axis Extend and Retract angles
793
 //#define SERVO_ENDSTOP_ANGLES {0,0, 0,0, 70,0} // X,Y,Z Axis Extend and Retract angles
678
 
794
 
795
+/**********************************************************************\
796
+ * Support for a filament diameter sensor
797
+ * Also allows adjustment of diameter at print time (vs  at slicing)
798
+ * Single extruder only at this point (extruder 0)
799
+ * 
800
+ * Motherboards
801
+ * 34 - RAMPS1.4 - uses Analog input 5 on the AUX2 connector 
802
+ * 81 - Printrboard - Uses Analog input 2 on the Aux 2 connector
803
+ * 301 - Rambo  - uses Analog input 3
804
+ * Note may require analog pins to be defined for different motherboards
805
+ **********************************************************************/
806
+#define FILAMENT_SENSOR
807
+#define FILAMENT_SENSOR_EXTRUDER_NUM	0  //The number of the extruder that has the filament sensor (0,1,2)
808
+#define MEASUREMENT_DELAY_CM			14  //measurement delay in cm.  This is the distance from filament sensor to middle of barrel
809
+
810
+#define DEFAULT_NOMINAL_FILAMENT_DIA  3.0  //Enter the diameter (in mm) of the filament generally used (3.0 mm or 1.75 mm) - this is then used in the slicer software.  Used for sensor reading validation
811
+#define MEASURED_UPPER_LIMIT          3.30  //upper limit factor used for sensor reading validation in mm
812
+#define MEASURED_LOWER_LIMIT          1.90  //lower limit factor for sensor reading validation in mm
813
+#define MAX_MEASUREMENT_DELAY			20  //delay buffer size in bytes (1 byte = 1cm)- limits maximum measurement delay allowable (must be larger than MEASUREMENT_DELAY_CM  and lower number saves RAM)
814
+
815
+//defines used in the code
816
+#define DEFAULT_MEASURED_FILAMENT_DIA  DEFAULT_NOMINAL_FILAMENT_DIA  //set measured to nominal initially 
817
+
818
+
819
+
820
+
821
+
822
+
823
+
679
 #include "Configuration_adv.h"
824
 #include "Configuration_adv.h"
680
 #include "thermistortables.h"
825
 #include "thermistortables.h"
681
 
826
 

+ 13
- 2
Marlin/example_configurations/delta/Configuration_adv.h View File

281
 //=============================Additional Features===========================
281
 //=============================Additional Features===========================
282
 //===========================================================================
282
 //===========================================================================
283
 
283
 
284
+//#define CHDK 4        //Pin for triggering CHDK to take a picture see how to use it here http://captain-slow.dk/2014/03/09/3d-printing-timelapses/
285
+#define CHDK_DELAY 50 //How long in ms the pin should stay HIGH before going LOW again
286
+
284
 #define SD_FINISHED_STEPPERRELEASE true  //if sd support and the file is finished: disable steppers?
287
 #define SD_FINISHED_STEPPERRELEASE true  //if sd support and the file is finished: disable steppers?
285
 #define SD_FINISHED_RELEASECOMMAND "M84 X Y Z E" // You might want to keep the z enabled so your bed stays in place.
288
 #define SD_FINISHED_RELEASECOMMAND "M84 X Y Z E" // You might want to keep the z enabled so your bed stays in place.
286
 
289
 
401
 // the moves are than replaced by the firmware controlled ones.
404
 // the moves are than replaced by the firmware controlled ones.
402
 
405
 
403
 // #define FWRETRACT  //ONLY PARTIALLY TESTED
406
 // #define FWRETRACT  //ONLY PARTIALLY TESTED
404
-#define MIN_RETRACT 0.1 //minimum extruded mm to accept a automatic gcode retraction attempt
405
-
407
+#ifdef FWRETRACT
408
+  #define MIN_RETRACT 0.1                //minimum extruded mm to accept a automatic gcode retraction attempt
409
+  #define RETRACT_LENGTH 3               //default retract length (positive mm)
410
+  #define RETRACT_LENGTH_SWAP 13         //default swap retract length (positive mm), for extruder change
411
+  #define RETRACT_FEEDRATE 45            //default feedrate for retracting (mm/s)
412
+  #define RETRACT_ZLIFT 0                //default retract Z-lift
413
+  #define RETRACT_RECOVER_LENGTH 0       //default additional recover length (mm, added to retract length when recovering)
414
+  #define RETRACT_RECOVER_LENGTH_SWAP 0  //default additional swap recover length (mm, added to retract length when recovering from extruder change)
415
+  #define RETRACT_RECOVER_FEEDRATE 8     //default feedrate for recovering from retraction (mm/s)
416
+#endif
406
 
417
 
407
 //adds support for experimental filament exchange support M600; requires display
418
 //adds support for experimental filament exchange support M600; requires display
408
 #ifdef ULTIPANEL
419
 #ifdef ULTIPANEL

+ 8
- 8
Marlin/language.h View File

665
 	#define MSG_AUTOSTART " Autostart"
665
 	#define MSG_AUTOSTART " Autostart"
666
 	#define MSG_DISABLE_STEPPERS "Apagar motores"
666
 	#define MSG_DISABLE_STEPPERS "Apagar motores"
667
 	#define MSG_AUTO_HOME "Llevar al origen"
667
 	#define MSG_AUTO_HOME "Llevar al origen"
668
-	#define MSG_SET_HOME_OFFSETS "Set home offsets"
668
+	#define MSG_SET_HOME_OFFSETS "Ajustar offsets"
669
 	#define MSG_SET_ORIGIN "Establecer cero"
669
 	#define MSG_SET_ORIGIN "Establecer cero"
670
 	#define MSG_PREHEAT_PLA "Precalentar PLA"
670
 	#define MSG_PREHEAT_PLA "Precalentar PLA"
671
 	#define MSG_PREHEAT_PLA0 "Precalentar PLA 1"
671
 	#define MSG_PREHEAT_PLA0 "Precalentar PLA 1"
682
 	#define MSG_PREHEAT_ABS_BEDONLY "Precal. ABS Base"
682
 	#define MSG_PREHEAT_ABS_BEDONLY "Precal. ABS Base"
683
 	#define MSG_PREHEAT_ABS_SETTINGS "Ajustar temp. ABS"
683
 	#define MSG_PREHEAT_ABS_SETTINGS "Ajustar temp. ABS"
684
 	#define MSG_COOLDOWN "Enfriar"
684
 	#define MSG_COOLDOWN "Enfriar"
685
-	#define MSG_SWITCH_PS_ON "Switch Power On"
686
-	#define MSG_SWITCH_PS_OFF "Switch Power Off"
685
+	#define MSG_SWITCH_PS_ON "Encender"
686
+	#define MSG_SWITCH_PS_OFF "Apagar"
687
 	#define MSG_EXTRUDE "Extruir"
687
 	#define MSG_EXTRUDE "Extruir"
688
 	#define MSG_RETRACT "Retraer"
688
 	#define MSG_RETRACT "Retraer"
689
 	#define MSG_MOVE_AXIS "Mover ejes"
689
 	#define MSG_MOVE_AXIS "Mover ejes"
727
 	#define MSG_Z "z"
727
 	#define MSG_Z "z"
728
 	#define MSG_E "e"
728
 	#define MSG_E "e"
729
 	#define MSG_VMIN "Vmin"
729
 	#define MSG_VMIN "Vmin"
730
-	#define MSG_VTRAV_MIN "VTrav min"
730
+	#define MSG_VTRAV_MIN "Vvacio min"
731
 	#define MSG_AMAX "Amax"
731
 	#define MSG_AMAX "Amax"
732
 	#define MSG_A_RETRACT "A-retrac."
732
 	#define MSG_A_RETRACT "A-retrac."
733
 	#define MSG_XSTEPS "X pasos/mm"
733
 	#define MSG_XSTEPS "X pasos/mm"
775
 	#define MSG_CONTROL_ARROW "Control"
775
 	#define MSG_CONTROL_ARROW "Control"
776
 	#define MSG_RETRACT_ARROW "Retraer"
776
 	#define MSG_RETRACT_ARROW "Retraer"
777
 	#define MSG_STEPPER_RELEASED "Desacoplada."
777
 	#define MSG_STEPPER_RELEASED "Desacoplada."
778
-	#define MSG_ZPROBE_OUT "Z probe out. bed"
779
-	#define MSG_POSITION_UNKNOWN "Home X/Y before Z"
780
-	#define MSG_ZPROBE_ZOFFSET "Z Offset"
778
+	#define MSG_ZPROBE_OUT "sonda Z fuera"
779
+	#define MSG_POSITION_UNKNOWN "Reiniciar X/Y y Z"
780
+	#define MSG_ZPROBE_ZOFFSET "Offset Z"
781
 	#define MSG_BABYSTEP_X "Babystep X"
781
 	#define MSG_BABYSTEP_X "Babystep X"
782
 	#define MSG_BABYSTEP_Y "Babystep Y"
782
 	#define MSG_BABYSTEP_Y "Babystep Y"
783
 	#define MSG_BABYSTEP_Z "Babystep Z"
783
 	#define MSG_BABYSTEP_Z "Babystep Z"
784
 	#define MSG_ENDSTOP_ABORT "Endstop abort"
784
 	#define MSG_ENDSTOP_ABORT "Endstop abort"
785
-	#define MSG_CONTRAST "Contrast"
785
+	#define MSG_CONTRAST "Contraste"
786
 
786
 
787
 #endif
787
 #endif
788
 
788
 

+ 53
- 0
Marlin/stepper.cpp View File

559
       #endif //ADVANCE
559
       #endif //ADVANCE
560
 
560
 
561
         counter_x += current_block->steps_x;
561
         counter_x += current_block->steps_x;
562
+        #ifdef CONFIG_STEPPERS_TOSHIBA
563
+	/* The toshiba stepper controller require much longer pulses
564
+	 * tjerfore we 'stage' decompose the pulses between high, and
565
+	 * low instead of doing each in turn. The extra tests add enough
566
+	 * lag to allow it work with without needing NOPs */ 
567
+      if (counter_x > 0) {
568
+        WRITE(X_STEP_PIN, HIGH);
569
+      }
570
+
571
+      counter_y += current_block->steps_y;
572
+      if (counter_y > 0) {
573
+        WRITE(Y_STEP_PIN, HIGH);
574
+      }
575
+
576
+      counter_z += current_block->steps_z;
577
+      if (counter_z > 0) {
578
+        WRITE(Z_STEP_PIN, HIGH);
579
+      }
580
+
581
+      #ifndef ADVANCE
582
+        counter_e += current_block->steps_e;
583
+        if (counter_e > 0) {
584
+          WRITE_E_STEP(HIGH);
585
+        }
586
+      #endif //!ADVANCE
587
+
588
+      if (counter_x > 0) {
589
+        counter_x -= current_block->step_event_count;
590
+        count_position[X_AXIS]+=count_direction[X_AXIS];   
591
+        WRITE(X_STEP_PIN, LOW);
592
+      }
593
+
594
+      if (counter_y > 0) {
595
+        counter_y -= current_block->step_event_count;
596
+        count_position[Y_AXIS]+=count_direction[Y_AXIS];
597
+        WRITE(Y_STEP_PIN, LOW);
598
+      }
599
+
600
+      if (counter_z > 0) {
601
+        counter_z -= current_block->step_event_count;
602
+        count_position[Z_AXIS]+=count_direction[Z_AXIS];
603
+        WRITE(Z_STEP_PIN, LOW);
604
+      }
605
+
606
+      #ifndef ADVANCE
607
+        if (counter_e > 0) {
608
+          counter_e -= current_block->step_event_count;
609
+          count_position[E_AXIS]+=count_direction[E_AXIS];
610
+          WRITE_E_STEP(LOW);
611
+        }
612
+      #endif //!ADVANCE
613
+#else
562
         if (counter_x > 0) {
614
         if (counter_x > 0) {
563
         #ifdef DUAL_X_CARRIAGE
615
         #ifdef DUAL_X_CARRIAGE
564
           if (extruder_duplication_enabled){
616
           if (extruder_duplication_enabled){
635
           WRITE_E_STEP(INVERT_E_STEP_PIN);
687
           WRITE_E_STEP(INVERT_E_STEP_PIN);
636
         }
688
         }
637
       #endif //!ADVANCE
689
       #endif //!ADVANCE
690
+      #endif
638
       step_events_completed += 1;
691
       step_events_completed += 1;
639
       if(step_events_completed >= current_block->step_event_count) break;
692
       if(step_events_completed >= current_block->step_event_count) break;
640
     }
693
     }

+ 28
- 1
Marlin/ultralcd.cpp View File

162
 menuFunc_t currentMenu = lcd_status_screen; /* function pointer to the currently active menu */
162
 menuFunc_t currentMenu = lcd_status_screen; /* function pointer to the currently active menu */
163
 uint32_t lcd_next_update_millis;
163
 uint32_t lcd_next_update_millis;
164
 uint8_t lcd_status_update_delay;
164
 uint8_t lcd_status_update_delay;
165
+bool ignore_click = false;
166
+bool wait_for_unclick;
165
 uint8_t lcdDrawUpdate = 2;                  /* Set to none-zero when the LCD needs to draw, decreased after every draw. Set to 2 in LCD routines so the LCD gets at least 1 full redraw (first redraw is partial) */
167
 uint8_t lcdDrawUpdate = 2;                  /* Set to none-zero when the LCD needs to draw, decreased after every draw. Set to 2 in LCD routines so the LCD gets at least 1 full redraw (first redraw is partial) */
166
 
168
 
167
 //prevMenu and prevEncoderPosition are used to store the previous menu location when editing settings.
169
 //prevMenu and prevEncoderPosition are used to store the previous menu location when editing settings.
189
         lcd_status_update_delay = 10;   /* redraw the main screen every second. This is easier then trying keep track of all things that change on the screen */
191
         lcd_status_update_delay = 10;   /* redraw the main screen every second. This is easier then trying keep track of all things that change on the screen */
190
     }
192
     }
191
 #ifdef ULTIPANEL
193
 #ifdef ULTIPANEL
192
-    if (LCD_CLICKED)
194
+
195
+    bool current_click = LCD_CLICKED;
196
+
197
+    if (ignore_click) {
198
+        if (wait_for_unclick) {
199
+          if (!current_click) {
200
+              ignore_click = wait_for_unclick = false;
201
+          }
202
+          else {
203
+              current_click = false;
204
+          }
205
+        }
206
+        else if (current_click) {
207
+            lcd_quick_feedback();
208
+            wait_for_unclick = true;
209
+            current_click = false;
210
+        }
211
+    }
212
+
213
+    if (current_click)
193
     {
214
     {
194
         currentMenu = lcd_main_menu;
215
         currentMenu = lcd_main_menu;
195
         encoderPosition = 0;
216
         encoderPosition = 0;
1315
     }
1336
     }
1316
 }
1337
 }
1317
 
1338
 
1339
+void lcd_ignore_click(bool b)
1340
+{
1341
+    ignore_click = b;
1342
+    wait_for_unclick = false;
1343
+}
1344
+
1318
 void lcd_setstatus(const char* message)
1345
 void lcd_setstatus(const char* message)
1319
 {
1346
 {
1320
     if (lcd_status_message_level > 0)
1347
     if (lcd_status_message_level > 0)

+ 2
- 0
Marlin/ultralcd.h View File

49
   void lcd_buzz(long duration,uint16_t freq);
49
   void lcd_buzz(long duration,uint16_t freq);
50
   bool lcd_clicked();
50
   bool lcd_clicked();
51
 
51
 
52
+  void lcd_ignore_click(bool b=true);
53
+
52
   #ifdef NEWPANEL
54
   #ifdef NEWPANEL
53
     #define EN_C (1<<BLEN_C)
55
     #define EN_C (1<<BLEN_C)
54
     #define EN_B (1<<BLEN_B)
56
     #define EN_B (1<<BLEN_B)

+ 1
- 0
README.md View File

2
 Marlin 3D Printer Firmware
2
 Marlin 3D Printer Firmware
3
 ==========================
3
 ==========================
4
 [![Coverity Scan Build Status](https://scan.coverity.com/projects/2224/badge.svg)](https://scan.coverity.com/projects/2224)
4
 [![Coverity Scan Build Status](https://scan.coverity.com/projects/2224/badge.svg)](https://scan.coverity.com/projects/2224)
5
+[![Travis Build Status](https://travis-ci.org/ErikZalm/Marlin.svg)](https://travis-ci.org/ErikZalm/Marlin)
5
 
6
 
6
 Marlin has a GPL license because I believe in open development.
7
 Marlin has a GPL license because I believe in open development.
7
 Please do not use this code in products (3D printers, CNC etc) that are closed source or are crippled by a patent.
8
 Please do not use this code in products (3D printers, CNC etc) that are closed source or are crippled by a patent.

Loading…
Cancel
Save