/* ready2print Motive */ raus. ponycloud tot, und auf [[trokn]] sind nirgendwo welche...
[stratum0-wiki.git] / 3D-Drucken.mw
1 {{Hardware
2 |kontakt=[[Benutzer:NoikK|NoikK]], [[Benutzer:Daniel Bohrer|Daniel Bohrer]], teilweise auch [[#Druckberechtigte]]
3 |beschreibung=3D-Drucker
4 |status=working
5 |links=[http://repetier.s0 Repetier-Server] auf einem Raspberry Pi
6 |usage=Nach Einweisung durch Druckberechtigte
7 }}
8
9 Mittlerweile stehen im Space mehrere 3D-Drucker, die alle auf unterschiedliche Weise bedient werden können. Um die Bedienung von allen vorhandenen 3D-Druckern zu vereinheitlich und zu vereinfachen, wurde [http://www.repetier-server.com Repetier-Server] auf einem Raspberry Pi installiert. Hier soll die allgemeine Bedienung und die Einrichtung erläutert werden.
10
11 Zu den einzelnen Besonderheiten der Drucker siehe [[RepRap]], [[LulzBot]] und [[TinyBoy]].
12
13 Im Rahmen des ''Studium Generale'' an der TU Braunschweig gab es einen Vortrag von {{Benutzer|larsan}}, der eine grobe Einführung bietet. Die Slides dazu finden sich unter [[:Datei:Stratum 0 3D-Druck-Vortrag Folien Studium Generale.pdf]].
14
15 == Hinweise zur Benutzung ==
16 So ein 3D-Drucker ist nicht gerade billig, deshalb müssen einige Regeln befolgt werden.
17
18 * Nur die [[#Druckberechtigte]]n dürfen drucken.
19 * Kein Essen und Trinken am 3D-Drucker-Arbeitsplatz!
20 * Nicht an den Einstellungen herumspielen. Unbedachtes Ändern von Beschleunigungs- und Geschwindigkeitseinstellungen kann die Motoren und den 3D-Drucker beschädigen.
21 * Wenn der Drucker längere Zeit nicht druckt, stell sicher, dass die Heizung für den Extruder aus ist
22 * Das Filament muss ggf. per Hand nachgeführt werden, wenn es nicht von selbst abrollt.
23 ** Hacks: entsprechend positionierter Mikrofonständer als Abrollvorrichtung für die Rolle
24 * Die Plattform vor dem Drucken gründlich mit Alkohol oder Pinselreiniger säubern, wenn nicht auf Papier gedruckt wird. Das ist eine häufige Ursache für Probleme.
25 * Nach dem Drucken etwa 1-2 Minuten warten, bis die Teile abgekühlt sind, da sie sich ansonsten verformen.
26 * Manche Teile (besonders bei dünnen Strukturen) benötigen Kühlung, hierfür z.B. die Lüfter verwenden (siehe gedruckte Eule)
27 * Den Druck zwischendrin zu unterbrechen um später weiter zu drucken – und sei es nur für 5 Sekunden – ist mit unendlich viel Problemen behaftet und sollte wenn irgendwie möglich vermieden werden.
28
29 == Schritt 1: 3D-Modell erstellen ==
30 :''siehe: [[3D-Modell erstellen]]''
31
32 3D-Modell als [https://de.wikipedia.org/wiki/STL-Schnittstelle .stl-Datei bereitstellen.
33
34 Hierzu kann entweder ein eigenes Design erstellt werden (z.B. mit [http://www.openscad.org/ OpenSCAD], [https://www.tinkercad.com/ Tinkercad]) oder ein bereits vorhandenes verwendet werden (z.B. von [http://www.thingiverse.com/ Thingiverse]). Zum Umwandeln aus anderen 3D-Formaten eignet sich z.B. [https://blender.org Blender].
35
36 ===Geeignete CAD-Programme (Beispiele)===
37 * [http://www.openscad.org OpenSCAD]
38 ** <tt>git clone git://github.com/openscad/openscad.git</tt>
39 ** [http://www.openscad.net Online-Interface] (braucht halbwegs aktuelle Webbrowser mit WebGL)
40 * [https://www.tinkercad.com/ Tinkercad])
41 * [https://www.freecadweb.org/ FreeCAD]
42 * [http://www.meshmixer.com/ Autodesk Meshmixer]
43 * [https://www.rhino3d.com/de/ RhinoCeros]
44 ** Parametrische CAD-Software mit Slicer, vergünstigte Studentenversionen
45 * kommerzielle industriebewehrte Software (sehr teuer) wie NX, Solid Edge, Solid Works, Catia, Creo, Inventor ...
46 * [https://www.blender.org Blender]
47 ** Blender ist in den meisten Distributionen in den Repos
48 * [http://www.implicitcad.org/ ImplicitCAD]
49 * oder jedes andere Program, das einen STL-Export hat
50 * Manchmal enthalten die STLs Fehler und Slic3r kommt durcheinander. [https://cloud.netfabb.com/ Netfabb] kann viele dieser Dateien wieder reparieren.*
51
52 == Schritt 2: Slicen ==
53 Die .stl-Datei müssen in [[reprap:GCode|GCode]] umgewandelt werden, der zum Drucker gesendet werden kann. Dieser Vorgang wird Slicen genannt und benötigt ein weiteres Programm. Im Stratum0 wird der [http://slic3r.org/ Slic3r] oder [https://www.repetier.com/ RepetierHost] (bringt bei der Installation den Slic3r mit) verwendet.
54 * [http://slic3r.org '''Slic3r'''] (oder über die Paketverwaltung, oder <tt>git clone git://github.com/alexrj/Slic3r.git</tt>)
55
56 Weitere Software (unsupported, YMMV):
57 * [http://daid.github.com/Cura/ Cura]
58 ** Beispiel-Konfiguration ist unter [[Reprap/Configs/Cura]] zu finden
59 * [https://www.simplify3d.com/ Simplify 3D (kommerziell)]
60 * [http://fabmetheus.crsndoo.com/index.php Skeinforge]
61 * [https://github.com/ahmetcemturan/SFACT SFACT] (Fork von Skeinforge)
62
63 === Slic3r-Einstellungen ===
64 Wenn Repetier-Host für das Slicen verwendet wird, sollte das eingebundene Programm ''Slic3r'' verwendet werden. Dazu den KAPUTTER LINK <strike>[https://www.dropbox.com/sh/lppa83e1b0kes31/AAAinheEm9P6xD-EZW7AUWzma?dl=0 Download als .zip]</strike> herunterladen, entpacken und anschließend im Repetier-Host unter ''Slicer'' bei ''Manager'' das Slic3r-Konfigurationsverzeichnis auf den entpackten Ordner verweisen. Jetzt sind alle .ini-Dateien, die zum Drucken notwendig sind, vorhanden.
65
66 Alternativ kann das folgende Config-Bundle in Repetier Host oder Slic3r importiert werden. In Slic3r geht das über den Menüpunkt „File“ → „Load Config Bundle“. Eventuell ist diese Config nicht mehr ganz aktuell. Bitte die Hinweise für die jeweiligen Drucker beachten (z.B. [[LulzBot#Slicen]]).
67
68 {{rawinclude|3D-Drucker/SlicerBundle.ini|Slic3rBundle.ini|fold=y}}
69
70 ===Hinweise===
71 * Die Config muss nach jedem Start neu geladen werden
72 * Die Drucktemperatur sollte auf dem Filament stehen. Ansonsten ist 180°C-200°C eine gute Temperatur für PLA, 240°C für ABS.
73 * Der erste Layer sollte mit 10°C mehr gedruckt werden
74 * Es kann helfen, von Zeit zu Zeit die Version zu updaten
75
76 == Schritt 3: GCode senden ==
77 Drucken durch senden des .gcode an den Drucker.
78
79 Bitte vor dem starten eines Drucks unbedingt die Düsenhöhe prüfen (sollte man bei der Einweisung gelernt haben). Sollte die Düsenhöhe nicht passen, bitte unbedingt jemanden fragen der sich wirklich damit auskennt.
80
81 Im Stratum0 wird [http://www.repetier-server.com Repetier-Server] zur Bedienung der 3D-Drucker verwendet. Entweder wird der erstellte .gcode im Webinterface hochgeladen, oder durch [https://www.repetier.com/ RepetierHost] an den Server gesendet. Anschließend kann der Druck über den das Webinterface gestartet werden.
82
83 === Weboberfläche: Repetier-Server ===
84 [[Datei:Repetier s0 Webinterface.png|thumb|Das Repetier-Server-Webinterface]]
85
86 Repetier-Server dient zum Hochladen und Verwalten von G-Code im Browser, sowie dem Starten von Drucken und das allgemeine Steuern der Drucker.
87
88 Der Webserver ist aus dem Stratum0 Netzwerk unter http://repetier.s0 (notfalls 192.168.178.147) zu erreichen:
89 * Benutzername: <code>stratum0</code>
90 * Passwort: <code>stratum0</code> (you guessed it.)
91
92 === Rechner: Repetier-Host ===
93 Neben der Möglichkeit, Repetier-Server über den Browser zu bedienen, kann auch [http://www.repetier.com/ Repetier-Host] auf dem Rechner direkt zum Hochladen des G-Codes verwendet werden. Dies benötigt IP und API-Key:
94
95 * IP: <code>[http://192.168.178.147 192.168.178.147]</code>
96 * API-Key: <code>7b47c015-8a6f-4ef9-811a-3929a335a7da</code>
97 ===Alternativen===
98 ==== Rechner per USB ====
99 Schließlich gibt es noch [http://github.com/kliment/Printrun.git '''Printrun'''/Pronterface/Pronsole], das zum Steuern des Druckers verwendet werden kann, wenn man ihn per USB anschließt (prinzipiell meldet sich der Drucker als serielle Konsole im System, aber du willst etwas mehr Komfort haben). Hiermit kann man insbesondere auch GCode zum Drucker schicken, was allerdings auch über die Weboberfläche kein Problem darstellt.
100 * Pronterface öffnen (<tt>pronterface.py</tt>), den GCode laden und mit 250000 Baud zur entsprechenden seriellen Schnittstelle (meist <tt>/dev/ttyUSB0</tt>) verbinden. Es sollte die Meldung "Printer is now online." erscheinen und die Steuerelemente, die den Drucker kontrollieren, sollten farbig werden.
101 * Es bietet sich an, die Temperaturüberwachung einzuschalten (Checkbox "Watch" neben dem Graphen bzw. "Monitor Printer" neben dem Reset-Button oben)
102 * Dann den Button "Print" drücken.
103
104 ==== Über den Raspberry Pi und SSH ====
105 Falls der Raspberry am Drucker hängt, kann auch der zum Drucken benutzt werden, allerdings mit etwas Komforteinbußen ohne grafische Oberfläche.
106 * Per SSH ist der Raspberry unter dem Namen <tt>rapsberry</tt> [sic] zu erreichen (zB über [[mDNS]]: <tt>ssh pi@rapsberry.local</tt>). Zugangsdaten stehen auf der SD-Karte.
107 * GCode könnt ihr einfach direkt unter <tt>/home/pi</tt> abladen, zB per scp.
108 * Dann entweder:
109 ** <tt>pronsole.py</tt> aus <tt>/home/pi/Printrun</tt> starten
110 ** oder die pronsole-Instanz aus der [[screen]]-Session benutzen, die ich immer benutze (damit nix kaputtgeht, wenn die SSH-Session mal abschmiert): <tt>screen -x</tt>. Mit der Tastenfolge Ctrl-A Ctrl-D kommt man wieder aufs „normale“ Terminal.
111 * pronsole dokumentiert sich eigentlich mit dem Befehl <tt>help</tt> ausreichend selbst. Oft benutzte Befehle sind: <tt>connect</tt>, <tt>load</tt>, <tt>home</tt>, <tt>settemp</tt>, <tt>bedtemp</tt>, <tt>gettemp</tt>, <tt>extrude</tt>, <tt>print</tt>, <tt>monitor</tt>. GCode kann man außerdem auch direkt eingeben.
112
113 ===== Typische Befehlreihenfolgen =====
114 ====== Druck starten ======
115 $ screen -x
116
117 oder, falls das nicht an eine vorhandene screen-Session andockt:
118
119 $ screen Printrun/pronsole.py
120
121 Dann in pronsole:
122
123 > connect
124 > load $filename
125 > print
126
127 ====== Druck abbrechen ======
128 > pause
129 > settemp 0
130 > move z 20
131 > m84
132
133 ===== Hinweise =====
134 * Reverse-extrude geht, indem man dem Befehl <tt>extrude</tt> eine negative Länge gibt.
135 * <tt>/tmp</tt> und <tt>/run</tt> sind im Arbeitsspeicher gemountet, um die SD-Karte etwas zu schonen. Dort also besser nichts wertvolles ablegen.
136
137 == Filamente (outdated)==
138 Wir haben derzeit einen Druckkopf, der eine Filamentstärke von 1,75 mm benötigt.
139
140 === ABS ===
141 Erster Test von {{Benutzer|Sintox}} mit schwarzem 1,75 mm ABS-Filament des Händlers "Filamentworld.de":
142 Sowohl bei großen als auch bei kleinen Teilen:
143 * Heatbed-Temperatur: 80 °C
144 * Hotend-Temperatur: 240 °C
145 * Hotend-Fan (mit "Luft-Kanalisierer"): dauerhaft auf 100%, da am besten keine 120 mm Lüfter verwendet werden sollten (ABS kann sich verformen, wenn der Bauraum zu stark gekühlt wird)
146
147 Geschwindigkeiten und Infill-Dichte sind scheinbar nicht Filament-abhängig und müssen je nach Zweck und Größe des Gedruckten individuell eingestellt werden.
148 Beim verwendeten Filament war keine wirkliche ABS-Geruchsentwicklung im Raum festzustellen, lediglich leichter Geruch direkt am 3D-Drucker.
149
150 Aufheiz-Zeit des Heatbeds auf 80 °C betrug etwa 15 Minuten, zwischen nacheinander gedruckten Modellen besser Heatbed-Temperatur auf 80 °C fixieren, um nicht immer wieder hochheizen zu müssen.
151
152 Ablösen des Gedruckten ist bei großer Kontaktfläche mit dem Heatbed im geheizten Zustand recht schwer, aber mit ein wenig vorsichtiger Verwendung der "Ablöse-Werkzeuge" gut machbar.
153
154 === PLA ===
155
156 Wir haben derzeit PLA in mehreren verschiedenen Farben.
157
158 === Holz-PLA ===
159 {{Benutzer|Ortwin}} hat welches gekauft und [[Benutzer:Daniel Bohrer|Daniel Bohrer]] hat das mal ausprobiert. Die gedruckten Objekte sind längst nicht so stabil wie mit normalen PLA, eher so wie Hartgummi.
160 * grrf sagt zwar, dass Holz-PLA ab 185°C zu drucken geht, aber Temperaturen um 200°C sind anscheinend noch besser für die Festigkeit.
161 * Generell eher was für gröbere Arbeiten, das Filament kann anscheinend nicht sehr fein gedruckt werden. Man sollte darauf achten, dass man nicht zu feine Strukturen und nicht zu wenig Infill druckt (siehe Fotos). Beim Mate-Tags lohnt es sich durchaus, nochmal 1&nbsp;mm bei der Dicke draufzuschlagen.
162 * Das Filament ist ziemlich flüssig, sodass es sehr leicht heraustropft. Dadurch kommen die unschönen Würste am Mate-Tag zustande, Man Müsste™ nochmal probieren, ob Cura das besser als Slic3r hinkriegt (weil es den Druckkopf nur innerhalb der Perimeter bewegt).
163 * Auch aus diesem Grund lohnt es sich durchaus, 3-4 Skirt-Loops zu drucken, bis das Filament wieder richtig fließt.
164 * Nach dem Drucken die Objekte lieber länger als zu kurz abkühlen lassen, sonst sind sie noch ziemlich weich.
165 * Beim Ablösen behutsam vorgehen, das Holz-PLA klebt sehr gerne am Kapton fest, und besonders die Kanten der Kapton-Klebestreifen werden gerne mal mit hochgezogen. (Den Mate-Tag habe ich schließlich mit einem Messer vorsichtig an einer Ecke durch Hebelwirkung abgelöst und mich dann schrittweise mit dem Messer vorgetastet. Das Kapton ist heile geblieben.)
166
167 <gallery heights="150" widths="225">
168 Datei:Holz-PLA Würfel.jpg|Test-Würfel mit nur 20% Infill, dementsprechend failt der oberste Layer… Die untere Hälfte mit 185°C ist etwas heller als die obere Hälfte mit 200°C.
169 Datei:Holz-PLA Mate-Tag 1.jpg|Mate-Tag (durchgängig 200°C, 90% Infill)
170 Datei:Holz-PLA Mate-Tag 2.jpg|Die Haptik erinnert ein bisschen an Kokosfaser.
171 Datei:Holz-PLA Mate-Tag 3.jpg|Resultat von tropfendem Filament, kann aber mit dem Skalpell leicht korrigiert werden
172 </gallery>
173
174 == Fehler und Behebung ==
175 Eine sehr gute Übersicht an Fehlern und Ratschlägen zu deren Behebnung bietet [https://www.simplify3d.com/support/print-quality-troubleshooting/ Simplify3D] jedoch sind viele Lösungen nicht ohne Eingriff in die Firmware anwendbar. Falls es es jemand wirklich für Notwendig erachtet Werte in der Firmware Dauerhaft zu ändern, spricht er bitte [[Benutzer:NoikK|NoikK]] an.
176
177 == Setup und Konfiguration ==
178 === Port 80 statt 3344 für RepetierServer ===
179 Der Standardport des RepetierServers ist 3344, mehr konvenient ist aber Port 80. Um den Port zu ändern:
180 sudo vim /usr/local/Repetier-Server/etc/RepetierServer.xml
181 Da Port 80 aber ein privileged Port ist, muss der RepetierServer-Binary noch die notwendige Capability gegeben werden:
182 sudo setcap cap_net_bind_service=+ep /usr/local/Repetier-Server/bin/RepetierServer
183 Ob das Binary die Capability bekommen hat, kann man mit getcap überprüfen:
184 sudo getcap /usr/local/Repetier-Server/bin/RepetierServer
185 Danach den Service (neu)starten:
186 sudo systemctl restart RepetierServer
187
188 ==Druckberechtigte==
189 * [[Benutzer:DanielWillmann|Daniel Willmann]]
190 * {{Benutzer|Shoragan}}
191 * {{Benutzer|Daniel Bohrer}}
192 * Oni
193 * {{Benutzer|DooMMasteR}}
194 * DieLenaMaria
195 * Marylin
196 * {{Benutzer|Larsan}}
197 * {{Benutzer|Stew}}
198 * {{Benutzer|Chrissi^}}
199 * {{Benutzer|Hanhaiwen}}
200 * {{Benutzer|Matthis}}
201 * {{Benutzer|Emantor}}
202 * {{Benutzer|Joke}}
203 * {{Benutzer|Lulu}}
204 * {{Benutzer|tsuro}}
205 * {{Benutzer|blinry}}
206 * mjh
207 * {{Benutzer|mkalte666}}
208 * {{Benutzer|Pecca}}
209 * {{Benutzer|Ortwin}}
210 * Arnulf
211 * leonmortiba
212 * {{Benutzer|Kasalehlia}}
213 * bw_snaable
214 * {{Benutzer|Sonnenschein}}
215 * {{Benutzer|Drahflow}}
216 * {{Benutzer|Sintox}}
217 * {{Benutzer|Alex-k}}
218 * {{Benutzer|NoikK}}
219 * Tropion
220 * lichtfeind
221 * mkalte
222
223 ==== Interessierte Entitäten ====
224 Bitte bei Bedarf eine erfahrene Druckentität ansprechen.
225 Prinzipiell kann das aber auch jede Entität machen, die sich auskennt und schon mehrmals gedruckt hat. Es gibt keine Prüfung oder ähnliches.
226
227 == Aussicht ==
228 Auf lange Sicht sollen alle 3D-Drucker vereinheitlicht werden. Dazu siehe https://pad.stratum0.org/p/3d-Drucker
229
230 [[Kategorie:RepRap]]
231 [[Kategorie:LulzBot]]
232 [[Kategorie:Infrastruktur]]
233 [[Kategorie:Raspberry Pi]]
234 [[Kategorie:3D-Druck]]
This page took 0.05318 seconds and 5 git commands to generate.