Skip to main content

MachPro Commands, Function Buttons, and Dashboard

Commands

The system has many packaged functions called commands. These commands can perform a variety of actions, such as turning on the spindle or zeroing an axis. All commands have an action associated with them. Some actions also have a feedback associated with them, such as the 'Spindle Forward' command where the feedback is whether the spindle is currently running forward or not.

Commands and User Commands can be assigned to function buttons on the control, in order to customize the experience.

User Commands

Additionally custom commands, called User Commands, can be configured in the 'Screen Configuration' dialog. This is accessible through the 'Screen Config' button on the Service/Maintenance tab.

dZWcreate_user_command.png

To make a new User Command, press the 'Add' button. Each User Command should have a unique name. To edit a User Command, select its name from the list. A searchable list of actions for the command is available in the first box. This selects the general type of action to be done. The second box, labeled 'Options', is also part of the action and must be selected.

The 'Feedback Source' and 'Feedback Target' sections are optional. They are relevant if the User Command will be assigned to a function button. Some User Commands won't have a logical feedback source. A reasonable example is for a command that turns soft limits on and off: the feedback would be if soft limits is on or off. The feedback target offers a way to do a simple forwarding of the user command state if desired.

edit_user_command.png

One option for user commands are User Scripts. These are lua functions that will be executed as the command, to get the feedback state, or to forward to the target. This is a way to create completely custom functionality. They should always be done in the UserGUIModule.UserStartUpScript function. The following is an example of how to create these lua function in the UserGUIModule.

function UserGUIModule.UserStartUpScript()
  local action_func = function()
          local state = w.GetSignalState(mc.OSIG_OUTPUT0)
          w.SetSignalState(mc.OSIG_OUTPUT0, not state)
      end
  w.CreateUserCommandActionOption("Toggle Output #0", action_func)

  local feedback_func = function()
          return w.GetSignalState(mc.OSIG_OUTPUT0)
      end
  w.CreateUserCommandFeedbackOption("Output #0", feedback_func)
  
  return true, true, w.FunctionCompleted()
end

Function Buttons

The MachPro operator panels and wireless pendants have a number of function buttons on them, labelled F1, F2, etc. These buttons initially do nothing, but can have commands or user commands mapped to them. This is done through the MachMotion operator panel configuration.

Each function button on the operator panels and pendants can have a command mapped to their press action and release action. First select the function button to be configured, and then select which press and release functions are desired. Selecting the blank entry will clear the command from the button.

Upon saving and exiting configuration, these commands will be mapped to the function buttons.

assign_user_command.png

Function buttons on the MachPro operator panels have an LED light in the corner. This light will reflect the feedback state of the mapped command. If a command is mapped to the press and to the release function of the button, the LED will reflect the feedback of the press command.

On the screen, there are five function buttons underneath the axis DROs. Instructions on how to configure those buttons, as well as how to add more function buttons to the screen, are in the Dashboard section.

Dashboard

dashboard_config.pngThe MachPro controls have multiple places to customize the interface to meet the users needs. The operator panel has function buttons that can be assigned operations, and there are two dashboards on the screen for the user to place widgets that they want to see. One dashboard is on the far right of the control and is available from all views. The other dashboard available to customize is on the service page.

Dashboards can be configured by right-clicking on them to access their menu. The user can choose how many and which widgets to show on the dashboard, as well as their layout. There is a wide variety of widgets to select from, and some widgets have additional options within them accessible through the 'Configure Widget' menu option.

One particular widget is the 'Function Buttons' widget. It is configurable in a similar way to the overall dashboard, but instead of selecting widgets, the user can select Commands to run on press and release. The user can also set the labels and colors of the button to suit them.

function_buttons.png

Aside from running Commands, function buttons can be configured to run an MDI command instead. Setting the MDI command to run, either press or release, is accessible through the right-click menu. Those menu options will only be available if the button does not have a Command set for it already. To create a multiline MDI command add a "\n" between the MDI lines.

For example, to run this command:

M6 T1

M3 S1000

You must program it like this: "M6 T1 \n M3 S1000". 

Function button list

image.png

