commit
f47fc879fe
21 changed files with 433 additions and 360 deletions
|
@ -263,8 +263,6 @@ void Config_StoreSettings() {
|
||||||
EEPROM_WRITE_VAR(i, dummy);
|
EEPROM_WRITE_VAR(i, dummy);
|
||||||
}
|
}
|
||||||
|
|
||||||
int storageSize = i;
|
|
||||||
|
|
||||||
char ver2[4] = EEPROM_VERSION;
|
char ver2[4] = EEPROM_VERSION;
|
||||||
int j = EEPROM_OFFSET;
|
int j = EEPROM_OFFSET;
|
||||||
EEPROM_WRITE_VAR(j, ver2); // validate data
|
EEPROM_WRITE_VAR(j, ver2); // validate data
|
||||||
|
@ -446,7 +444,7 @@ void Config_ResetDefault() {
|
||||||
float tmp1[] = DEFAULT_AXIS_STEPS_PER_UNIT;
|
float tmp1[] = DEFAULT_AXIS_STEPS_PER_UNIT;
|
||||||
float tmp2[] = DEFAULT_MAX_FEEDRATE;
|
float tmp2[] = DEFAULT_MAX_FEEDRATE;
|
||||||
long tmp3[] = DEFAULT_MAX_ACCELERATION;
|
long tmp3[] = DEFAULT_MAX_ACCELERATION;
|
||||||
for (int i = 0; i < NUM_AXIS; i++) {
|
for (uint16_t i = 0; i < NUM_AXIS; i++) {
|
||||||
axis_steps_per_unit[i] = tmp1[i];
|
axis_steps_per_unit[i] = tmp1[i];
|
||||||
max_feedrate[i] = tmp2[i];
|
max_feedrate[i] = tmp2[i];
|
||||||
max_acceleration_units_per_sq_second[i] = tmp3[i];
|
max_acceleration_units_per_sq_second[i] = tmp3[i];
|
||||||
|
|
|
@ -388,7 +388,11 @@ const char axis_codes[NUM_AXIS] = {'X', 'Y', 'Z', 'E'};
|
||||||
static float destination[NUM_AXIS] = { 0, 0, 0, 0 };
|
static float destination[NUM_AXIS] = { 0, 0, 0, 0 };
|
||||||
|
|
||||||
static float offset[3] = { 0, 0, 0 };
|
static float offset[3] = { 0, 0, 0 };
|
||||||
|
|
||||||
|
#ifndef DELTA
|
||||||
static bool home_all_axis = true;
|
static bool home_all_axis = true;
|
||||||
|
#endif
|
||||||
|
|
||||||
static float feedrate = 1500.0, next_feedrate, saved_feedrate;
|
static float feedrate = 1500.0, next_feedrate, saved_feedrate;
|
||||||
static long gcode_N, gcode_LastN, Stopped_gcode_LastN = 0;
|
static long gcode_N, gcode_LastN, Stopped_gcode_LastN = 0;
|
||||||
|
|
||||||
|
@ -397,7 +401,7 @@ static bool relative_mode = false; //Determines Absolute or Relative Coordinate
|
||||||
static char cmdbuffer[BUFSIZE][MAX_CMD_SIZE];
|
static char cmdbuffer[BUFSIZE][MAX_CMD_SIZE];
|
||||||
#ifdef SDSUPPORT
|
#ifdef SDSUPPORT
|
||||||
static bool fromsd[BUFSIZE];
|
static bool fromsd[BUFSIZE];
|
||||||
#endif //!SDSUPPORT
|
#endif
|
||||||
static int bufindr = 0;
|
static int bufindr = 0;
|
||||||
static int bufindw = 0;
|
static int bufindw = 0;
|
||||||
static int buflen = 0;
|
static int buflen = 0;
|
||||||
|
@ -933,24 +937,22 @@ void get_command()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
float code_value() {
|
||||||
float code_value()
|
|
||||||
{
|
|
||||||
float ret;
|
float ret;
|
||||||
char *e = strchr(strchr_pointer, 'E');
|
char *e = strchr(strchr_pointer, 'E');
|
||||||
if (e != NULL) *e = 0;
|
if (e) {
|
||||||
|
*e = 0;
|
||||||
|
ret = strtod(strchr_pointer+1, NULL);
|
||||||
|
*e = 'E';
|
||||||
|
}
|
||||||
|
else
|
||||||
ret = strtod(strchr_pointer+1, NULL);
|
ret = strtod(strchr_pointer+1, NULL);
|
||||||
if (e != NULL) *e = 'E';
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
long code_value_long()
|
long code_value_long() { return (strtol(strchr_pointer + 1, NULL, 10)); }
|
||||||
{
|
|
||||||
return (strtol(strchr_pointer + 1, NULL, 10));
|
|
||||||
}
|
|
||||||
|
|
||||||
bool code_seen(char code)
|
bool code_seen(char code) {
|
||||||
{
|
|
||||||
strchr_pointer = strchr(cmdbuffer[bufindr], code);
|
strchr_pointer = strchr(cmdbuffer[bufindr], code);
|
||||||
return (strchr_pointer != NULL); //Return True if a character was found
|
return (strchr_pointer != NULL); //Return True if a character was found
|
||||||
}
|
}
|
||||||
|
@ -1009,6 +1011,7 @@ XYZ_CONSTS_FROM_CONFIG(signed char, home_dir, HOME_DIR);
|
||||||
#endif //DUAL_X_CARRIAGE
|
#endif //DUAL_X_CARRIAGE
|
||||||
|
|
||||||
static void axis_is_at_home(int axis) {
|
static void axis_is_at_home(int axis) {
|
||||||
|
|
||||||
#ifdef DUAL_X_CARRIAGE
|
#ifdef DUAL_X_CARRIAGE
|
||||||
if (axis == X_AXIS) {
|
if (axis == X_AXIS) {
|
||||||
if (active_extruder != 0) {
|
if (active_extruder != 0) {
|
||||||
|
@ -1017,7 +1020,7 @@ static void axis_is_at_home(int axis) {
|
||||||
max_pos[X_AXIS] = max(extruder_offset[X_AXIS][1], X2_MAX_POS);
|
max_pos[X_AXIS] = max(extruder_offset[X_AXIS][1], X2_MAX_POS);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if (dual_x_carriage_mode == DXC_DUPLICATION_MODE && active_extruder == 0) {
|
else if (dual_x_carriage_mode == DXC_DUPLICATION_MODE) {
|
||||||
current_position[X_AXIS] = base_home_pos(X_AXIS) + home_offset[X_AXIS];
|
current_position[X_AXIS] = base_home_pos(X_AXIS) + home_offset[X_AXIS];
|
||||||
min_pos[X_AXIS] = base_min_pos(X_AXIS) + home_offset[X_AXIS];
|
min_pos[X_AXIS] = base_min_pos(X_AXIS) + home_offset[X_AXIS];
|
||||||
max_pos[X_AXIS] = min(base_max_pos(X_AXIS) + home_offset[X_AXIS],
|
max_pos[X_AXIS] = min(base_max_pos(X_AXIS) + home_offset[X_AXIS],
|
||||||
|
@ -1026,17 +1029,14 @@ static void axis_is_at_home(int axis) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SCARA
|
#ifdef SCARA
|
||||||
float homeposition[3];
|
float homeposition[3];
|
||||||
char i;
|
|
||||||
|
|
||||||
if (axis < 2)
|
if (axis < 2) {
|
||||||
{
|
|
||||||
|
for (int i = 0; i < 3; i++) homeposition[i] = base_home_pos(i);
|
||||||
|
|
||||||
for (i=0; i<3; i++)
|
|
||||||
{
|
|
||||||
homeposition[i] = base_home_pos(i);
|
|
||||||
}
|
|
||||||
// SERIAL_ECHOPGM("homeposition[x]= "); SERIAL_ECHO(homeposition[0]);
|
// SERIAL_ECHOPGM("homeposition[x]= "); SERIAL_ECHO(homeposition[0]);
|
||||||
// SERIAL_ECHOPGM("homeposition[y]= "); SERIAL_ECHOLN(homeposition[1]);
|
// SERIAL_ECHOPGM("homeposition[y]= "); SERIAL_ECHOLN(homeposition[1]);
|
||||||
// Works out real Homeposition angles using inverse kinematics,
|
// Works out real Homeposition angles using inverse kinematics,
|
||||||
|
@ -1046,10 +1046,7 @@ static void axis_is_at_home(int axis) {
|
||||||
// SERIAL_ECHOPGM("base Theta= "); SERIAL_ECHO(delta[X_AXIS]);
|
// SERIAL_ECHOPGM("base Theta= "); SERIAL_ECHO(delta[X_AXIS]);
|
||||||
// SERIAL_ECHOPGM(" base Psi+Theta="); SERIAL_ECHOLN(delta[Y_AXIS]);
|
// SERIAL_ECHOPGM(" base Psi+Theta="); SERIAL_ECHOLN(delta[Y_AXIS]);
|
||||||
|
|
||||||
for (i=0; i<2; i++)
|
for (int i = 0; i < 2; i++) delta[i] -= home_offset[i];
|
||||||
{
|
|
||||||
delta[i] -= home_offset[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
// SERIAL_ECHOPGM("addhome X="); SERIAL_ECHO(home_offset[X_AXIS]);
|
// SERIAL_ECHOPGM("addhome X="); SERIAL_ECHO(home_offset[X_AXIS]);
|
||||||
// SERIAL_ECHOPGM(" addhome Y="); SERIAL_ECHO(home_offset[Y_AXIS]);
|
// SERIAL_ECHOPGM(" addhome Y="); SERIAL_ECHO(home_offset[Y_AXIS]);
|
||||||
|
@ -1068,8 +1065,7 @@ static void axis_is_at_home(int axis) {
|
||||||
min_pos[axis] = base_min_pos(axis); // + (delta[axis] - base_home_pos(axis));
|
min_pos[axis] = base_min_pos(axis); // + (delta[axis] - base_home_pos(axis));
|
||||||
max_pos[axis] = base_max_pos(axis); // + (delta[axis] - base_home_pos(axis));
|
max_pos[axis] = base_max_pos(axis); // + (delta[axis] - base_home_pos(axis));
|
||||||
}
|
}
|
||||||
else
|
else {
|
||||||
{
|
|
||||||
current_position[axis] = base_home_pos(axis) + home_offset[axis];
|
current_position[axis] = base_home_pos(axis) + home_offset[axis];
|
||||||
min_pos[axis] = base_min_pos(axis) + home_offset[axis];
|
min_pos[axis] = base_min_pos(axis) + home_offset[axis];
|
||||||
max_pos[axis] = base_max_pos(axis) + home_offset[axis];
|
max_pos[axis] = base_max_pos(axis) + home_offset[axis];
|
||||||
|
@ -1233,10 +1229,6 @@ static void do_blocking_move_to(float x, float y, float z) {
|
||||||
feedrate = oldFeedRate;
|
feedrate = oldFeedRate;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_blocking_move_relative(float offset_x, float offset_y, float offset_z) {
|
|
||||||
do_blocking_move_to(current_position[X_AXIS] + offset_x, current_position[Y_AXIS] + offset_y, current_position[Z_AXIS] + offset_z);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void setup_for_endstop_move() {
|
static void setup_for_endstop_move() {
|
||||||
saved_feedrate = feedrate;
|
saved_feedrate = feedrate;
|
||||||
saved_feedmultiply = feedmultiply;
|
saved_feedmultiply = feedmultiply;
|
||||||
|
@ -2156,7 +2148,6 @@ inline void gcode_G28() {
|
||||||
}
|
}
|
||||||
|
|
||||||
int verbose_level = 1;
|
int verbose_level = 1;
|
||||||
float x_tmp, y_tmp, z_tmp, real_z;
|
|
||||||
|
|
||||||
if (code_seen('V') || code_seen('v')) {
|
if (code_seen('V') || code_seen('v')) {
|
||||||
verbose_level = code_value_long();
|
verbose_level = code_value_long();
|
||||||
|
@ -2444,6 +2435,7 @@ inline void gcode_G28() {
|
||||||
// When the bed is uneven, this height must be corrected.
|
// When the bed is uneven, this height must be corrected.
|
||||||
if (!dryrun)
|
if (!dryrun)
|
||||||
{
|
{
|
||||||
|
float x_tmp, y_tmp, z_tmp, real_z;
|
||||||
real_z = float(st_get_position(Z_AXIS)) / axis_steps_per_unit[Z_AXIS]; //get the real Z (since the auto bed leveling is already correcting the plane)
|
real_z = float(st_get_position(Z_AXIS)) / axis_steps_per_unit[Z_AXIS]; //get the real Z (since the auto bed leveling is already correcting the plane)
|
||||||
x_tmp = current_position[X_AXIS] + X_PROBE_OFFSET_FROM_EXTRUDER;
|
x_tmp = current_position[X_AXIS] + X_PROBE_OFFSET_FROM_EXTRUDER;
|
||||||
y_tmp = current_position[Y_AXIS] + Y_PROBE_OFFSET_FROM_EXTRUDER;
|
y_tmp = current_position[Y_AXIS] + Y_PROBE_OFFSET_FROM_EXTRUDER;
|
||||||
|
@ -4590,7 +4582,6 @@ inline void gcode_T() {
|
||||||
#if EXTRUDERS > 1
|
#if EXTRUDERS > 1
|
||||||
bool make_move = false;
|
bool make_move = false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (code_seen('F')) {
|
if (code_seen('F')) {
|
||||||
#if EXTRUDERS > 1
|
#if EXTRUDERS > 1
|
||||||
make_move = true;
|
make_move = true;
|
||||||
|
@ -5193,16 +5184,10 @@ void ClearToSend()
|
||||||
|
|
||||||
void get_coordinates() {
|
void get_coordinates() {
|
||||||
for (int i = 0; i < NUM_AXIS; i++) {
|
for (int i = 0; i < NUM_AXIS; i++) {
|
||||||
float dest;
|
if (code_seen(axis_codes[i]))
|
||||||
if (code_seen(axis_codes[i])) {
|
destination[i] = code_value() + (axis_relative_modes[i] || relative_mode ? current_position[i] : 0);
|
||||||
dest = code_value();
|
|
||||||
if (axis_relative_modes[i] || relative_mode)
|
|
||||||
dest += current_position[i];
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
dest = current_position[i];
|
destination[i] = current_position[i];
|
||||||
|
|
||||||
destination[i] = dest;
|
|
||||||
}
|
}
|
||||||
if (code_seen('F')) {
|
if (code_seen('F')) {
|
||||||
next_feedrate = code_value();
|
next_feedrate = code_value();
|
||||||
|
|
|
@ -489,7 +489,7 @@ void CardReader::updir() {
|
||||||
if (workDirDepth > 0) {
|
if (workDirDepth > 0) {
|
||||||
--workDirDepth;
|
--workDirDepth;
|
||||||
workDir = workDirParents[0];
|
workDir = workDirParents[0];
|
||||||
for (int d = 0; d < workDirDepth; d++)
|
for (uint16_t d = 0; d < workDirDepth; d++)
|
||||||
workDirParents[d] = workDirParents[d+1];
|
workDirParents[d] = workDirParents[d+1];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,6 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define PROTOCOL_VERSION "1.0"
|
#define PROTOCOL_VERSION "1.0"
|
||||||
#define FIRMWARE_URL "https://github.com/MarlinFirmware/Marlin"
|
|
||||||
|
|
||||||
#if MB(ULTIMAKER)|| MB(ULTIMAKER_OLD)|| MB(ULTIMAIN_2)
|
#if MB(ULTIMAKER)|| MB(ULTIMAKER_OLD)|| MB(ULTIMAIN_2)
|
||||||
#define MACHINE_NAME "Ultimaker"
|
#define MACHINE_NAME "Ultimaker"
|
||||||
|
@ -59,9 +58,11 @@
|
||||||
#define FIRMWARE_URL "http://www.bq.com/gb/downloads-prusa-i3-hephestos.html"
|
#define FIRMWARE_URL "http://www.bq.com/gb/downloads-prusa-i3-hephestos.html"
|
||||||
#else // Default firmware set to Mendel
|
#else // Default firmware set to Mendel
|
||||||
#define MACHINE_NAME "Mendel"
|
#define MACHINE_NAME "Mendel"
|
||||||
|
#define FIRMWARE_URL "https://github.com/MarlinFirmware/Marlin"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CUSTOM_MENDEL_NAME
|
#ifdef CUSTOM_MENDEL_NAME
|
||||||
|
#undef MACHINE_NAME
|
||||||
#define MACHINE_NAME CUSTOM_MENDEL_NAME
|
#define MACHINE_NAME CUSTOM_MENDEL_NAME
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -275,13 +275,9 @@
|
||||||
|
|
||||||
#ifdef ADVANCE
|
#ifdef ADVANCE
|
||||||
#define EXTRUDER_ADVANCE_K .0
|
#define EXTRUDER_ADVANCE_K .0
|
||||||
|
|
||||||
#define D_FILAMENT 1.75
|
#define D_FILAMENT 1.75
|
||||||
#define STEPS_MM_E 1000
|
#define STEPS_MM_E 1000
|
||||||
#define EXTRUSION_AREA (0.25 * D_FILAMENT * D_FILAMENT * 3.14159)
|
#endif
|
||||||
#define STEPS_PER_CUBIC_MM_E (axis_steps_per_unit[E_AXIS]/ EXTRUSION_AREA)
|
|
||||||
|
|
||||||
#endif // ADVANCE
|
|
||||||
|
|
||||||
// Arc interpretation settings:
|
// Arc interpretation settings:
|
||||||
#define MM_PER_ARC_SEGMENT 1
|
#define MM_PER_ARC_SEGMENT 1
|
||||||
|
|
|
@ -40,12 +40,14 @@
|
||||||
#define FIRMWARE_URL "https://github.com/MarlinFirmware/Marlin"
|
#define FIRMWARE_URL "https://github.com/MarlinFirmware/Marlin"
|
||||||
|
|
||||||
#if MB(ULTIMAKER)|| MB(ULTIMAKER_OLD)|| MB(ULTIMAIN_2)
|
#if MB(ULTIMAKER)|| MB(ULTIMAKER_OLD)|| MB(ULTIMAIN_2)
|
||||||
|
#undef FIRMWARE_URL
|
||||||
#define MACHINE_NAME "Ultimaker"
|
#define MACHINE_NAME "Ultimaker"
|
||||||
#define FIRMWARE_URL "http://firmware.ultimaker.com"
|
#define FIRMWARE_URL "http://firmware.ultimaker.com"
|
||||||
#elif MB(RUMBA)
|
#elif MB(RUMBA)
|
||||||
#define MACHINE_NAME "Rumba"
|
#define MACHINE_NAME "Rumba"
|
||||||
#elif MB(3DRAG)
|
#elif MB(3DRAG)
|
||||||
#define MACHINE_NAME "3Drag"
|
#define MACHINE_NAME "3Drag"
|
||||||
|
#undef FIRMWARE_URL
|
||||||
#define FIRMWARE_URL "http://3dprint.elettronicain.it/"
|
#define FIRMWARE_URL "http://3dprint.elettronicain.it/"
|
||||||
#elif MB(K8200)
|
#elif MB(K8200)
|
||||||
#define MACHINE_NAME "K8200"
|
#define MACHINE_NAME "K8200"
|
||||||
|
@ -53,18 +55,22 @@
|
||||||
#define MACHINE_NAME "Makibox"
|
#define MACHINE_NAME "Makibox"
|
||||||
#elif MB(SAV_MKI)
|
#elif MB(SAV_MKI)
|
||||||
#define MACHINE_NAME "SAV MkI"
|
#define MACHINE_NAME "SAV MkI"
|
||||||
|
#undef FIRMWARE_URL
|
||||||
#define FIRMWARE_URL "https://github.com/fmalpartida/Marlin/tree/SAV-MkI-config"
|
#define FIRMWARE_URL "https://github.com/fmalpartida/Marlin/tree/SAV-MkI-config"
|
||||||
#elif MB(WITBOX)
|
#elif MB(WITBOX)
|
||||||
#define MACHINE_NAME "WITBOX"
|
#define MACHINE_NAME "WITBOX"
|
||||||
|
#undef FIRMWARE_URL
|
||||||
#define FIRMWARE_URL "http://www.bq.com/gb/downloads-witbox.html"
|
#define FIRMWARE_URL "http://www.bq.com/gb/downloads-witbox.html"
|
||||||
#elif MB(HEPHESTOS)
|
#elif MB(HEPHESTOS)
|
||||||
#define MACHINE_NAME "HEPHESTOS"
|
#define MACHINE_NAME "HEPHESTOS"
|
||||||
|
#undef FIRMWARE_URL
|
||||||
#define FIRMWARE_URL "http://www.bq.com/gb/downloads-prusa-i3-hephestos.html"
|
#define FIRMWARE_URL "http://www.bq.com/gb/downloads-prusa-i3-hephestos.html"
|
||||||
#else // Default firmware set to Mendel
|
#else // Default firmware set to Mendel
|
||||||
#define MACHINE_NAME "Mendel"
|
#define MACHINE_NAME "Mendel"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CUSTOM_MENDEL_NAME
|
#ifdef CUSTOM_MENDEL_NAME
|
||||||
|
#undef MACHINE_NAME
|
||||||
#define MACHINE_NAME CUSTOM_MENDEL_NAME
|
#define MACHINE_NAME CUSTOM_MENDEL_NAME
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -127,10 +127,13 @@
|
||||||
#define _E3_PINS
|
#define _E3_PINS
|
||||||
|
|
||||||
#if EXTRUDERS > 1
|
#if EXTRUDERS > 1
|
||||||
|
#undef _E1_PINS
|
||||||
#define _E1_PINS E1_STEP_PIN, E1_DIR_PIN, E1_ENABLE_PIN, HEATER_1_PIN, analogInputToDigitalPin(TEMP_1_PIN),
|
#define _E1_PINS E1_STEP_PIN, E1_DIR_PIN, E1_ENABLE_PIN, HEATER_1_PIN, analogInputToDigitalPin(TEMP_1_PIN),
|
||||||
#if EXTRUDERS > 2
|
#if EXTRUDERS > 2
|
||||||
|
#undef _E2_PINS
|
||||||
#define _E2_PINS E2_STEP_PIN, E2_DIR_PIN, E2_ENABLE_PIN, HEATER_2_PIN, analogInputToDigitalPin(TEMP_2_PIN),
|
#define _E2_PINS E2_STEP_PIN, E2_DIR_PIN, E2_ENABLE_PIN, HEATER_2_PIN, analogInputToDigitalPin(TEMP_2_PIN),
|
||||||
#if EXTRUDERS > 3
|
#if EXTRUDERS > 3
|
||||||
|
#undef _E3_PINS
|
||||||
#define _E3_PINS E3_STEP_PIN, E3_DIR_PIN, E3_ENABLE_PIN, HEATER_3_PIN, analogInputToDigitalPin(TEMP_3_PIN),
|
#define _E3_PINS E3_STEP_PIN, E3_DIR_PIN, E3_ENABLE_PIN, HEATER_3_PIN, analogInputToDigitalPin(TEMP_3_PIN),
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
@ -167,12 +170,18 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DISABLE_MAX_ENDSTOPS
|
#ifdef DISABLE_MAX_ENDSTOPS
|
||||||
|
#undef X_MAX_PIN
|
||||||
|
#undef Y_MAX_PIN
|
||||||
|
#undef Z_MAX_PIN
|
||||||
#define X_MAX_PIN -1
|
#define X_MAX_PIN -1
|
||||||
#define Y_MAX_PIN -1
|
#define Y_MAX_PIN -1
|
||||||
#define Z_MAX_PIN -1
|
#define Z_MAX_PIN -1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DISABLE_MIN_ENDSTOPS
|
#ifdef DISABLE_MIN_ENDSTOPS
|
||||||
|
#undef X_MIN_PIN
|
||||||
|
#undef Y_MIN_PIN
|
||||||
|
#undef Z_MIN_PIN
|
||||||
#define X_MIN_PIN -1
|
#define X_MIN_PIN -1
|
||||||
#define Y_MIN_PIN -1
|
#define Y_MIN_PIN -1
|
||||||
#define Z_MIN_PIN -1
|
#define Z_MIN_PIN -1
|
||||||
|
|
|
@ -4,18 +4,25 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef Z_ENABLE_PIN
|
||||||
#define Z_ENABLE_PIN 63
|
#define Z_ENABLE_PIN 63
|
||||||
|
|
||||||
|
#undef X_MAX_PIN
|
||||||
|
#undef Y_MAX_PIN
|
||||||
|
#undef Z_MAX_PIN
|
||||||
#define X_MAX_PIN 2
|
#define X_MAX_PIN 2
|
||||||
#define Y_MAX_PIN 15
|
#define Y_MAX_PIN 15
|
||||||
#define Z_MAX_PIN -1
|
#define Z_MAX_PIN -1
|
||||||
|
|
||||||
|
#undef SDSS
|
||||||
#define SDSS 25//53
|
#define SDSS 25//53
|
||||||
|
|
||||||
#define BEEPER 33
|
#undef FAN_PIN
|
||||||
|
|
||||||
#define FAN_PIN 8
|
#define FAN_PIN 8
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
|
#undef HEATER_2_PIN
|
||||||
|
#undef HEATER_BED_PIN
|
||||||
#define HEATER_0_PIN 10
|
#define HEATER_0_PIN 10
|
||||||
#define HEATER_1_PIN 12
|
#define HEATER_1_PIN 12
|
||||||
#define HEATER_2_PIN 6
|
#define HEATER_2_PIN 6
|
||||||
|
@ -23,8 +30,15 @@
|
||||||
#define HEATER_BED_PIN 9 // BED
|
#define HEATER_BED_PIN 9 // BED
|
||||||
|
|
||||||
#if defined(ULTRA_LCD) && defined(NEWPANEL)
|
#if defined(ULTRA_LCD) && defined(NEWPANEL)
|
||||||
|
#undef BEEPER
|
||||||
#define BEEPER -1
|
#define BEEPER -1
|
||||||
|
|
||||||
|
#undef LCD_PINS_RS
|
||||||
|
#undef LCD_PINS_ENABLE
|
||||||
|
#undef LCD_PINS_D4
|
||||||
|
#undef LCD_PINS_D5
|
||||||
|
#undef LCD_PINS_D6
|
||||||
|
#undef LCD_PINS_D7
|
||||||
#define LCD_PINS_RS 27
|
#define LCD_PINS_RS 27
|
||||||
#define LCD_PINS_ENABLE 29
|
#define LCD_PINS_ENABLE 29
|
||||||
#define LCD_PINS_D4 37
|
#define LCD_PINS_D4 37
|
||||||
|
@ -33,7 +47,15 @@
|
||||||
#define LCD_PINS_D7 31
|
#define LCD_PINS_D7 31
|
||||||
|
|
||||||
// Buttons
|
// Buttons
|
||||||
|
#undef BTN_EN1
|
||||||
|
#undef BTN_EN2
|
||||||
|
#undef BTN_ENC
|
||||||
#define BTN_EN1 16
|
#define BTN_EN1 16
|
||||||
#define BTN_EN2 17
|
#define BTN_EN2 17
|
||||||
#define BTN_ENC 23 //the click
|
#define BTN_ENC 23 //the click
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#define BEEPER 33
|
||||||
|
|
||||||
#endif // ULTRA_LCD && NEWPANEL
|
#endif // ULTRA_LCD && NEWPANEL
|
||||||
|
|
|
@ -64,6 +64,15 @@
|
||||||
// Microstepping pins
|
// Microstepping pins
|
||||||
// Note that the pin mapping is not from fastio.h
|
// Note that the pin mapping is not from fastio.h
|
||||||
// See Sd2PinMap.h for the pin configurations
|
// See Sd2PinMap.h for the pin configurations
|
||||||
|
|
||||||
|
#undef X_MS1_PIN
|
||||||
|
#undef X_MS2_PIN
|
||||||
|
#undef Y_MS1_PIN
|
||||||
|
#undef Y_MS2_PIN
|
||||||
|
#undef Z_MS1_PIN
|
||||||
|
#undef Z_MS2_PIN
|
||||||
|
#undef E0_MS1_PIN
|
||||||
|
#undef E0_MS2_PIN
|
||||||
#define X_MS1_PIN 25
|
#define X_MS1_PIN 25
|
||||||
#define X_MS2_PIN 26
|
#define X_MS2_PIN 26
|
||||||
#define Y_MS1_PIN 9
|
#define Y_MS1_PIN 9
|
||||||
|
|
|
@ -4,7 +4,10 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef FAN_PIN
|
||||||
#define FAN_PIN 9 // (Sprinter config)
|
#define FAN_PIN 9 // (Sprinter config)
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
#define HEATER_1_PIN -1
|
#define HEATER_1_PIN -1
|
||||||
|
|
||||||
#ifdef TEMP_STAT_LEDS
|
#ifdef TEMP_STAT_LEDS
|
||||||
|
|
|
@ -4,7 +4,9 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef FAN_PIN
|
||||||
#define FAN_PIN 9 // (Sprinter config)
|
#define FAN_PIN 9 // (Sprinter config)
|
||||||
|
|
||||||
#define BEEPER 33
|
#define BEEPER 33
|
||||||
|
|
||||||
#define E2_STEP_PIN 23
|
#define E2_STEP_PIN 23
|
||||||
|
@ -19,6 +21,9 @@
|
||||||
#define E4_DIR_PIN 37
|
#define E4_DIR_PIN 37
|
||||||
#define E4_ENABLE_PIN 42
|
#define E4_ENABLE_PIN 42
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
|
#undef HEATER_2_PIN
|
||||||
|
#undef HEATER_3_PIN
|
||||||
#define HEATER_1_PIN -1
|
#define HEATER_1_PIN -1
|
||||||
#define HEATER_2_PIN 16
|
#define HEATER_2_PIN 16
|
||||||
#define HEATER_3_PIN 17
|
#define HEATER_3_PIN 17
|
||||||
|
@ -27,6 +32,8 @@
|
||||||
#define HEATER_6_PIN 6
|
#define HEATER_6_PIN 6
|
||||||
#define HEATER_7_PIN 11
|
#define HEATER_7_PIN 11
|
||||||
|
|
||||||
|
#undef TEMP_2_PIN
|
||||||
|
#undef TEMP_3_PIN
|
||||||
#define TEMP_2_PIN 12 // ANALOG NUMBERING
|
#define TEMP_2_PIN 12 // ANALOG NUMBERING
|
||||||
#define TEMP_3_PIN 11 // ANALOG NUMBERING
|
#define TEMP_3_PIN 11 // ANALOG NUMBERING
|
||||||
#define TEMP_4_PIN 10 // ANALOG NUMBERING
|
#define TEMP_4_PIN 10 // ANALOG NUMBERING
|
||||||
|
|
|
@ -4,8 +4,13 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef FAN_PIN
|
||||||
#define FAN_PIN 9 // (Sprinter config)
|
#define FAN_PIN 9 // (Sprinter config)
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
#define HEATER_1_PIN -1
|
#define HEATER_1_PIN -1
|
||||||
|
|
||||||
|
#undef TEMP_0_PIN
|
||||||
|
#undef TEMP_1_PIN
|
||||||
#define TEMP_0_PIN 9 // ANALOG NUMBERING
|
#define TEMP_0_PIN 9 // ANALOG NUMBERING
|
||||||
#define TEMP_1_PIN 11 // ANALOG NUMBERING
|
#define TEMP_1_PIN 11 // ANALOG NUMBERING
|
||||||
|
|
|
@ -4,13 +4,23 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef X_MAX_PIN
|
||||||
|
#undef Y_MAX_PIN
|
||||||
|
#undef Z_MAX_PIN
|
||||||
#define X_MAX_PIN -1
|
#define X_MAX_PIN -1
|
||||||
#define Y_MAX_PIN -1
|
#define Y_MAX_PIN -1
|
||||||
#define Z_MAX_PIN -1
|
#define Z_MAX_PIN -1
|
||||||
|
|
||||||
|
#undef Y2_STEP_PIN
|
||||||
|
#undef Y2_DIR_PIN
|
||||||
|
#undef Y2_ENABLE_PIN
|
||||||
#define Y2_STEP_PIN -1
|
#define Y2_STEP_PIN -1
|
||||||
#define Y2_DIR_PIN -1
|
#define Y2_DIR_PIN -1
|
||||||
#define Y2_ENABLE_PIN -1
|
#define Y2_ENABLE_PIN -1
|
||||||
|
|
||||||
|
#undef Z2_STEP_PIN
|
||||||
|
#undef Z2_DIR_PIN
|
||||||
|
#undef Z2_ENABLE_PIN
|
||||||
#define Z2_STEP_PIN -1
|
#define Z2_STEP_PIN -1
|
||||||
#define Z2_DIR_PIN -1
|
#define Z2_DIR_PIN -1
|
||||||
#define Z2_ENABLE_PIN -1
|
#define Z2_ENABLE_PIN -1
|
||||||
|
@ -19,11 +29,14 @@
|
||||||
#define E1_DIR_PIN 34
|
#define E1_DIR_PIN 34
|
||||||
#define E1_ENABLE_PIN 30
|
#define E1_ENABLE_PIN 30
|
||||||
|
|
||||||
|
#undef SDPOWER
|
||||||
#define SDPOWER 1
|
#define SDPOWER 1
|
||||||
|
|
||||||
|
#undef FAN_PIN
|
||||||
#define FAN_PIN 9 // (Sprinter config)
|
#define FAN_PIN 9 // (Sprinter config)
|
||||||
#define PS_ON_PIN 12
|
#define PS_ON_PIN 12
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
#define HEATER_1_PIN 7 // EXTRUDER 2
|
#define HEATER_1_PIN 7 // EXTRUDER 2
|
||||||
|
|
||||||
#if defined(ULTRA_LCD) && defined(NEWPANEL)
|
#if defined(ULTRA_LCD) && defined(NEWPANEL)
|
||||||
|
|
|
@ -4,5 +4,8 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef FAN_PIN
|
||||||
#define FAN_PIN 9 // (Sprinter config)
|
#define FAN_PIN 9 // (Sprinter config)
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
#define HEATER_1_PIN -1
|
#define HEATER_1_PIN -1
|
||||||
|
|
|
@ -4,5 +4,8 @@
|
||||||
|
|
||||||
#include "pins_RAMPS_13.h"
|
#include "pins_RAMPS_13.h"
|
||||||
|
|
||||||
|
#undef FAN_PIN
|
||||||
#define FAN_PIN 9 // (Sprinter config)
|
#define FAN_PIN 9 // (Sprinter config)
|
||||||
|
|
||||||
|
#undef HEATER_1_PIN
|
||||||
#define HEATER_1_PIN -1
|
#define HEATER_1_PIN -1
|
||||||
|
|
|
@ -701,12 +701,12 @@ float junction_deviation = 0.1;
|
||||||
|
|
||||||
int moves_queued = movesplanned();
|
int moves_queued = movesplanned();
|
||||||
|
|
||||||
// slow down when de buffer starts to empty, rather than wait at the corner for a buffer refill
|
// Slow down when the buffer starts to empty, rather than wait at the corner for a buffer refill
|
||||||
|
#if defined(OLD_SLOWDOWN) || defined(SLOWDOWN)
|
||||||
bool mq = moves_queued > 1 && moves_queued < BLOCK_BUFFER_SIZE / 2;
|
bool mq = moves_queued > 1 && moves_queued < BLOCK_BUFFER_SIZE / 2;
|
||||||
#ifdef OLD_SLOWDOWN
|
#ifdef OLD_SLOWDOWN
|
||||||
if (mq) feed_rate *= 2.0 * moves_queued / BLOCK_BUFFER_SIZE;
|
if (mq) feed_rate *= 2.0 * moves_queued / BLOCK_BUFFER_SIZE;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SLOWDOWN
|
#ifdef SLOWDOWN
|
||||||
// segment time im micro seconds
|
// segment time im micro seconds
|
||||||
unsigned long segment_time = lround(1000000.0/inverse_second);
|
unsigned long segment_time = lround(1000000.0/inverse_second);
|
||||||
|
@ -720,7 +720,7 @@ float junction_deviation = 0.1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
// END OF SLOW DOWN SECTION
|
#endif
|
||||||
|
|
||||||
block->nominal_speed = block->millimeters * inverse_second; // (mm/sec) Always > 0
|
block->nominal_speed = block->millimeters * inverse_second; // (mm/sec) Always > 0
|
||||||
block->nominal_rate = ceil(block->step_event_count * inverse_second); // (step/sec) Always > 0
|
block->nominal_rate = ceil(block->step_event_count * inverse_second); // (step/sec) Always > 0
|
||||||
|
|
|
@ -607,7 +607,6 @@ double dnrm2 ( int n, double x[], int incx )
|
||||||
double norm;
|
double norm;
|
||||||
double scale;
|
double scale;
|
||||||
double ssq;
|
double ssq;
|
||||||
double value;
|
|
||||||
|
|
||||||
if ( n < 1 || incx < 1 )
|
if ( n < 1 || incx < 1 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -85,17 +85,31 @@ static volatile bool endstop_z_hit = false;
|
||||||
int motor_current_setting[3] = DEFAULT_PWM_MOTOR_CURRENT;
|
int motor_current_setting[3] = DEFAULT_PWM_MOTOR_CURRENT;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static bool old_x_min_endstop = false,
|
#if defined(X_MIN_PIN) && X_MIN_PIN >= 0
|
||||||
old_x_max_endstop = false,
|
static bool old_x_min_endstop = false;
|
||||||
old_y_min_endstop = false,
|
#endif
|
||||||
old_y_max_endstop = false,
|
#if defined(X_MAX_PIN) && X_MAX_PIN >= 0
|
||||||
old_z_min_endstop = false,
|
static bool old_x_max_endstop = false;
|
||||||
#ifndef Z_DUAL_ENDSTOPS
|
#endif
|
||||||
old_z_max_endstop = false;
|
#if defined(Y_MIN_PIN) && Y_MIN_PIN >= 0
|
||||||
#else
|
static bool old_y_min_endstop = false;
|
||||||
old_z_max_endstop = false,
|
#endif
|
||||||
old_z2_min_endstop = false,
|
#if defined(Y_MAX_PIN) && Y_MAX_PIN >= 0
|
||||||
old_z2_max_endstop = false;
|
static bool old_y_max_endstop = false;
|
||||||
|
#endif
|
||||||
|
#if defined(Z_MIN_PIN) && Z_MIN_PIN >= 0
|
||||||
|
static bool old_z_min_endstop = false;
|
||||||
|
#endif
|
||||||
|
#if defined(Z_MAX_PIN) && Z_MAX_PIN >= 0
|
||||||
|
static bool old_z_max_endstop = false;
|
||||||
|
#endif
|
||||||
|
#ifdef Z_DUAL_ENDSTOPS
|
||||||
|
#if defined(Z2_MIN_PIN) && Z2_MIN_PIN >= 0
|
||||||
|
static bool old_z2_min_endstop = false;
|
||||||
|
#endif
|
||||||
|
#if defined(Z2_MAX_PIN) && Z2_MAX_PIN >= 0
|
||||||
|
static bool old_z2_max_endstop = false;
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static bool check_endstops = true;
|
static bool check_endstops = true;
|
||||||
|
|
|
@ -586,7 +586,9 @@ void manage_heater() {
|
||||||
if (ct < max(HEATER_0_MINTEMP, 0.01)) min_temp_error(0);
|
if (ct < max(HEATER_0_MINTEMP, 0.01)) min_temp_error(0);
|
||||||
#endif //HEATER_0_USES_MAX6675
|
#endif //HEATER_0_USES_MAX6675
|
||||||
|
|
||||||
|
#if defined(WATCH_TEMP_PERIOD) || !defined(PIDTEMPBED) || HAS_AUTO_FAN
|
||||||
unsigned long ms = millis();
|
unsigned long ms = millis();
|
||||||
|
#endif
|
||||||
|
|
||||||
// Loop through all extruders
|
// Loop through all extruders
|
||||||
for (int e = 0; e < EXTRUDERS; e++) {
|
for (int e = 0; e < EXTRUDERS; e++) {
|
||||||
|
|
|
@ -25,10 +25,6 @@ int absPreheatFanSpeed;
|
||||||
unsigned long message_millis = 0;
|
unsigned long message_millis = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ULTIPANEL
|
|
||||||
static float manual_feedrate[] = MANUAL_FEEDRATE;
|
|
||||||
#endif // ULTIPANEL
|
|
||||||
|
|
||||||
/* !Configuration settings */
|
/* !Configuration settings */
|
||||||
|
|
||||||
//Function pointer to menu functions.
|
//Function pointer to menu functions.
|
||||||
|
@ -43,10 +39,13 @@ char lcd_status_message[LCD_WIDTH+1] = WELCOME_MSG;
|
||||||
#include "ultralcd_implementation_hitachi_HD44780.h"
|
#include "ultralcd_implementation_hitachi_HD44780.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Different menus */
|
// The main status screen
|
||||||
static void lcd_status_screen();
|
static void lcd_status_screen();
|
||||||
|
|
||||||
#ifdef ULTIPANEL
|
#ifdef ULTIPANEL
|
||||||
|
|
||||||
extern bool powersupply;
|
extern bool powersupply;
|
||||||
|
static float manual_feedrate[] = MANUAL_FEEDRATE;
|
||||||
static void lcd_main_menu();
|
static void lcd_main_menu();
|
||||||
static void lcd_tune_menu();
|
static void lcd_tune_menu();
|
||||||
static void lcd_prepare_menu();
|
static void lcd_prepare_menu();
|
||||||
|
@ -67,14 +66,14 @@ static void lcd_sdcard_menu();
|
||||||
|
|
||||||
#ifdef DELTA_CALIBRATION_MENU
|
#ifdef DELTA_CALIBRATION_MENU
|
||||||
static void lcd_delta_calibrate_menu();
|
static void lcd_delta_calibrate_menu();
|
||||||
#endif // DELTA_CALIBRATION_MENU
|
#endif
|
||||||
|
|
||||||
#if defined(MANUAL_BED_LEVELING)
|
#if defined(MANUAL_BED_LEVELING)
|
||||||
#include "mesh_bed_leveling.h"
|
#include "mesh_bed_leveling.h"
|
||||||
static void _lcd_level_bed();
|
static void _lcd_level_bed();
|
||||||
static void _lcd_level_bed_homing();
|
static void _lcd_level_bed_homing();
|
||||||
static void lcd_level_bed();
|
static void lcd_level_bed();
|
||||||
#endif // MANUAL_BED_LEVELING
|
#endif
|
||||||
|
|
||||||
static void lcd_quick_feedback();//Cause an LCD refresh, and give the user visual or audible feedback that something has happened
|
static void lcd_quick_feedback();//Cause an LCD refresh, and give the user visual or audible feedback that something has happened
|
||||||
|
|
||||||
|
@ -210,12 +209,12 @@ static void menu_action_setting_edit_callback_long5(const char* pstr, unsigned l
|
||||||
|
|
||||||
/** Used variables to keep track of the menu */
|
/** Used variables to keep track of the menu */
|
||||||
#ifndef REPRAPWORLD_KEYPAD
|
#ifndef REPRAPWORLD_KEYPAD
|
||||||
volatile uint8_t buttons;//Contains the bits of the currently pressed buttons.
|
volatile uint8_t buttons; // Bits of the pressed buttons.
|
||||||
#else
|
#else
|
||||||
volatile uint8_t buttons_reprapworld_keypad; // to store the reprapworld_keypad shift register values
|
volatile uint8_t buttons_reprapworld_keypad; // The reprapworld_keypad shift register values
|
||||||
#endif
|
#endif
|
||||||
#ifdef LCD_HAS_SLOW_BUTTONS
|
#ifdef LCD_HAS_SLOW_BUTTONS
|
||||||
volatile uint8_t slow_buttons;//Contains the bits of the currently pressed buttons.
|
volatile uint8_t slow_buttons; // Bits of the pressed buttons.
|
||||||
#endif
|
#endif
|
||||||
uint8_t currentMenuViewOffset; /* scroll offset in the current menu */
|
uint8_t currentMenuViewOffset; /* scroll offset in the current menu */
|
||||||
uint32_t blocking_enc;
|
uint32_t blocking_enc;
|
||||||
|
@ -224,6 +223,7 @@ uint32_t encoderPosition;
|
||||||
#if (SDCARDDETECT > 0)
|
#if (SDCARDDETECT > 0)
|
||||||
bool lcd_oldcardstatus;
|
bool lcd_oldcardstatus;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif // ULTIPANEL
|
#endif // ULTIPANEL
|
||||||
|
|
||||||
menuFunc_t currentMenu = lcd_status_screen; /* function pointer to the currently active menu */
|
menuFunc_t currentMenu = lcd_status_screen; /* function pointer to the currently active menu */
|
||||||
|
@ -520,22 +520,21 @@ void _lcd_preheat(int endnum, const float temph, const float tempb, const int fa
|
||||||
void lcd_preheat_pla0() { _lcd_preheat(0, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
void lcd_preheat_pla0() { _lcd_preheat(0, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
||||||
void lcd_preheat_abs0() { _lcd_preheat(0, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
void lcd_preheat_abs0() { _lcd_preheat(0, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
||||||
|
|
||||||
#if TEMP_SENSOR_1 != 0 //2nd extruder preheat
|
#if TEMP_SENSOR_1 != 0 || TEMP_SENSOR_2 != 0 || TEMP_SENSOR_3 != 0 || TEMP_SENSOR_BED != 0 //more than one extruder present
|
||||||
|
|
||||||
|
#if TEMP_SENSOR_1 != 0
|
||||||
void lcd_preheat_pla1() { _lcd_preheat(1, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
void lcd_preheat_pla1() { _lcd_preheat(1, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
||||||
void lcd_preheat_abs1() { _lcd_preheat(1, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
void lcd_preheat_abs1() { _lcd_preheat(1, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
||||||
#endif //2nd extruder preheat
|
#endif
|
||||||
|
#if TEMP_SENSOR_2 != 0
|
||||||
#if TEMP_SENSOR_2 != 0 //3 extruder preheat
|
|
||||||
void lcd_preheat_pla2() { _lcd_preheat(2, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
void lcd_preheat_pla2() { _lcd_preheat(2, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
||||||
void lcd_preheat_abs2() { _lcd_preheat(2, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
void lcd_preheat_abs2() { _lcd_preheat(2, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
||||||
#endif //3 extruder preheat
|
#endif
|
||||||
|
#if TEMP_SENSOR_3 != 0
|
||||||
#if TEMP_SENSOR_3 != 0 //4 extruder preheat
|
|
||||||
void lcd_preheat_pla3() { _lcd_preheat(3, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
void lcd_preheat_pla3() { _lcd_preheat(3, plaPreheatHotendTemp, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
||||||
void lcd_preheat_abs3() { _lcd_preheat(3, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
void lcd_preheat_abs3() { _lcd_preheat(3, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed); }
|
||||||
#endif //4 extruder preheat
|
#endif
|
||||||
|
|
||||||
#if TEMP_SENSOR_1 != 0 || TEMP_SENSOR_2 != 0 || TEMP_SENSOR_3 != 0 //more than one extruder present
|
|
||||||
void lcd_preheat_pla0123() {
|
void lcd_preheat_pla0123() {
|
||||||
setTargetHotend0(plaPreheatHotendTemp);
|
setTargetHotend0(plaPreheatHotendTemp);
|
||||||
setTargetHotend1(plaPreheatHotendTemp);
|
setTargetHotend1(plaPreheatHotendTemp);
|
||||||
|
@ -548,7 +547,8 @@ void lcd_preheat_abs0() { _lcd_preheat(0, absPreheatHotendTemp, absPreheatHPBTem
|
||||||
setTargetHotend2(absPreheatHotendTemp);
|
setTargetHotend2(absPreheatHotendTemp);
|
||||||
_lcd_preheat(3, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed);
|
_lcd_preheat(3, absPreheatHotendTemp, absPreheatHPBTemp, absPreheatFanSpeed);
|
||||||
}
|
}
|
||||||
#endif //more than one extruder present
|
|
||||||
|
#if TEMP_SENSOR_0 != 0
|
||||||
|
|
||||||
void lcd_preheat_pla_bedonly() { _lcd_preheat(0, 0, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
void lcd_preheat_pla_bedonly() { _lcd_preheat(0, 0, plaPreheatHPBTemp, plaPreheatFanSpeed); }
|
||||||
void lcd_preheat_abs_bedonly() { _lcd_preheat(0, 0, absPreheatHPBTemp, absPreheatFanSpeed); }
|
void lcd_preheat_abs_bedonly() { _lcd_preheat(0, 0, absPreheatHPBTemp, absPreheatFanSpeed); }
|
||||||
|
@ -557,18 +557,16 @@ static void lcd_preheat_pla_menu() {
|
||||||
START_MENU();
|
START_MENU();
|
||||||
MENU_ITEM(back, MSG_PREPARE, lcd_prepare_menu);
|
MENU_ITEM(back, MSG_PREPARE, lcd_prepare_menu);
|
||||||
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H1, lcd_preheat_pla0);
|
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H1, lcd_preheat_pla0);
|
||||||
#if TEMP_SENSOR_1 != 0 //2 extruder preheat
|
#if TEMP_SENSOR_1 != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H2, lcd_preheat_pla1);
|
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H2, lcd_preheat_pla1);
|
||||||
#endif //2 extruder preheat
|
#endif
|
||||||
#if TEMP_SENSOR_2 != 0 //3 extruder preheat
|
#if TEMP_SENSOR_2 != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H3, lcd_preheat_pla2);
|
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H3, lcd_preheat_pla2);
|
||||||
#endif //3 extruder preheat
|
#endif
|
||||||
#if TEMP_SENSOR_3 != 0 //4 extruder preheat
|
#if TEMP_SENSOR_3 != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H4, lcd_preheat_pla3);
|
MENU_ITEM(function, MSG_PREHEAT_PLA_N MSG_H4, lcd_preheat_pla3);
|
||||||
#endif //4 extruder preheat
|
#endif
|
||||||
#if TEMP_SENSOR_1 != 0 || TEMP_SENSOR_2 != 0 || TEMP_SENSOR_3 != 0 //all extruder preheat
|
|
||||||
MENU_ITEM(function, MSG_PREHEAT_PLA_ALL, lcd_preheat_pla0123);
|
MENU_ITEM(function, MSG_PREHEAT_PLA_ALL, lcd_preheat_pla0123);
|
||||||
#endif //all extruder preheat
|
|
||||||
#if TEMP_SENSOR_BED != 0
|
#if TEMP_SENSOR_BED != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_PLA_BEDONLY, lcd_preheat_pla_bedonly);
|
MENU_ITEM(function, MSG_PREHEAT_PLA_BEDONLY, lcd_preheat_pla_bedonly);
|
||||||
#endif
|
#endif
|
||||||
|
@ -579,23 +577,24 @@ static void lcd_preheat_abs_menu() {
|
||||||
START_MENU();
|
START_MENU();
|
||||||
MENU_ITEM(back, MSG_PREPARE, lcd_prepare_menu);
|
MENU_ITEM(back, MSG_PREPARE, lcd_prepare_menu);
|
||||||
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H1, lcd_preheat_abs0);
|
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H1, lcd_preheat_abs0);
|
||||||
#if TEMP_SENSOR_1 != 0 //2 extruder preheat
|
#if TEMP_SENSOR_1 != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H2, lcd_preheat_abs1);
|
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H2, lcd_preheat_abs1);
|
||||||
#endif //2 extruder preheat
|
#endif
|
||||||
#if TEMP_SENSOR_2 != 0 //3 extruder preheat
|
#if TEMP_SENSOR_2 != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H3, lcd_preheat_abs2);
|
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H3, lcd_preheat_abs2);
|
||||||
#endif //3 extruder preheat
|
#endif
|
||||||
#if TEMP_SENSOR_3 != 0 //4 extruder preheat
|
#if TEMP_SENSOR_3 != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H4, lcd_preheat_abs3);
|
MENU_ITEM(function, MSG_PREHEAT_ABS_N MSG_H4, lcd_preheat_abs3);
|
||||||
#endif //4 extruder preheat
|
#endif
|
||||||
#if TEMP_SENSOR_1 != 0 || TEMP_SENSOR_2 != 0 || TEMP_SENSOR_3 != 0 //all extruder preheat
|
|
||||||
MENU_ITEM(function, MSG_PREHEAT_ABS_ALL, lcd_preheat_abs0123);
|
MENU_ITEM(function, MSG_PREHEAT_ABS_ALL, lcd_preheat_abs0123);
|
||||||
#endif //all extruder preheat
|
|
||||||
#if TEMP_SENSOR_BED != 0
|
#if TEMP_SENSOR_BED != 0
|
||||||
MENU_ITEM(function, MSG_PREHEAT_ABS_BEDONLY, lcd_preheat_abs_bedonly);
|
MENU_ITEM(function, MSG_PREHEAT_ABS_BEDONLY, lcd_preheat_abs_bedonly);
|
||||||
#endif
|
#endif
|
||||||
END_MENU();
|
END_MENU();
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // more than one temperature sensor present
|
||||||
|
|
||||||
void lcd_cooldown() {
|
void lcd_cooldown() {
|
||||||
setTargetHotend0(0);
|
setTargetHotend0(0);
|
||||||
|
@ -618,7 +617,7 @@ static void lcd_prepare_menu() {
|
||||||
MENU_ITEM(function, MSG_SET_HOME_OFFSETS, lcd_set_home_offsets);
|
MENU_ITEM(function, MSG_SET_HOME_OFFSETS, lcd_set_home_offsets);
|
||||||
//MENU_ITEM(gcode, MSG_SET_ORIGIN, PSTR("G92 X0 Y0 Z0"));
|
//MENU_ITEM(gcode, MSG_SET_ORIGIN, PSTR("G92 X0 Y0 Z0"));
|
||||||
#if TEMP_SENSOR_0 != 0
|
#if TEMP_SENSOR_0 != 0
|
||||||
#if TEMP_SENSOR_1 != 0 || TEMP_SENSOR_2 != 0 || TEMP_SENSOR_BED != 0
|
#if TEMP_SENSOR_1 != 0 || TEMP_SENSOR_2 != 0 || TEMP_SENSOR_3 != 0 || TEMP_SENSOR_BED != 0
|
||||||
MENU_ITEM(submenu, MSG_PREHEAT_PLA, lcd_preheat_pla_menu);
|
MENU_ITEM(submenu, MSG_PREHEAT_PLA, lcd_preheat_pla_menu);
|
||||||
MENU_ITEM(submenu, MSG_PREHEAT_ABS, lcd_preheat_abs_menu);
|
MENU_ITEM(submenu, MSG_PREHEAT_ABS, lcd_preheat_abs_menu);
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -17,9 +17,8 @@
|
||||||
#ifdef DOGLCD
|
#ifdef DOGLCD
|
||||||
extern int lcd_contrast;
|
extern int lcd_contrast;
|
||||||
void lcd_setcontrast(uint8_t value);
|
void lcd_setcontrast(uint8_t value);
|
||||||
#endif
|
|
||||||
|
|
||||||
static unsigned char blink = 0; // Variable for visualization of fan rotation in GLCD
|
static unsigned char blink = 0; // Variable for visualization of fan rotation in GLCD
|
||||||
|
#endif
|
||||||
|
|
||||||
#define LCD_MESSAGEPGM(x) lcd_setstatuspgm(PSTR(x))
|
#define LCD_MESSAGEPGM(x) lcd_setstatuspgm(PSTR(x))
|
||||||
#define LCD_ALERTMESSAGEPGM(x) lcd_setalertstatuspgm(PSTR(x))
|
#define LCD_ALERTMESSAGEPGM(x) lcd_setalertstatuspgm(PSTR(x))
|
||||||
|
|
Reference in a new issue