Interface Customization

Introduction
The FreeCAD interface is based on the modern Qt toolkit and has a state-of-the-art organization. Some aspects of the interface can be customized. You can, for example, add custom toolbars, with tools from several workbenches or tools defined in macros, and you can create you own keyboard shortcuts. But the menus and default toolbars that come with FreeCAD and its workbenches cannot be changed.



Usage

 * 1) The commands available in the Customize dialog box depend on the workbenches that have been loaded in the current FreeCAD session.  So you should first load all workbenches whose commands you want to have access to.
 * 2) There are several ways to invoke the [[Image:Std_DlgCustomize.svg|16px]] Std DlgCustomize command:
 * 3) * Select the option from the menu.
 * 4) * Right-click a toolbar area and choose from the context menu.
 * 5) The Customize dialog box opens. For more information see Options.
 * 6) The  button does not work at this time.
 * 7) Press the  button to close the dialog box.

Options
In the Customize dialog box the following tabs are available:

Commands


On this tab you can browse the available commands.

Browse commands

 * 1) Select a command category in the Category panel on the left. Some categories match menu entries.
 * 2) The tools available in the selected category are shown in the panel on the right.
 * 3) Hover a command: its tooltip appears.
 * 4) Select a command: its status bar text is displayed below the two panels.

Keyboard


On this tab custom keyboard shortcuts can be defined. Shortcuts for macro commands can be defined on the Macros tab.

Add a custom shortcut

 * 1) Select a command category from the Category dropdown list.
 * 2) Select a command from the Commands panel.
 * 3) The Current shortcut box displays the current short cut, if available.
 * 4) Enter a new shortcut in the Press new shortcut input box. Shortcuts can be up to 4 inputs long. Each input is either a single character, a combination of one or more special keys or a combination of one or more special keys and a character. Use  to correct mistakes.
 * 5) If the shortcut is already in use, a dialog box will ask you if you want to override it, and the command the shortcut is assigned to will appear in the Currently assigned to panel.
 * 6) Press the  button to assign the new shortcut.
 * 7) Press the  button to remove the entered shortcut. This will also remove the content of the Current shortcut box. Note that default shortcuts are not permanently removed. They will be restored upon restarting FreeCAD.

Remove a custom shortcut

 * 1) Select a command category from the Category dropdown list.
 * 2) Select a command from the Commands panel.
 * 3) Press the  button.

Remove all custom shortcuts

 * 1) Press the  button.

Notes (Keyboard)

 * Shortcuts only work if their commands appear in the standard menu or in the menu of a workbench that has been loaded in the current FreeCAD session, or if their commands appear on a visible toolbar.


 * In V0.19 there is an issue with some Draft commands. Their default shortcuts do not work and/or custom shortcuts cannot be assigned to them.
 * To reassign a default shortcut a new shortcut has to be assigned to its original command first.

Workbenches



 * This tab is no longer available. Its functionality has been moved to the Available Workbenches tab in the Workbenches section of the Preferences Editor.

On this tab the Workbench selector list can be changed. The Enabled workbenches list shows the workbenches as they will appear in the Workbench selector.

Disable a workbench

 * 1) Select a workbench in the Enabled workbenches list.
 * 2) Do one of the following:
 * 3) * Drag and drop the workbench onto the Disabled workbenches list.
 * 4) * Press the button.

Re-enable a workbench

 * 1) Select a workbench in the Disabled workbenches list.
 * 2) Do one of the following:
 * 3) * Drag and drop the workbench onto the Enabled workbenches list.
 * 4) * Press the button.

Re-enable all workbenches

 * 1) Press the  button.

Change a workbench position

 * 1) Select a workbench in the Enabled workbenches list.
 * 2) Do one of the following:
 * 3) * Drag the workbench to a new position.
 * 4) * Press the button or the  button. Optionally repeat this until the workbench is in the correct position.

Sort workbenches alphabetically

 * 1) Press the  button.

Toolbars


On this tab custom toolbars can be created and modified.

Select the workbench

 * 1) In the dropdown list on the right select the workbench whose custom toolbars you want to modify. The  option is there for custom toolbars that should be available in all workbenches.

Create a toolbar

 * 1) Press the  button.
 * 2) Enter a name in the dialog box that opens.
 * 3) Press the  button.
 * 4) The new toolbar will appear in the panel on the right.

Rename a toolbar

 * 1) Select a toolbar in the panel on the right.
 * 2) Press the  button.
 * 3) Enter a new name in the dialog box that opens.
 * 4) Press the  button.

Delete a toolbar

 * 1) Select a toolbar in the panel on the right.
 * 2) Press the  button.

Disable a toolbar

 * 1) Uncheck the checkbox in front of the toolbar name in the panel on the right.
 * 2) A disabled toolbar will be invisible in the FreeCAD interface.