image.png

image.png

image.png

Usually we only configure the button press, but we can also configure the button release function. Functions that toggle have a similar effect to the press and release functions. 

Most controls have at least three dashboards on the screen, the first one is under the Axis Positions (Labeled '1' in the example below) referred to as the Axis Positions Dashboard, and the second on the right side of the screen referred to as the Side Bar Dashboard (Labeled '2' in the example below).  The third dashboard is on the Service page.

Dashboards.PNG

Axis Positions Dashboard

The Axis Position Dashboard is locked to only allow the Function Button widget with 5 configurable buttons. These buttons configurable in the same manner as the function button widget on the Side Bar Dashboard, through the right-click menu. 

Side Bar Dashboard

On the right side of the screen is a large Dashboard with lots of space to add Widgets that will improve productivity.  Configure the dashboard through the right-click menu.

Widgets

Widgets are small components that can be added to the dashboards to show data like the last probe position or to add buttons for controlling a chip conveyor.  To see the list of available widgets right-click on the edge of a dashboard and select the drop down list.

Many widgets have additional options to configure the way they look or which variables are shown in the widget.  So see a list of options right-click inside the widget and select from the menu. The menu is context sensitive and some widgets have additional options, but these three options are always available. 

If "Set Variable Format String" is an option, right-click on the row you want to change and select "Set Variable Format String." Then enter a string format with the following syntax: %.Xf (where the X represents how many decimal places. For example, if you only want 1 decimal place, enter %.1f. This will display a value 170.2353 as 170.2. You have to re-enter the value on the screen for it to display with the new format. Search for external documentation on operator (c-style string formatting) syntax for a complete list of options. 

Right click directly on an entry.q9qimage.png

Use compact display or specify height of the rows. The default is 22.

rXNimage.png

 

Select Get Info about the entry you right clicked

Iyjimage.png

image.png

image.png

All Inputs and All Outputs

These are two separate widgets, one for inputs and one for outputs. They have the same function. They may be useful for troubleshooting during installation, and it will display all the inputs or outputs (including ones not enabled or used) in a scroll-able window. Alternately, to just see particular I/O information, use these widgets: 

If you add a description to an input in the Controls Inputs tab, that description will be used here.

image.png

Note the scrollbar on the right side. All inputs are visible when you scroll. 

If you right click and select Run Test Sequence, you will see this popup. There are a large number of inputs and running the sequence 10 times will take some time. 

image.png

Analog Input and Output Signals

These are two separate widgets and each allows you to add specific input and output signals to your dashboard. 

To add Analog signals, right click in the widget and select Add Variables. 

image.png

  • You can add an individual signal by selecting it, clicking the Add button at the bottom, and then the Close button. 
  • You can add a contiguous series of signals. Select the first signal. Hold down the shift key on the keyboard and select the last signal in the series. Click the Add button. 
  • You can repeat this action for other series of signals, and click Add after each series is selected.
  • You can add separate signals. Select the first signal. Hold down the control key on the keyboard and select each individual signal that you want to add to the widget. Click the Add button.
  • When you have finished adding all of the signals, click the close button. 

Right click in the widget or directly on one of the signals.

 

image.png

  • Using the process to the left, you can add additional variables.
  • You can also remove all variables, or only the variable that you right clicked on. 
  • You can get more detailed information about the particular variable you right clicked on. 

*Approach Distances

All axes will use this value when doing a probe move for both edges and corners. It is the maximum distance the probe will move while searching for material. If the probe is not activated before this distance is consumed, then an error will occur and the operation will be stopped.

image.png

The Approach Distances feature is used on the fixtures tab with edge finding. 

*Axis Compensation

image.png

This is used on grinders to adjust for the grind wheel size changing during dressing or grind cycles. Grinder controls will have these functions configured in their profile, and you will not normally need to add this widget.

Calculator

image.png

This is a simple calculator that is useful if you often need one while working on the control. There are no special features to configure here. If you need a calculator with more advanced features, the Windows calculator is available. 

Current Fixture Offsets

This displays the current offset of each axis from the machine zero location on that axis. It is the same as the opening the Fixtures Offsets table on the Fixtures tab. This is a display widget. If you want to change these values, open the Fixture Offsets table on the fixtures tab.

image.png

image.png

*Cylindrical Grinder Part Offsets

The part offset table (Part Correction Offset) which, when multiple features are being ground on the part, can be used in conjunction with an "E" variable in the program to allow adjustments to each feature individually. This widget is normally part of the grinder profile and should not need to be manually added. 

image.png

DRO Measure

image.png

This provides a digital "tape measure" that can measure axis movement, and be reset at will. It does not change any operating values or parameters.

Dual Table

image.png

This widget is used on routers with two tables. Setup and use is documented in the 2000 Series Dual Table article. 

Enabled Inputs and Outputs

image.png

These widgets will show only the inputs or outputs that been enabled. Right clicking on the display will bring up a menu. If you click on a particular input or output, you can get information about that entry. 

Feedback

 

image.png

 

This provides an on-screen indicator when any of the axes are moving. 

image.png

Right click on the border space around the buttons and select Configure Widget to access the display options. 

 

The Grid Configuration you select determines how many rows and columns of axis indicators you will have. 

*File Travel Limits

image.png

This displays the extents of movement you will have on each axis for the file that is loaded. Using this along with the yellow soft limit display on the tool path will help you identify fixture problems before you run a file. 

*G30 Coordinates

image.png

This is similar to the G28 command. G28 ends at machine zero while G30 allows you to specify a different end coordinates than machine zero. 

G54 - G59 fixture Offsets

This widget displays the current values of your offsets. These coordinates are always the distances from machine zero on each axis. You may add a widget for each set of offsets that you want to monitor. This is a display widget. If you want to change these values, open the Fixture Offsets table on the fixtures tab. If you want a single widget that dynamically updates to show the current offsets, use the Current Fixture Offsets (above). 

Standard display

image.png

Compact Display with Y offset labels customized

image.png

*G92/G50 Offsets

G92 fixture offset shift 

G52 fixture offset shift

Use G54–G59 fixture offsets or GOTO positions instead of G92 and G50/G52, which were used before fixture offsets existed. Try these features first. You may also use the Head Shift Offset and Work Shift Offset widgets to make adjustments directly on the screen - without any G-Code changes. 

The widget will display any offsets created with G92 or G52 in your G-Code.

 

image.png

You may also change the labels of the offsets to match your naming convention.

image.png

Head Shift Offsets

Head Shift and Work Shift offsets are very similar. Head shift is typically used for permanent offsets related to multiple heads - such as a router with a standard spindle, and a drill bank, or an engraving laser. You need to shift your your cut path to use the other tool while maintaining the same fixture coordinates. 

The values entered in the on-screen widget update the fixture table. 

image.png

image.png

The head shift values will reset to zero when you restart the software. If you want to set permanent values in the head shifts, you can change that option in the MachMotion Plugin. You can restore the last value you entered, or you can enter a permanent value to be restored each time the software starts. 

image.png

Head shift values will not change the standard G54-G59 work offsets, but they do stack on top of those values. You can also have both head shift and work shift values in effect at the same time. The head and work shift values will apply to your current work offsets. 

I/O

This shows the status for most of the system, but it is not intended for changing values. It is primarily used for system customization.

These examples show how the I/O indicators change when the Goto and MDI features are used. Many more in-depth optionsThere are available,sub-menus under each category, and all of the current optionsthey are shown below.

image.png

image.png

image.png

image.png

image.png

image.png

image.png

image.png

image.png

image.png

image.png

image.png

image.png

IVIS

This is the interface for a software tool used on some grinders. If your system uses IVIS, we will configure this widget for you. 

Job File

This widget is used in custom profiles. Please contact MachMotion for configuration. 

Jogging

This widget provides both on-screen and keyboard jogging. There are different on-screen axis button configurations to better match your system.

 

image.png

 

 

image.png

 

image.png

image.png

image.png

Lite is used to select the axis on computers that have + and - jog buttons on the panel.

image.png

  • CONT is continuous movement as long as you press the relevant axis button. 
  • STEP moves the axis by one increment with each press of the axis button. 
  • KYB uses keyboard mappings to control different aspects of the jogging function. Select the functions you want to use in the Jogger Configuration window, then map the key combinations in the Keyboard Inputs plugin. 
  • INC cycles through the jogging distance increments: 0.0001, 0.001, 0.01, 0.1, 1.0

The Jogger Configuration option to link to the physical jogger, allows you to keep the feedrate value synced with other physical pendants. 

This is the feedrate slider 

image.png

 

image.png

 

NDUimage.png

Last Commanded Coordinates

image.png

This reports the last position that each axis has been commanded, either by the G-Code file or by MDI. 

G0 X1 Y1 Z1
G0 X2 Y2

These G-Codes above resulted in this display. If an axis is not commanded for multiple blocks of code, it will retain the last commanded coordinate. 

Mach Parameters

These are the values stored in profile\parameters.ini and are best accessed in the MachMotion Plugin. Pull down the Configure menu | Plugins -> MachMotion parameters. Normally you will not need to monitor or change these values. This widget is primarily used for system customization. 

image.png

 

image.png

 

image.png

Right-click in the widget to bring up the menu. This menu is specific to #5130 because I right-clicked that entry. 

To add variables, select Configure Widget, fill in the parameters you want displayed, and click Add. You may do this repeatedly. The Add window only closes when you click Close. 

Using the right-click menu you may remove individual variables, or all of them. 

Machine Coordinates

These are the distances from the machine zero on each axis. You can toggle the DRO to show View Machine, and you can use this widget to display machine values at all times. See also Part Coordinates.

image.png

image.png

Notepad

This is a simple notepad that retains the text even when the control is fully power cycled. Right-clicking will display the options.

image.png

Original Offsets

Please refer to, and use, the Current Fixture Offset widget

Pound Variables

The system variables, or pound variables (# variables) are documented in the Macro B Reference Guide in the System Variables section. They are shared memory between G-Code files, and M-Codes and plugins. 

From the Macro B section 3.6 System Variables

 

image.png

Setting the widget values

image.png

image.png

Part Counters

This widget is incorporated into the standard interface, on the GCode tab, and it is best used there.

image.png

 

image.png

 

Part Counters (internal documentation)

Probe Machine Coordinates and Part Coordinates

image.png

image.png

Registers

 

Signals

 


Part Coordinates

Work Shift Offsets

Work Shifts and Head Shifts are very similar. Read the Head Shift documentation as both type of offsets are configured and modified the same way. 

Work shifts are typically used for temporary changes. Your stock may have a defect and you need to shift your fixture coordinates by 0.005 inches for this piece. This widget provides an easy way to make those kind of temporary adjustments quickly, without changing your existing fixture offsets. When you are done with this piece you can reset the work offsets to 0.0000 and use unmodified fixture offsets. 

Widget Customization

Lets test and customize the Pound Variable widget to learn more about its features.  First right click on the Side Bar Dashboard and select the Pound 

Pound Variables 

In this example we are going to add variables to the Pound Variables widget. Right click with your mouse inside the Pound Variables widget and select Configure Widget.

Poundvar-Widget.PNG

Now from this window we can enter the range of variables we want to view and the press Add.  I entered 500-510.

Poundvar-Widget-Configure.PNG

Now we have the widget showing the values from the variables. 

Poundvar-Widget-Displaying-500-510.PNG

Next lets rename one of the variables with a name to make it easier to remember. Right-click on the row labeled #501 and select Set Description: #501.

Poundvar-Widget-Renaming-501.PNG

Enter the name Part Width and press OK.

Poundvar-Widget-Part-Width.PNG

Now we have a widget customized with a description for variable #501.

Poundvar-Widget-Finsished.PNG

You can also set how many decimal places for pound variables. Again, right-click on the row you want to change and select "Set Variable Format String." Then enter a string format with the following syntax: %.Xf (where the X represents how many decimal places. For example, if you only want 1 decimal place, enter %.1f. This will display a value 170.2353 as 170.2. You have to re-enter the value on the screen for it to display with the new format.