display: Use a separate display group for 16x4 multiple extruders

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-03-04 19:08:01 -05:00
parent 0ba83c5b04
commit f2dd4b001d
1 changed files with 73 additions and 57 deletions

View File

@ -2,7 +2,7 @@
###################################################################### ######################################################################
# Display templates # Helper macros for showing common screen values
###################################################################### ######################################################################
[display_template _heater_temperature] [display_template _heater_temperature]
@ -30,6 +30,31 @@ text:
~degrees~ ~degrees~
{% endif %} {% endif %}
[display_template _fan_speed]
text:
{% if 'fan' in printer %}
{% set speed = printer.fan.speed %}
{% if speed %}
~animated_fan~
{% else %}
~fan~
{% endif %}
{ "{:>4.0%}".format(speed) }
{% endif %}
[display_template _printing_time]
text:
{% set ptime = printer.idle_timeout.printing_time %}
{% set progress = printer.display_status.progress %}
{% if progress >= 0.05 and ptime % 12 >= 6 %}
# Periodically show time remaining
{% set rtime = (ptime / progress) - ptime %}
{ "-%02d:%02d" % (rtime // (60 * 60), (rtime // 60) % 60) }
{% else %}
{% set msg = "%02d:%02d" % (ptime // (60 * 60), (ptime // 60) % 60) %}
{ "%6s" % (msg,) }
{% endif %}
[display_template _print_status] [display_template _print_status]
text: text:
{% if printer.display_status.message %} {% if printer.display_status.message %}
@ -52,77 +77,68 @@ text: { render("_heater_temperature", param_heater_name="extruder") }
[display_data _default_16x4 fan] [display_data _default_16x4 fan]
position: 0, 10 position: 0, 10
text: text: { render("_fan_speed") }
{% if 'fan' in printer %}
{% set speed = printer.fan.speed %}
{% if speed %}
~animated_fan~
{% else %}
~fan~
{% endif %}
{ "{:>4.0%}".format(speed) }
{% endif %}
[display_data _default_16x4 row1col0] [display_data _default_16x4 heater_bed]
position: 1, 0 position: 1, 0
text: text: { render("_heater_temperature", param_heater_name="heater_bed") }
{% if 'extruder1' in printer %}
# A multi-extruder setup uses an alternate screen layout
{ render("_heater_temperature", param_heater_name="extruder1") }
{% else %}
{ render("_heater_temperature", param_heater_name="heater_bed") }
{% endif %}
[display_data _default_16x4 ro1col10] [display_data _default_16x4 speed_factor]
position: 1, 10 position: 1, 10
text: text:
{% if 'extruder1' in printer %} ~feedrate~
# A multi-extruder setup uses an alternate screen layout { "{:>4.0%}".format(printer.gcode.speed_factor) }
{% set progress = printer.display_status.progress %}
{ "{:^6.0%}".format(progress) }
{% else %}
~feedrate~
{ "{:>4.0%}".format(printer.gcode.speed_factor) }
{% endif %}
[display_data _default_16x4 row2col0] [display_data _default_16x4 print_progress]
position: 2, 0 position: 2, 0
text: text: { "{:^10.0%}".format(printer.display_status.progress) }
{% if 'extruder1' in printer %} [display_data _default_16x4 progress_bar]
# A multi-extruder setup uses an alternate screen layout position: 2, 1 # Draw graphical progress bar after text is written
{ render("_heater_temperature", param_heater_name="heater_bed") } text: { draw_progress_bar(2, 0, 10, printer.display_status.progress) }
{% else %}
{% set progress = printer.display_status.progress %}
{ "{:^10.0%}".format(progress) }
{% endif %}
[display_data _default_16x4 printing_time] [display_data _default_16x4 printing_time]
position: 2, 10 position: 2, 10
text: text: { render("_printing_time") }
{% set ptime = printer.idle_timeout.printing_time %}
{% set progress = printer.display_status.progress %}
{% if progress >= 0.05 and ptime % 12 >= 6 %}
{% set rtime = (ptime / progress) - ptime %}
{ "-%02d:%02d" % (rtime // (60 * 60), (rtime // 60) % 60) }
{% else %}
{% set msg = "%02d:%02d" % (ptime // (60 * 60), (ptime // 60) % 60) %}
{ "%6s" % (msg,) }
{% endif %}
[display_data _default_16x4 print_status] [display_data _default_16x4 print_status]
position: 3, 0 position: 3, 0
text: { render("_print_status") } text: { render("_print_status") }
[display_data _default_16x4 progress_bar]
position: 3, 16 # Render graphical progress bar after text is written ######################################################################
text: # Alternative 16x4 layout for multi-extruders
{% set progress = printer.display_status.progress %} ######################################################################
{% if 'extruder1' in printer %}
# A multi-extruder setup uses an alternate screen layout [display_data _multiextruder_16x4 extruder]
{ draw_progress_bar(1, 10, 6, progress) } position: 0, 0
{% else %} text: { render("_heater_temperature", param_heater_name="extruder") }
{ draw_progress_bar(2, 0, 10, progress) }
{% endif %} [display_data _multiextruder_16x4 fan]
position: 0, 10
text: { render("_fan_speed") }
[display_data _multiextruder_16x4 extruder1]
position: 1, 0
text: { render("_heater_temperature", param_heater_name="extruder1") }
[display_data _multiextruder_16x4 print_progress]
position: 1, 10
text: { "{:^6.0%}".format(printer.display_status.progress) }
[display_data _multiextruder_16x4 progress_bar]
position: 1, 11 # Draw graphical progress bar after text is written
text: { draw_progress_bar(1, 10, 6, printer.display_status.progress) }
[display_data _multiextruder_16x4 heater_bed]
position: 2, 0
text: { render("_heater_temperature", param_heater_name="heater_bed") }
[display_data _multiextruder_16x4 printing_time]
position: 2, 10
text: { render("_printing_time") }
[display_data _multiextruder_16x4 print_status]
position: 3, 0
text: { render("_print_status") }
###################################################################### ######################################################################