NEWS
Adapter Klipper-Moonraker
-
@foxriver76
Ahso, es heißt immer noch: "Adapter" für "Adapter" schreiben.
Und keine vernünftige Status Daten vom Drucker.
Als nicht Profi Programmierer, bleibe ich dann bei Überwachung mit Webcam+VPN+Webinterface...Ich bedanke mich trotzdem bei allen Entwicklern.
-
Da ich nichts bei Google gefunden habe:
Kann ich die voraussichtliche Restdruckzeit irgendwie auslesen? -
Mahlzeit zusammen.
Ich habe mir vor 2 Wochen auch endlich einen 3D-Drucker gekauft, sozusagen als vorgezogenes Weihnachtsgeschenk für mich selbst. Es ist ein ELEGOO Neptune 4 Plus geworden. Und als ich dann feststellte, daß es einen Adapter für ioB gibt, war die Freude noch größer.
@foxriver76, sehe ich das richtig, daß Du da jetzt auch Entwicklungsarbeit reinsteckst? Eventuell kannst Du mir ja behilflich sein. In den Objekten wird mir der Druckfortschritt angezeigt, allerdings nicht als z.B.
80%
, sondern als0,8%
. Kannst Du da was machen?Außerdem besteht das Problem immer noch, daß der Adapter nach Neustart des Druckers (also wenn er komplett AUS war) keine neuen Werte liefert. @Dutchman, hattest Du die Möglichkeit, Dir das mal anzuschauen?
.
.
.
Aber erstmal ist jetzt Weihnachten. Ich wünsche Euch viele Geschenke und lecker Essen.* , _/^\_ < > * /.-.\ * * `/&\` * ,@.*;@, /_o.I %_\ * * (`'--:o(_@; /`;--.,__ `') * ;@`o % O,*`'`&\ * (`'--)_@ ;o %'()\ * /`;--._`''--._O'@; /&*,()~o`;-.,_ `""`) * /`,@ ;+& () o*`;-';\ (`""--.,_0 +% @' &()\ /-.,_ ``''--....-'`) * * /@%;o`:;'--,.__ __.'\ ;*,&(); @ % &^;~`"`o;@(); * /(); o^~; & ().o@*&`;&%O\ jgs `"="==""==,,,.,="=="==="` __.----.(\-''#####---...___...-----._ '` \)_`"""""` .--' ') o( )_-\ `"""` `
-
@1topf Den Fortschritt einfach mit 100 multiplizieren, wenn du das als Prozent haben willst. So ist es halt ein Wert zwischen 0 und 1
Bezüglich den Daten: Ich lasse den Adapter einfach alle 10 Minuten neu starten.
Ich lass mir in der Vis die Sachen anzeigen:
Creality K1 verbunden: true Druckerstatus: printing Datei: Plate 2 - Muted White_0.15mm_PLA_Generic Klipper Printer_7h26m.gcode Fortschritt: 56.0% Druckzeit bisher: 04:20:42h Layer: 348 / 772 Druckbett: 55°C / 55°C Düse: 209°C / 210°C
-
Ich bin hier am verzweifeln mir die restzeit raus zu fummeln in HA gehts ja auch hat jemand schon ne lösung dafür ?
in HA schaut das ganze so aus
swx1_time_remaining: unique_id: sensor.swx1_time_remaining friendly_name: "T-remaining" icon_template: mdi:clock-end value_template: >- {{ (((states.sensor.swx1_sensor.attributes['print_stats']['print_duration'] / states.sensor.swx1_sensor.attributes['display_status']['progress'] - states.sensor.swx1_sensor.attributes['print_stats']['print_duration']) if states.sensor.swx1_sensor.attributes['display_status']['progress'] > 0 else 0) | timestamp_custom('%H:%M:%S', 0)) if is_state('sensor.swx1_sensor', 'OK') else None }}
-
Die Restzeit hat es mir gestern unter "display-status" - "message" angezeigt. Heute steht dort nur "printing".
-
@kammi_ Hab leider keine Möglichkeit gefunden. Der Adapter liefert da keinen brauchbaren Wert
-
@1topf Bei mir gibt es
display_status.progress
als DP. Habe da auch einen Alias drauf für*100
wenn das immer eine Konvertierung benötigt, kann man das auch im Adapter einbauen ja. -
@foxriver76 Schöner wäre die geplante Endzeit
-
@merlin123 gibt es nicht über die API
-
@foxriver76 Ah ok. Schade Ich finde aber irgendwie auch sonst keine Möglichkeit, die Restlaufzeit oder so herauszufinden.
Hab mal versucht über den Fortschritt und die verstrichene Zeit was zu machen, aber der Fortschritt scheint sich nicht auf die Zeit zu beziehen.. -
so nach einigen hin und her auch wenn es umständlich ist, wenn ich jetzt meine API abrufe
http://192.168.0.84:7125/printer/objects/query?display_status
bekomm ich folgende ausgabe
result eventtime 21482.066148242 status display_status progress 0 message "00-22"
gelöst durch dieses makro
[gcode_macro M73] rename_existing: M990073 #variable_R: 0 #variable_P: 0 #default_parameter_P: 0 #default_parameter_R: 0 gcode: #SET_GCODE_VARIABLE MACRO=M73 VARIABLE=R TYPE=int VALUE={params.R} #SET_GCODE_VARIABLE MACRO=M73 VARIABLE=P TYPE=int VALUE={params.P} M990073 P{ params.P|int} M117 { "%02d-%02d" % (params.R|int // 60, (params.R|int) % 60) }
-
lässt sich doch jetzt mit blockly etc und der simpleapi einfach umsetzen
-
Also ich hab das alles ohne API, sondern nur über die IP des Druckers. Jetzt drucke ich gerade etwas (... meine Frau guckt schon komisch ... ), und da zeigt es die verbleibende Zeit wieder an. Ich muß nur mal in Ruhe vergleichen, wo der Unterschied liegt: jetzt habe ich die Datei per CURA zum Drucker geschickt, die vorige (ohne Anzeige im DP) aber mit ELEGOO CURA (abgewandelte Form vom Hersteller). Morgen habe ich eventuell Zeit für Vergleiche.
-
Das mit der API liegt daran das ich nich die VIS sondern ein Dashboard benutze
-
@kammi_ Also zum Verständnis:
Ich muss das Marco in Klipper einbauen, dann kann ich mithttp://192.168.0.252:7125/printer/objects/query?display_status
nicht nur
{"result": {"eventtime": 37888.166006499, "status": {"display_status": {"progress": 0.81, "message": null}}}}
Sondern auch die Message in der Art "00-22" was dann ein Ende um 0:20Uhr bedeuten würde?
NACHTRAG:
Wenn ich das Macro ans Ende der gcode_macro.cfg kopiere und den status abrufe, hat sich nichts geändert
Ich hab das auf nem Creality K1 am Laufen -
Moin und Frohe Weihnachten euch allen. Ich habe das am anfang bei mir eingefügt
# QIDI Plus4 V1.6.0 #20241102 #1. 起始代码腔室加热将在调平后开启 #2. 腔室加热开启必须带着热床升温 #3. M141和M191宏定义修改,热床低于70会开启热床加热 #4. ## eigener code anfang [gcode_macro M73] rename_existing: M990073 #variable_R: 0 #variable_P: 0 #default_parameter_P: 0 #default_parameter_R: 0 gcode: #SET_GCODE_VARIABLE MACRO=M73 VARIABLE=R TYPE=int VALUE={params.R} #SET_GCODE_VARIABLE MACRO=M73 VARIABLE=P TYPE=int VALUE={params.P} M990073 P{ params.P|int} M117 { "%02d%02d" % (params.R|int // 60, (params.R|int) % 60) } ## Eigener code ende [gcode_macro _CG28] gcode:
mit dieser adresse kannst du dir alles anzeigen lassen
http://192.168.0.84:7125/printer/objects/list
würde dann so aussehen wenn du daten abrufen willst
http://192.168.0.84:7125/printer/objects/query?display_status&heaters&print_stats
die 00-22 sind in minuten du kannst die zeile auch so ändern
M117 { "%02d:%02d" % (params.R|int // 60, (params.R|int) % 60) } Minuten
dann wäre die Ausgabe 00:22 Minuten oder was du auch immer dahinter schreibst. Wie ich das anders Formatiere hab ich keine Ahnung gcode is ne andere Welt für mich.
bei mir sieht das dann so aus in der übersicht was mich allerdings nicht stört
-
@kammi_ ok. Danke. Muss ich mir mal anschauen, werd aber erst morgen dazu kommen. Sind das dann stunden:Minuten?
-
Ja ist es, muss jetzt nur noch nen weg finden, wie ich das in blockly umsetz das ich die aktuelle Zeit + die druck Zeit zusammen zähle und die mir ausgeben lasse so das ich se dann wiederum mit der api abrufen kann.
//edit
was ich festgestellt habe ist das es sich bei der Zeit wo ausgegeben wir um reine durck Zeit handelt. Also ohne aufheizen und was sonst noch vor dem eigentlichen druck passiert. -
So. Ich bekomme die Zeit in den Objekten angezeigt, wenn ich in CURA das Script "Display Info on LCD" hinzufüge. Natürlich betrifft das nur die reine Druckzeit, hochheizen ist da nicht dabei.
Leider wird auch die Endzeit "Fertig um ..." nicht mit übermittelt.
Aber es gibt genug Datenpunkte, um den Drucker per smarter Steckdose auszuschalten, z.B. die Temperatur vom Druckbett.
Was momentan wirklich stört ist, daß der Adapter den Fehlerspeicher von ioB füllt, sobald die Verbindung zum Drucker weg ist. Und auch, daß der Adapter mit jedem neuen Druck einen Neustart benötigt.Sonst hab ich nix zu meckern.