Tutorial
|
Topic
|
Macros
|
Level
|
Beginner
|
Time to complete
|
|
Author
|
|
FreeCAD version
|
|
Example File(s)
|
|
|
This page contains macros to add functionality to your freecad installation
Macros
3D View operations
-
Macro Rotate View Detta makro roterar den nuvarande vyn med 90° åt vänster. Fungerar endast om du är i toppvyn.
Animation
Code and Scripting
-
Macro MessageBox: shows how to give information to the user through the GUI.
-
Macro Python Assistant Window: This macro provides a cut/copy/paste workspace for Python code, it is segmented so different sections can be selected and it is persistent between FreeCAD sessions.
-
Macro Build Utility: This macro provides a utility to assemble a project from sub-project files using the Merge Project facility.
-
Macro Global Variable Watcher: This macro facilitates the user selecting global variables and monitoring their values.
Conversion
- Konvertera Nät till Delar: Detta makro konverterar valda nät till delar. Det har en bred tolerans, så använd det bara med objekt som inte har några kurvor, annars kommer du att få konstiga resultat.
Drawing Workbench
-
Macro Automatic drawing: allows the user to get the view of his object in a drawing with 4 different position (front,top,iso,right). Needs some modification to be perfectly effective
-
Macro CartoucheFC: This GUI macro to fill simply all fields of the cartridge of the plan implementation worksheet FreeCAD, the format of the date and the symbol of the projection mode adapt to the EU region or US selected.
-
Macro CartoucheFC Full: This GUI macro to fill simply all fields of the cartridge templates_Full of the plan implementation worksheet FreeCAD, the format of the date and the symbol of the projection mode adapt to the EU region or US selected.
-
Macro CartoucheFC 2: This GUI macro to fill simply all fields of the cartridge model 2 of the plan implementation worksheet FreeCAD.
-
Macro Normal Vector: Get the normal vector of a preselected face for creating a drawing view normal to that face
Dxf 2D Draft
-
Macro Rectellipse: creates a parametric rectellipse
-
Macro Make Circle 3 Points: creates a circle on 3 selected points, the points can be objects (this example brings together the two examples below, all parameters simply settle on a graphic window).
-
Macro Draft Circle 3 Points: creates a circle from 3 selected points 2D orthogonal
-
Macro Draft Circle 3 Points 3D: creates a circle from 3 selected points in the space 3D
-
Macro Make Arc 3 Points: creates a arc from 3 selected points
-
Macro Ellipse-Center+2Points Makes an ellipse by selecting three points (in this order): centre, major radius and minor radius
-
Macro FC Convert Lines: this macro convert the object line, wire in line Dash, DashDot, DashDotDot,ZigZag and Hand with the dimensions given.
-
Macro EdgesToArc: Converts the selected Edges to a circular Arc if possible. Useful for restoring discretized arcs.
-
Macro Creating faces from a DXF file: This macro create face from a DXF file, the "Layer" are recognized separate and trained in groups.
-
Macro DXF to Face and Sketch: This macro converts selected elements of imported dxf to face and sketch.
-
Macro Compound Plus: Draf command set in a small macro for the 2D sketch example: work with the DXF files.
-
Macro Dxf To Shape: Macro utility for create unique wire with many wires, the type wire created is selected to MakeWire, Bspline, BsplineCurve, BsplineCurve + Arc, Polygon, Bezier curve
Fem
-
Macro GMSH: Create FEM Meshes by GMSH Mesh Generator
Info and measures
-
Macro FCInfo: Gives a series of information about the selected shape and can display a conversion of length, inclination (degrees, radian, grade) shape, surface, volume and the weight of the form in the density selected in various international and Anglo-Saxon units
-
Macro FCInfo Alternate Linux: same as above, but for Linux
-
Macro FCInfoGlass: Gives a series of information about the selected shape and displayed in screen 3D
-
Macro FCInfoToMouse: Provide informations coordinates, length and angles in real time on the mouse in a bubble annotation displayed in the 3D screen
-
Macro Delta xyz: Gives the Delta values and the distance between 2 points
-
Macro ObjectInfo: User-friendly "Info" module created by a FreeCAD user
-
Macro Dump Objects: This macro generates a listing of all objects in the current document - the list can be in a window or on the Report view.
-
Macro MeasureCircle: Compute the radius of a circle by 3 points or a circular edge.
Libraries
Mathematical functions
Multifunctional
-
Macro WorkFeatures: Tool utility to create plans of the axes, planes from 3 points, axes on a form, information on the coordinates of the shape and many other useful features to facilitate the creation of your project. This utility is up next in the combo view.
Object creation
-
Macro Make Cube: creates a rectangular cuboid from 4 points
-
Macro Solid Sweep: creates a solid by sweeping a 2D profile along a trajectory previously selected in the 3D view. The 2D elements can be created through the regular tools in FreeCAD's GUI.
-
Macro Geodesic Dome: This macro creates a geodesic dome shell
-
Macro Line Length: Create a line giving coordinate XYZ length and angle to plane X Y
-
Macro Cut Line: Cut a line and create x points, giving the number of points, create line or not, create points or not, create bicolor or not on choice.
-
Macro CirclePlus: Create a circle or arc giving radius, diameter, circumference, area, startangle, endangle, arc, anglecenter, cord, arrow, center (point) on choice (same below but with GUI) plus create sector and face.
-
Macro Circle: Create a circle or arc giving radius, diameter, circumference, area, startangle, endangle, arc, anglecenter, cord, arrow, center (point) on choice (same above without GUI).
-
Macro Cut Circle: Cut a circle or arc and create x arcs, giving the number of cut.
-
Macro Triangle AH: This macro create one triangle creates a triangle by giving the head angle and the height of the triangle (the triangle of the head is positioned to the xyz coordinates 0.0)
-
Macro Texture: Create a project from a bmp image to create a texture easily
-
Macro Loft: Create a loft with a list of wire (specially created for Macro Texture see above)
-
Macro Circular Text: This macro create a text around a cylinder
-
Macro WireXYZ: This macro creates a Wire with the coordinates extracted from a file. The coordinates X Y Z are separated by a space.
-
Macro Repro Wire: This macro reproduce all element selected subobject wire or face.
-
Macro Apothem Based Prism GUI: A GUI dialog that creates an Apothem, (inradius) Based Prism from user input.
-
Macro FCSpring Helix Variable: This macro create one spring truncate, the troncature is adjustable on the all coil to choice.
-
Macro Guitar fretboard: Guitar Fretboard Maker
Object transformation
Printer 3D
Raytracing
Spreadsheet Workbench
-
Macro Alias Manager: helps managing aliases inside FreeCAD Spreadsheet workbench. It is able to create, delete, move aliases and create a 'part family' group of files.
-
Macro Spreadsheet Tools: This macro helps managing cells inside FreeCAD Spreadsheet workbench.
-
Macro FCTreeView: Macro for list all objects in the project in one list without hierarchy, options sort by name, label, visibility, group, by length option search by name, label .... without case sensitive or with case sensitive and select all objects displayed in the macro window.
-
Macro FCSpreadSheet Extract: This macro save the data in a csv file with the formula or in a xml file.
Utility
Wizards
-
Macro Sheet Metal Unfolder: Creates an unfolded part from a sheet-metal-part.
-
Macro Unroll Ruled Surface: allows to unroll ruled surfaces and to draw them on a page.
-
Macro Unfold Box: allows to unfold the surfaces of a box of any shape and to draw them on a page.
-
Macro Airfoil Import & Scale: Imports and scales a .dat airfoil to desired chord length.
-
Macro Geneva Wheel: Allows the user to create a Geneva wheel mechanism from scratch. Must edit values within the Macro to alter the size of the object.
-
Macro Geneva Wheel GUI: A GUI front end that allows the user to create a Geneva wheel mechanism from scratch.
-
Macro Cabinets32: creates side and top/bottom walls for a cabinet with drilled holes for connection parts of manufacturer Hettich.
-
Macro Half_turn_stairs: Creates a half turn (left/right) stair from a Data-file.
-
Macro Half-Hull Model: This macro generates both three dimensional half-hull and full-hull models from a series of 2D line drawings.
-
Macro Stairs: Create stair helix, create your stair nosing select and run the macro.
-
Macro FCGear: Additional Workbench to create different types of gears, involute gear, involute rack, cycloide gear, bevel gear.
-
Macro Corner shapes wizard: pops up a dialog asking for the dimensions of your corner piece, then creates the object in the document and creates a page view with top, front and lateral views of the piece
-
Macro PropertyMemo: This little macro create one Property additional (memo or other text) for you object (only Draft)
Other interesting macros create by FreeCAD users and deposit in extra wiki.
-
By microelly2 : freeCAD_macro, geodata, Animation, freecad-nurbs, PieMenu, ..... other
-
By hamish2014: FreeCAD_assembly2, FreeCAD_drawing_dimensioning, ...
-
By triplus: IconThemes, ShortCuts, NavigationIndicator, TabBar, Launcher, PersistentToolbars, PieMenu, ....
-
By rockn: FreeCAD-Timber, FreeCAD-addons, FreeCAD-library, FreeCAD-StructuresBois, .... other
-
By oddtopus: flamingo (workbench for metal structures)
-
By dprojects: getDimensions FreeCAD macro to get chipboards dimensions to cut (woodworking)
-
By Siardeni: workbench for create metal profiles, square tubing, z profile, palette, rotation, drawing ...
How to use?
The above macros can easily be plugged on any FreeCAD installation
- Starting from FreeCAD v 0.17, a new Tools -> Addons Manager allows you to easily install any macro from this page. The instructions below must still be followed if your version of FreeCAD doesn't have the Addons Manager yet.
- Copy the macro python code from the corresponding macro page
- In FreeCAD, Macro->Macros->Create new, and give it a name
- Paste the python code you copied
- Hit the Save button, and restart FreeCAD
- Open the Macro manager, select your new macro and click "execute"
- Tutorial How to install macros
Additionally, you can also add your new macro to a custom toolbar
- In FreeCAD, go to Tools -> Customize
- In the Macros tab, add a new macro, and, if you like, define an icon and a keyboard shortcut
- In the Toolbars tab, create a new toolbar, and add your macro, taking it from the "Macros" category.
- Tutorial Customize Toolbars
Adding new macros to this repository
- Create a new page, beginning its name with "Macro", for example "Macro_My_Excellent_Macro", this can be done simply by editing this page, and adding a new link to your macro, like this:
* {{MacroLink|Text-x-python|Macro My Excellent Macro|Macro My Excellent Macro title}} : My excellent macro description.
- Text-x-python : icon by default (replace with your name icon with the exact same name as your macro page if there is. The format always .png only)
- Macro My Excellent Macro : macro name
- Macro My Excellent Macro title : macro name or title
A new page (red link) will be created.
- In that page, paste the following text:
(With the default icon)
{{Macro|Icon=Text-x-python|Name=Macro_My_Excellent_Macro|Description=What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}
(With the icon custom)
{{Macro|Icon=Macro_My_Excellent_Macro|Name=Macro_My_Excellent_Macro|Description=What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}}
(Another language with the default icon (example "/fr" "/de" "/it"....))
{{Macro/fr|Icon=Text-x-python|Name=Macro_My_Excellent_Macro|Name/fr=Macro_My_Excellent_Macro|Description=
What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}
(Another language with the icon custom (example "/fr" "/de" "/it"....))
{{Macro/fr|Icon=Macro_My_Excellent_Macro|Name=Macro_My_Excellent_Macro|Name/fr=Macro_My_Excellent_Macro|Description=
What my excellent macro does|Author=your username|Version=1.0|Date=YYYY-MM-DD}}
- You can also Upload a custom format icon.png
Note that the name of the icon must have the same name as the name of the macro.
- example: " Macro_My_Excellent_Macro " without extension (the extension is given by the system), and, replace " Icon=Text-x-python " by " Icon=Macro_My_Excellent_Macro "
- Text-x-python
is the default icon of the page dedicated to the Macro.
- Paste your macro, and use the Code template to avoid adding spaces into your script. This will display the macro in a monospace font inside a light grey box like the example above.
- If you like, upload a .png icon with the exact same name as your macro page (ex. Macro_My_Excellent_Macro.png)
- Add an image: an image is useful to show what the macro does. Optionally you can create an animated gif that represents the object in context. The gif image should have a maximum size of 500x500px as the wiki does not resize animated gifs; if the gif is any bigger the animation won't work.
- Optionally you can add some more info on how to use your macro, tips, limitations and workaround.
- It is also interesting to include version information in your macro. This macro allows you to locate in time compared to the evolution of FreeCAD, do "Menu > Help > About FreeCAD and click to Copy to clipboard" and paste it your macro
Ex:
#OS: Windows Vista
#Platform: 32-bit
#Version: 0.14.3389
#Python version: 2.6.2
#Qt version: 4.5.2
#Coin version: 3.1.0
#SoQt version: 1.4.1
#OCC version: 6.5.1
It is also advisable to create a macro in your header, this header can be used by the Plugin Loader program to install the macro and check versions. Also available addons_installer.FCMacro
Ex:
__Title__="Title_Of_macro"
__Author__ = "User_Name"
__Version__ = "00.11"
__Date__ = "2015-07-25"
__Comment__ = "This is the comment of the macro"
__Web__ = "http://forum.freecadweb.org/viewtopic.php?f=3&t=7384"
__Wiki__ = "http://www.freecadweb.org/wiki/index.php?title=Macro_Title_Of_macro"
__Icon__ = "/usr/lib/freecad/Mod/plugins/icons/Title_Of_macro"
__IconW__ = "C:/Documents and Settings/YourUserName/Application Data/FreeCAD"
__Help__ = "start the macro and follow the instructions"
__Status__ = "stable"
__Requires__ = "freecad 0.14.3706"
__Communication__ = "http://www.freecadweb.org/wiki/index.php?title=User:User_Name"
- Add it to the above categories, create a new category if needed.
Tutorials