LinkSub
Description
A LinkSub is a data structure that is used as input to various functions and objects; its purpose is to pass a subobject or subelement (vertex, edge, or face) from an object to another object that will use or transform that geometry.
A LinkSub is composed of a list of two arguments.
sub = [argument1, argument2]
The first argument is a reference to a document object, and the second argument is a text string indicating the internal name of the subelement. This name has a number starting with one, and up to the total number of those subelements.
sub = [obj1, "Vertex1"]
sub = [obj2, "Face1"]
sub = [obj3, "Edge1"]
The second argument can itself be a list of strings, indicating various subelements of the same document object.
sub1 = [obj1, ["Vertex1", "Vertex2"]]
sub2 = [obj2, ["Face1", "Face3", "Face5"]]
sub3 = [obj3, ["Vertex1", "Face5", "Edge1", "Edge2"]]
It is possible to see that a LinkSubList is a list of LinkSub structures.
Scripting
See also: FreeCAD Scripting Basics, LinkSubList.
A new scripted object can accept a LinkSub by adding the corresponding property.
It is important to recompute the objects before their subelements are used as input for other objects, otherwise an error may be produced as the geometry may not contain a valid Shape.
doc = App.newDocument()
cube = doc.addObject("Part::Box", "Cube")
cyl = doc.addObject("Part::Cylinder", "Cylinder")
doc.recompute()
new_obj = doc.addObject("App::FeaturePython", "New")
new_obj.addProperty("App::PropertyLinkSub", "Geometry")
new_obj.Geometry = [cube, ["Vertex1", "Vertex2"]]
new_obj2 = doc.addObject("App::FeaturePython", "New")
new_obj2.addProperty("App::PropertyLinkSub", "Geometry")
new_obj2.Geometry = [cyl, "Edge1"]
doc.recompute()
The subelement can then be extracted from the assigned property, and can be manipulated to do something.
>>> new_obj.Geometry
(<Part::PartFeature>, ['Vertex1', 'Vertex2'])
>>> new_obj.Geometry[1]
['Vertex1', 'Vertex2']
>>> new_obj.Geometry[1][1]
'Vertex2'
>>> new_obj.Geometry[1][1].strip("Vertex")
'2'
>>> int(new_obj.Geometry[1][1].strip("Vertex"))
2
- Scripts FreeCAD : Python, Introduction à Python, Tutoriel sur les scripts Python, Débuter avec les scripts
- Modules : Modules intégrés, Unités, Quantity
- Ateliers : Création d'atelier, Commands Gui, Les commandes, Installer des ateliers supplémentaires
- Maillages et objets Parts : Scripts Mesh, Script de données topologiques, Conversion objet Mesh en Part, PythonOCC
- Objets paramétriques : Objets créés par script, Viewproviders (Icône personnalisée dans l'arborescence)
- Scénographie : Graphe de scène Coin (Inventor), Pivy
- Interface graphique : Création d'interface, Création d'une boite de dialogue (1, 2, 3, 4, 5), PySide, Exemples PySide débutant, intermédiaire, expérimenté
- Macros : Macros, Comment installer des macros
- Intégration : Intégrer FreeCAD, Intégration de FreeCADGui
- Autre : Expressions, Extraits de codes, Fonction - tracer une ligne, Bibliothèque mathématique vectorielle de FreeCAD (déprécié)