Add a command

 * 1) At least one custom toolbar is required. See Create a toolbar.
 * 2) Select the correct toolbar in the panel on the right. If no toolbar is selected, the command will be added to the first toolbar in the list.
 * 3) Select a category from the dropdown list on the left. Macro commands that have been set up on the Macros tab appear in the 'Macros' category.
 * 4) Select a command from the panel on the left.
 * 5) Or select '' to add a separator (a line between two toolbar buttons).
 * 6) Press  button.

Remove a command

 * 1) If required, expand the toolbar in the panel on the right.
 * 2) Select a command.
 * 3) Press  button.

Change a command position

 * 1) If required, expand the toolbar in the panel on the right.
 * 2) Select a command.
 * 3) Press the  button or the  button.
 * 4) Optionally repeat this until the command is in the correct position.

Notes (Toolbars)

 * Toolbars belonging to the current workbench are updated immediately, but after disabling/re-enabling a toolbar a workbench change is required (switch to a different workbench and then switch back).
 * To update global toolbars a workbench change (if commands have been added or removed) or a restart (if the order of a toolbar has changed or a toolbar was renamed) is required.


 * In V0.19 there is an issue with some Draft commands. After adding them to a custom toolbar and exiting the FreeCAD application the file must be manually edited for these commands. Search for the name of the custom toolbar and in that section change the content of the  items that start with  to.

Macros


On this tab user macro commands can be set up. Once set up, they can be added to custom toolbars. FreeCAD uses a dedicated folder for user macros and only macros in that folder can be set up. Use the Std DlgMacroExecute command to find this folder on your system.

If you download a macro with the Addon Manager then make sure that you also download its icon image file. Most macros have an image link on the information page that appears in the Addon Manager. You can for example put this image file in the user macros folder.

If you want to use a macro downloaded from a different source you will have to install it manually. See How to install macros for more information.

Add a macro command

 * 1) In the Macro dropdown list select a macro.
 * 2) Enter a Menu text. This will be the name used to identify the macro command and will also appear in the toolbar if there is no icon.
 * 3) Optionally enter a Tool tip. This text will appear near the location of the mouse when you hover the toolbar icon.
 * 4) Optionally enter a Status text. This text will appear in the status bar when you hover the toolbar icon.
 * 5) Optionally enter the wiki page for the macro, if available, in the What's this input box. Enter the page name, not the full URL.
 * 6) Optionally enter a shortcut in the Accelerator input box. See Keyboard for more information.
 * 7) To add an icon:
 * 8) Press the Pixmap  button.
 * 9) The Choose Icon dialog box opens.
 * 10) If required press the  button to add an icon folder.
 * 11) Select an icon from the panel. The Choose Icon dialog box closes automatically.
 * 12) Press the  button.
 * 13) The macro command appears in the panel on the left.
 * 14) The macro command can now be selected on the Toolbars tab.

Remove a macro command

 * 1) Select the macro command in the panel on the left.
 * 2) Press the  button.

Change a macro command

 * 1) Double-click the macro command in the panel on the left.
 * 2) Make the required changes. Note that you cannot remove the icon, you can only replace it.
 * 3) Press the  button.

Spaceball Motion
This tab is blank if no Spaceball is detected. See: 3Dconnexion input devices.

Spaceball Buttons
This is tab is blank if no Spaceball is detected. See: 3Dconnexion input devices.

Themes
FreeCAD supports complete theming of the interface, via .qss stylesheets. The qss format is very similar to the css format used in web pages, it basically adds methods to reference the different widgets and elements of the Qt interface. You can change the default theme (which simply takes the style defined by your desktop system) by selecting a style sheet in the FreeCAD preferences.

You can also create your own theme if you are not satisfied with the themes that are bundled with FreeCAD, for example by editing an existing style sheet. Your new style must be placed in a specific folder for it to be found by FreeCAD:
 * (on Windows). The folder can be retrieved by entering  in the Python console.
 * (on Linux).
 * (on macOS).

Addons
Addons offer yet another way to customize the use interface. Below are some addons created by users in the FreeCAD community. They can be downloaded through the Addon Manager (note: they are listed on the Workbenches tab).

CubeMenu

 * Github repository: https://github.com/triplus/CubeMenu

Glass

 * Github repository: https://github.com/triplus/Glass.

IconThemes

 * Github repository: https://github.com/triplus/IconThemes

Launcher

 * Github repository: https://github.com/triplus/Launcher

PieMenu

 * Github repository: https://github.com/triplus/PieMenu

RemBench

 * Github repository: https://github.com/triplus/RemBench

ShortCut

 * Github repository: https://github.com/triplus/ShortCuts