Extra python modules/de

Übersicht
Diese Seite listet verschiedene zusätzliche Python-Module und andere Software-Elemente auf, die kostenlos aus dem Internet heruntergeladen werden können und deiner FreeCAD-Installation Funktionalität hinzufügen.



PySide (vorher PyQt4)

 * Homepage (PySide): (http://qt-project.org/wiki/PySide http://qt-project.org/wiki/PySide http://qt-project.org/wiki/PySide)
 * Lizenz: LGPL
 * Optional, wird aber von mehreren Modulen benötigt: Draft, Arch, Ship, Plot, OpenSCAD, Spreadsheet

PySide (früher PyQt) wird von mehreren Modulen von FreeCAD benötigt, um auf die Qt-Schnittstelle von FreeCAD zuzugreifen. Es ist bereits in der Windows-Version von FreeCAD enthalten und wird in der Regel automatisch von FreeCAD unter Linux installiert, wenn es aus offiziellen Repositories installiert wird. Wenn diese Module (Draft, Arch, etc.) nach der Installation von FreeCAD aktiviert werden, bedeutet das, dass PySide (früher PyQt) bereits vorhanden ist und nichts mehr getan werden muss.

Hinweis: FreeCAD hat sich nach und nach von PyQt ab Version 0.13 zu Gunsten von PySide entfernt, das genau den gleichen Job macht, aber eine (LGPL) Lizenz hat, die besser mit FreeCAD kompatibel ist.

Linux
Der einfachste Weg, PySide zu installieren, ist über den Paketmanager deiner Distribution. Auf Debian/Ubuntu-Systemen lautet der Paketname im Allgemeinen python-PySide, während er auf RPM-basierten Systemen pyside genannt wird. Die notwendigen Abhängigkeiten (Qt und SIP) werden automatisch erledigt.

Windows
Das Programm kann unter http://qt-project.org/wiki/Category:LanguageBindings::PySide::Downloads heruntergeladen werden. Du must die Qt- und SIP-Bibliotheken installieren, bevor Du PySide installieren kannst (zu dokumentieren).

macOS
PySide auf dem Mac kann über Homebrew oder Port installiert werden. Weitere Informationen findet man unter Abhängigkeiten einrichten.

Anwendung
Sobald es installiert ist, kann überprüft werden, ob alles funktioniert, indem in die FreeCAD-Python-Konsole eingegeben wird:

Um auf die FreeCAD-Schnittstelle zuzugreifen, gib ein :

Nun kann mit dem Befehl dir begonnen werden, die Oberfläche zu erkunden. Neue Elemente können ergänzt werden, wie ein benutzerdefiniertes Widget, mit Befehlen wie :

Arbeiten mit Unicode :

Arbeiten mit QFileDialog und OpenFileName :

Arbeiten mit QFileDialog und SaveFileName :



Beispiel für den Übergang von PyQt4 und PySide
PS: diese Beispiele von Fehlern wurden beim Übergang von PyQt4 zu PySide gefunden und diese Korrekturen wurden vorgenommen, andere Lösungen sind sicherlich mit den obigen Beispielen verfügbar

Um auf die FreeCAD Oberfläche zuzugreifen, gib ein : Du kannst neue Elemente hinzufügen, wie ein benutzerdefiniertes Widget, mit Befehlen wie :

Arbeiten mit Unicode :

Arbeiten mit QFileDialog und OpenFileName :

Arbeiten mit QFileDialog und SaveFileName :

Die MitteilungsBox:

Arbeiten mit setProperty (PyQt4) und setValue (PySide)

ersetzen durch :

Arbeiten mit setToolTip

ersetzen durch :

oder:



Zusätzliche Dokumentation

 * Qt official documentation site

Pivy

 * Startseite: https://bitbucket.org/Coin3D/coin/wiki/Home
 * Lizenz: BSD
 * Optional, aber von verschiedenen Modulen von FreeCAD benötigt: Draft, Arch

Pivy wird von mehreren Modulen benötigt, um auf die 3D-Ansicht von FreeCAD zuzugreifen. Unter Windows ist Pivy bereits im FreeCAD Installationsprogramm enthalten, unter Linux wird es normalerweise automatisch installiert, wenn Du FreeCAD aus einem offiziellen Repository installierst. Unter macOSX musst Du Pivy leider selbst kompilieren.

Voraussetzungen
Ich glaube, bevor Du Pivy kompilierst, solltest Du Coin und SoQt installiert haben.

Ich fand, dass es zum Bauen auf Mac ausreicht, das Coin3-Binärpaket zu installieren. Der Versuch, Coin von MacPorts aus zu installieren, war problematisch: versuchte, eine Menge X Windowspakete hinzuzufügen und stürzte schließlich mit einem Skriptfehler ab.

Für Fedora habe ich eine RPM mit Coin3 gefunden.

SoQt kompiliert von source gut auf Mac und Linux.



Debian & Ubuntu
Beginnend mit Debian Squeeze und Ubuntu Lucid, ist pivy direkt aus den offiziellen Repositorien verfügbar, was uns eine Menge Ärger erspart. In der Zwischenzeit kannst Du entweder eines der Pakete, die wir (für debian und ubuntu karmic) auf den Download Seiten zur Verfügung gestellt haben, herunterladen oder selbst kompilieren.

Der beste Weg, pivy einfach zu kompilieren, ist, das Debian-Quellpaket für pivy zu holen und ein Paket mit debuild zu erstellen. Es ist derselbe Quellcode von der offiziellen Pivy Seite, aber die Debian Leute haben einige fehlerbereinigende Ergänzungen vorgenommen. Es lässt sich auch gut mit ubuntu karmic kompilieren: http://packages.debian.org/squeeze/python-pivy lade die .orig.gz und die .diff.gz Datei herunter, entpacke dann beide und wende dann den. diff auf den Quellcode an: gehe in den entpackten pivy Quellcode-Ordner und wende den .diff Patch an:

dann

um pivy ordnungsgemäß in ein offizielles installierbares Paket eingebaut zu haben. Dann installiere das Paket einfach mit gdebi.



Andere Linux-Distributionen
Hole Dir zuerst die neuesten Quellen aus dem Projekt-Repositorium:

Ab März 2012 ist die neueste Version Pivy-0.5.

Dann brauchst Du ein Werkzeug namens SWIG, um den C++ Code für die Python Bindungen zu generieren. Pivy-0.5 berichtet, dass es nur mit SWIG 1.3.31, 1.3.33, 1.3.35 und 1.3.40 getestet wurde. Du kannst also eine Quell Tar-Datei für eine dieser alten Versionen von http://www.swig.org herunterladen. Dann entpacke sie und mache sie von der Kommandozeile aus (als root):

Der Bau dauert nur wenige Sekunden.

Alternativ kannst Du versuchen, mit einer neueren SWIG zu bauen. Ab März 2012 ist eine typische Repositorien Version 2.0.4. Pivy hat ein kleines Kompilierproblem mit SWIG 2.0.4 unter macOS (siehe unten), scheint aber auf Fedora Core 15 gut zu bauen.

Danach gehst du zu den pivy Quellen und rufst

die die Quelldateien erstellt. Beachte, dass der Bau tausende von Warnungen erzeugen kann, aber hoffentlich keine Fehler auftreten werden.

Dies ist wahrscheinlich veraltet, aber du köntest auf einen Compiler Fehler stoßen, bei dem ein 'const char*' nicht in ein 'char*' umgewandelt werden kann. Um das zu beheben, musst du nur eine 'const' vorher in die entsprechenden Zeilen schreiben. Es sind sechs Zeilen zu korrigieren.

Danach installieren durch ausgeben (als root):

Das war's, pivy ist installiert.

macOS
Diese Anleitungen könnten möglicherweise nicht vollständig sein. Etwas in dieser Art funktionierte für OS 10.7 ab März 2012. Ich verwende MacPorts für Repositorien, aber andere Optionen sollten auch funktionieren.

Wie für Linux, hole dir die neueste Quelle:

Wenn du kein hg hast, kannst du es von MacPorts holen:

Dann brauchst du wie oben SWIG. Es sollte eine Sache sein von:

Ich fand, ich brauche auch:

Seit März 2012 ist die MacPorts SWIG Version 2.0.4. Wie oben für Linux angemerkt, ist es vielleicht besser, eine ältere Version herunterzuladen. SWIG 2.0.4 scheint einen Fehler zu haben, der das Bauen von Pivy verhindert. Siehe erste Meldung in diesem: Auszug

Dies kann korrigiert werden, indem man die 2 Quellorte bearbeitet, um Dereferenzierungen hinzuzufügen: *arg4, *arg5 an Stelle von arg4, arg5. Jetzt sollte Pivy bauen:

Windows
Angenommen, du verwendest Visual Studio 2005 oder höher, solltest du eine Eingabeaufforderung mit 'Visual Studio 2005 Command prompt' aus dem Werkzeugmenü öffnen. Wenn der Python-Interpreter noch nicht im Systempfad liegt, mache

Um mit pivy arbeiten zu können, solltest du dir die neuesten Quellen aus dem Repositorium des Projekts besorgen:

Dann brauchst Du ein Werkzeug namens SWIG, um den C++ Code für die Python Bindungen zu erzeugen. Es wird empfohlen, die Version 1.3.25 von SWIG zu verwenden, nicht die neueste Version, da Pivy im Moment nur mit 1.3.25 korrekt funktioniert. Lade die Binärdateien für 1.3.25 von http://www.swig.org herunter. Entpacke sie dann und füge sie von der Kommandozeile aus dem Systempfad hinzu

und setze COINDIR auf den entsprechenden Pfad

Unter Windows erwartet die Pivy Konfigurationsdatei standardmäßig SoWin anstelle von SoQt. Ich habe keinen naheliegenden Weg gefunden, um mit SoQt zu bauen, also habe ich die Datei setup.py direkt modifiziert. In Zeile 200 einfach den Teil 'sowin' : ('gui._sowin', 'sowin-config', 'pivy.gui.') entfernen (die schließende Klammer nicht entfernen).

Danach gehe zu den pivy Quellen und rufe

was die Quelldateien erstellt. Es kann sein, dass du einen Kompilierer Fehler bekommst, weil mehrere Kopfdateien nicht gefunden wurden. In diesem Fall passe die INCLUDE Variable an

und wenn die SoQt Kopfzeilen nicht an der gleichen Stelle wie die Coin Kopfzeilen sind auch

und schließlich die Qt Kopfzeilen

Wenn du die Express Edition von Visual Studio verwendest, erhälst du möglicherweise eine Python-keyerror-Ausnahme. In diesem Fall musst Du ein paar Dinge in der Datei msvccompiler.py, die sich in deiner Pythoninstallation befindet, ändern.

Gehe zur Zeile 122 und ersetze die Zeile

mit

Dann versuche es noch einmal. Wenn du einen zweiten Fehler erhältst, wie

Du must auch Zeile 128 ersetzen

mit

Versuche es noch einmal. Wenn du wieder einen Fehler wie

dann solltest du die Umgebungsvariablen DISTUTILS_USE_SDK und MSSDK prüfen mit

Wenn noch nicht gesetzt, dann setze ihn einfach z.B. auf 1

Nun kann es zu einem Compilerfehler kommen, bei dem ein 'const char*' nicht in ein 'char*' umgewandelt werden kann. Um das zu beheben, musst du nur vorher eine 'const' in die entsprechenden Zeilen schreiben. Es sind sechs Zeilen zu korrigieren. Danach kopiere das generierte Pivy-Verzeichnis an einen Ort, wo der Python-Interpreter in FreeCAD es finden kann.

Anwendung
Um zu überprüfen, ob Pivy korrekt installiert ist:

Um pivy Zugriff auf den FreeCAD Szenengraphen zu haben, gehe wie folgt vor:

Du kannst nun den FCSceneGraph mit dem dir Befehl untersuchen.



Zusätzliche Dokumentation
Leider ist die Dokumentation über pivy im Netz immer noch fast nicht vorhanden. Aber du könntest die Coin-Dokumentation nützlich finden, da pivy einfach Coin Funktionen, Knoten und Methoden in Python übersetzt, alles behält den gleichen Namen und die gleichen Eigenschaften, wobei der Unterschied in der Syntax zwischen C und Python berücksichtigt wird:


 * https://bitbucket.org/Coin3D/coin/wiki/Documentation - Coin3D API Referenz
 * http://www-evasion.imag.fr/~Francois.Faure/doc/inventorMentor/sgi_html/index.html - Der Inventor Mentor - Die "Bibel" der Inventor Szenenbeschreibungssprache.

Du kannst dir auch die Datei Draft.py im FreeCAD Mod/Draft Ordner ansehen, da sie starken Gebrauch von pivy macht.

pyCollada

 * Startseite: http://pycollada.github.com
 * Lizenz: BSD
 * optional, notwendig um den Import und Export von Collada-Dateien (.DAE) zu ermöglichen

pyCollada ist eine Python-Bibliothek, die es Programmen ermöglicht, Dateien Collada (*.DAE) zu lesen und zu schreiben. Wenn pyCollada auf Ihrem System installiert ist, ist FreeCAD in der Lage, den Import und Export im Collada Dateiformat zu handhaben.

Installation
Pycollada ist normalerweise noch nicht in den Repositorien der Linux Distributionen verfügbar, aber da es nur aus Python-Dateien besteht, muss es nicht kompiliert werden und ist einfach zu installieren. Es gibt 2 Wege, oder direkt aus dem offiziellen Pycollada-git-Repositorium, oder mit dem Werkzeug easy_install.

Linux
In jedem Fall benötigst Du die folgenden Pakete bereits installiert auf Deinem System:



Aus dem Git Repositorium


Mit easy_install
Angenommen, du hast bereits eine komplette Python-Installation, sollte das Hilfsprogramm easy_install bereits vorhanden sein:

Du kannst überprüfen, ob pycollada korrekt installiert wurde, indem du in einer Python-Konsole eingibst:

Wenn es nichts zurückgibt (keine Fehlermeldung), dann ist alles OK

Windows
Wenn es nichts zurückgibt (keine Fehlermeldung), dann ist alles OK. Unter Windows, da 0.15 pycollada sowohl in der FreeCAD Version als auch in den Entwickler Builds enthalten ist, so dass keine zusätzlichen Schritte notwendig sind.

MacOS
Wenn du den Homebrew Build von FreeCAD verwendest, kannst du pycollada mit pip in dein System Python installieren.

Wenn du pip installieren musst:

Installiere pycollada:

Wenn du eine binäre Version von FreeCAD verwendest, kannst du pip anweisen, pycollada in die Site Pakete innerhalb von FreeCAD.app zu installieren:

oder nach dem Herunterladen des pycollada Codes

IfcOpenShell

 * Startseite: http://www.ifcopenshell.org
 * Lizenz. * LGPL
 * optional, notwendig zur Erweiterung der Importfähigkeit von IFC-Dateien

IFCOpenShell ist eine derzeit in Entwicklung befindliche Bibliothek, die es erlaubt, Dateien Industry Foundation Classes (*.IFC) zu importieren (und bald auch zu exportieren). IFC ist eine Erweiterung des STEP-Formats und wird zum Standard in [hhttps://de.wikipedia.org/wiki/Building_Information_Modeling BIM]-Arbeitsabläufen. Wenn ifcopenshell korrekt auf Ihrem System installiert ist, wird das FreeCAD Arch-Arbeitsgebiet es erkennen und zum Importieren von IFC-Dateien verwenden, anstelle des eingebauten rudimentären Importeurs. Da ifcopenshell wie FreeCAD auf OpenCasCade basiert, ist die Qualität des Imports sehr hoch und erzeugt hochwertige Volumenkörpergeometrie.

Installation
Da ifcopenshell ziemlich neu ist, wirst du es wahrscheinlich selbst kompilieren müssen.

Linux
Du brauchst ein paar auf deinem System installierte Entwicklungspakete, um ifcopenshell zu kompilieren:

aber da FreeCAD auch alle benötigt, benötigst Du, wenn Du FreeCAD kompilieren kannst, keine zusätzlichen Abhängigkeiten, um IfcOpenShell zu kompilieren.

Hole dir den neuesten Quellcode von hier:

Der Bauprozess ist sehr einfach:

oder, wenn du oce statt opencascade benutzt:

Da ifcopenshell hauptsächlich für Blender gemacht ist, verwendet es standardmäßig Python3. Um es innerhalb von FreeCAD zu verwenden, musst du es gegen die gleiche Version von Python kompilieren, die auch von FreeCAD verwendet wird. Daher musst du möglicherweise die Python-Version mit zusätzlichen cmake-Parametern erzwingen (passe die Python-Version an Deine an):

Dann:

Du kannst überprüfen, ob ifcopenshell korrekt installiert wurde, indem du in einer Python-Konsole eingibst:

Wenn es nichts zurückgibt (keine Fehlermeldung), dann ist alles OK

Windows
Hinweis: Offizielle FreeCAD Installationsprogramme, die von der FreeCAD Webseite/Github Seite bezogen wurden, enthalten jetzt bereits ifcopenshell.

Kopiert von der IfcOpenShell README Datei

Anwendern wird empfohlen, die Visual Studio .sln Datei im Ordner win/ zu verwenden. Für Windows-Anwender ist eine vorkompilierte Open CASCADE Version auf der OpenCASCADE-Webseite erhältlich. Lade diese Version herunter, installiere sie und stelle die Pfade zu den OpenCASCADE-Header- und Bibliotheksdateien für MS Visual Studio C++ zur Verfügung.

Um den IfcPython wrapper zu erstellen, muss SWIG installiert werden. Bitte lade die aktuelle swigwin Version von der SWIG-Webseite herunter. Nach dem Entpacken der .zip-Datei füge bitte den entpackten Ordner in die Umgebungsvariable PATH ein. Python muss installiert sein, bitte gib die Include- und Bibliotheks-Pfade in Visual Studio an.

Verweise
Tutorium Import/Export IFC - compiling IfcOpenShell

Installation
Auf allen Plattformen, nur durch Installation des entsprechenden Pakets von ODA DWG-DXF Converter. Nach der Installation, wenn das Dienstprogramm nicht automatisch von FreeCAD gefunden wird, musst Du möglicherweise den Pfad zur ausführbaren Konverterdatei manuell einstellen; öffne Bearbeiten → Einstellungen → Import-Export → DWG und fülle "Pfad zum Teigha File Converter" entsprechend aus.

LazyLoader
LazyLoader ist ein Python-Modul, das ein zeitversetztes Laden ermöglicht, während der Import immer noch am Anfang des Skripts erfolgt. Dies ist nützlich, wenn du ein anderes Modul importierst, das langsam ist und im gesamten Skript mehrmals verwendet wird. Die Verwendung von LazyLoader kann die Startzeiten des Arbeitsbereichs verbessern, aber das Modul muss bei der ersten Verwendung immer noch geladen werden.

Installation
LazyLoader ist in FreeCAD v0.19 enthalten

Anwendung
Du musst LazyLoader importieren und dann den Import des Moduls, das zurückgestellt werden soll, ändern.

Die Variable Part gibt an, wie das Modul in deinem Skript benannt ist. Du kannst "Part als P importieren" wiederholen, indem du die Variable änderst.

You can also import a module from a package.

Du kannst keine Einzelfunktionen importieren, sondern nur ganze Module.

Verweise

 * Originalquelle: https://github.com/tensorflow/tensorflow/blob/master/tensorflow/python/util/lazy_loader.py
 * Weitere Erklärung: https://wil.yegelwel.com/lazily-importing-python-modules/
 * Code innerhalb des FreeCAD Quellcodes: https://github.com/FreeCAD/FreeCAD/tree/master/src/3rdParty/lazy_loader
 * Forumsdiskussion: https://forum.freecadweb.org/viewtopic.php?f=10&t=45298