Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Moonraker-Obico pause stop the bed heater #61

Open
Caouette1988 opened this issue Mar 22, 2023 · 9 comments
Open

Moonraker-Obico pause stop the bed heater #61

Caouette1988 opened this issue Mar 22, 2023 · 9 comments

Comments

@Caouette1988
Copy link

My Obico is set to stop only the extruder heater when pausing a print when it detect a fail, but it also stop the bed heater.
The turn off bed heater was unchecked.
Any thoughts?
Thanks

@MallocArray
Copy link
Contributor

How long was it sitting idle? I recently discovered that the macro for M600 from the macro sample keeps the default idle timeout of 10 minutes and if you don't resume in that time, it turns off all heaters and disables the steppers so you can't resume. This could be the same issue
I added this to my M600 macro to extend the timeout, you may want to add it to the Pause macro instead, if that is what Obico calls when a failure is detected

SET_IDLE_TIMEOUT TIMEOUT=6000

@Caouette1988
Copy link
Author

Caouette1988 commented Mar 22, 2023

You're right, I have a couple macro to turn off heater and printer after idle time and also after the extruder temp get below 35.
There is a way to keep these macro and keep obico pause feature?
Actually in obico I unchecked "Turn off hotend heater(s)" maybe just that will do the trick?
Thank you.

@kennethjiang
Copy link
Contributor

This is a known issue - almost all modern printers have a heater timeout now. Not sure if there is a good way to solve this problem. Please let me know if you have suggestions.

@Caouette1988
Copy link
Author

Caouette1988 commented Mar 24, 2023

How long was it sitting idle? I recently discovered that the macro for M600 from the macro sample keeps the default idle timeout of 10 minutes and if you don't resume in that time, it turns off all heaters and disables the steppers so you can't resume. This could be the same issue I added this to my M600 macro to extend the timeout, you may want to add it to the Pause macro instead, if that is what Obico calls when a failure is detected

SET_IDLE_TIMEOUT TIMEOUT=6000

I find out it not only turn off all heater, but disable stepper too after 10mins. So you were right, bacause here my idle timout setting :
[idle_timeout]
gcode:
TURN_OFF_HEATERS
M84 ; disable steppers
timeout: 600 ;10 min

I'm reading back your response, I had not understand the first time, now I think I get it.
I need to specify a M600 macro with the command SET_IDLE_TIMEOUT TIMEOUT=6000 in it. 6000 stand for 100 minutes.
After that 100 minutes, steppers and heaters will be disable by the idle_timeout.

So I supose that obico send a M600 command to pause the printer when it detect a fail?

Is the synthaxes correct and do I need to define more line in the macro?

[gcode_macro M600]
gcode:
SET_IDLE_TIMEOUT TIMEOUT=6000

@MallocArray
Copy link
Contributor

In my use case I was trying to do a filament change and M600 is the correct gcode for that, but ultimately it was calling the PAUSE macro, so I think you may want to add the idle_timeout increase to the Pause feature, as I assume that is what Obico is calling, but hopefully @kennethjiang can clarify if that is what it does when Obico detects a failure

I'm using Mainsail, so inside of mainsail.cfg I have the original macro:

[gcode_macro PAUSE]
description: Pause the actual running print
rename_existing: PAUSE_BASE
gcode:
  PAUSE_BASE
  _TOOLHEAD_PARK_PAUSE_CANCEL {rawparams}

I'm thinking you may want to define this again in your own macro file or printer.cfg, since mainsail.cfg is read-only so you can redefine it after your printer.cfg line [include mainsail.cfg] (or I assume fluidd has something similar)

Then you can add the value you see fit, such as

[gcode_macro PAUSE]
description: Pause the actual running print
rename_existing: PAUSE_BASE
gcode:
  SET_IDLE_TIMEOUT TIMEOUT=6000
  PAUSE_BASE
  _TOOLHEAD_PARK_PAUSE_CANCEL {rawparams}

I haven't done this myself, but it is what I plan on doing.

@Caouette1988
Copy link
Author

Perfect, more logical that it use Pause.
I'll try that and keep you updated.

I was reading the mainsail.cfg
I saw that firmware retraction can be enabled while pausing.
There is a way to add this to obico pausing?

@Caouette1988
Copy link
Author

Here the line command about fw retraction that are already in mainsail.cfg :

{% set use_fw_retract = False if not macro_found
else False if client.use_fw_retract is not defined
else True if client.use_fw_retract|lower == 'true' and printer.firmware_retraction is defined
else False %}

@Caouette1988
Copy link
Author

Caouette1988 commented Mar 25, 2023

What I finaly do :

[delayed_gcode delayed_pause_hotend_off]
initial_duration: 300. #(5 mins)
gcode:
{% if printer.pause_resume.is_paused %}
SET_HEATER_TEMPERATURE HEATER=extruder TARGET=0
{% endif %}

[gcode_macro PAUSE]
description: Pause the actual running print
rename_existing: PAUSE_BASE
gcode:
SET_GCODE_VARIABLE MACRO=RESUME VARIABLE=last_extruder_temp VALUE="{printer[printer.toolhead.extruder].target}"
PAUSE_BASE
_TOOLHEAD_PARK_PAUSE_CANCEL {rawparams}
SET_IDLE_TIMEOUT TIMEOUT=7200 ; 2hrs
UPDATE_DELAYED_GCODE ID=delayed_pause_hotend_off DURATION=300 #(5 mins)

[gcode_macro RESUME]
description: Resume the actual running print
rename_existing: RESUME_BASE
variable_last_extruder_temp: 0
gcode:
SET_IDLE_TIMEOUT TIMEOUT=600
{% set macro_found = True if printer['gcode_macro _CLIENT_VARIABLE'] is defined else False %}
{% set client = printer['gcode_macro _CLIENT_VARIABLE'] %}
{% set velocity = printer.configfile.settings.pause_resume.recover_velocity %}
{% set sp_move = velocity if not macro_found else client.speed_move|default(velocity) %}
SET_HEATER_TEMPERATURE HEATER=extruder TARGET={last_extruder_temp}
TEMPERATURE_WAIT SENSOR=extruder MINIMUM={last_extruder_temp0.98} MAXIMUM={last_extruder_temp1.02}
_CLIENT_EXTRUDE
RESUME_BASE VELOCITY={params.VELOCITY|default(sp_move)}

But this guy's method interest me, I think this would be more reliable
[idle_timeout]
gcode:
{% if printer.pause_resume.is_paused %}
{action_respond_info("Extruder powered down on idle timeout.")}
M117 Idle Timeout, hotend cooldown
M104 S0 # Set Hot-end to 0C (off)
{% else %}
M117 Idle Timeout, poweroff
TURN_OFF_HEATERS
M84
{% endif %}

I find this there: https://github.com/mainsail-crew/mainsail-config/pull/13

But with thus method, temp still need to be restaured before resume print

@kennethjiang
Copy link
Contributor

Obico is using the standard Moonraker API to pause the print when a failure is detected (or you press the "pause" button in the Obico app). The API we use is: https://moonraker.readthedocs.io/en/latest/web_api/#pause-a-print

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants