Skip to content
Josh Blum edited this page Sep 6, 2014 · 23 revisions

PothosGui should be in your executable search path. Open up a terminal and type PothosGui and hit enter:

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_open_terminal.png

The following window should appear:

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_opened_gui.png

The block tree is a dockable widget that allows the user to browse through the available processing blocks. From the block tree, the user can view a selected block's documentation, and choose to insert the selected block into the graph editor. The block tree is a dock widget, and can be moved and re-positioned within the main window. If the block tree widget is not visible, make sure that "Block Tree" is checked under the view menu.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_block_tree_anatomy.png

To search the block tree for a given block, enter keywords into the search bar at the top of the block tree. In addition, hit the Ctrl+F key sequence at any time to make the block tree visible, and give focus to the search bar.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_block_tree_search.png

Mouse-over a block to view its associated documentation.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_block_tree_documentation.png

Use the mouse to drag and drop blocks from the block tree into the graph editor. In addition, a block can be added to the editor by double clicking the selection or by clicking the "Add Block" button.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_block_tree_dnd.png

To modify the parameters of a block, double click on the block or select the block and choose Edit -> Properties from the menu. The properties panel dialog will appear. Use this panel to change various parameters, and click "Commit" button when done editing.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_block_props.png

Connections describe a flow of data from a data provider (an output) to a data consumer (an input). A block has two types of data providers: output ports and a signal emitter. A block has two types of data consumers: input ports and a slot acceptor.

To create a stream connection, click on a output streaming port, then click on an input streaming port. The clicks must occur in that order. A connection will be created from the output port to the input port.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_stream_before.png https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_stream_after.png

To create a signals and slots connection, click on a block's signal emitter, then click on the main body of block. The clicks must occur in that order. A connection will be created from the signal to the slot.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_sigslots_before.png https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_sigslots_after.png

Next, the connection must be configured by selecting from a list of available signals and available slots. The new signals and slots connection will have the text "Empty" on it. Double click on the connection to open its configuration panel.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_sigslots_edit.png

The configuration panel allows users to connect individual signals and slots by name. Click on an available slot to select it, and then click on an available signal. A new connection between the selected signal and slot will appear in the list.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_sigslots_edit_connect.png

Click the "Commit" button to apply the changes.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_connection_sigslots_edit_commit.png

Some blocks have an associated widget which can be inserted into the graph editor.

Right click on the graph editor, or use the edit menu. The menu will have submenu called "Insert graph widgets...". This submenu contains a list of available graphical widgets which can be inserted into the editor. Select one of the available widgets from the list, and a new widget will appear in the editor.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_widget_blocks_menu.png

Graphical widgets can be moved around the editor and resized. Simply mouse over the widget and a size-grip will appear. The size grip can be used to move and resize the widget.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_widget_blocks_move.png

Topology designs can be split across multiple pages to better organize the design or when a design cannot fit within a single page. In addition, graphical widgets can be moved to a display-only page to create a top-level visualization and control interface.

To create a new graph page, select the Edit menu or right click on the editor to open a context menu. Choose the "Graph page options..." submenu and click on "Create a new graph page":

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_pages_menu.png

A dialog will appear asking the user to create a name for the new page. Enter a unique name for the new page:

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_pages_dialog.png

The new page will appear a new tab on the left side of the graph editor. Click on the tab to switch between graph editor pages:

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_pages_created.png

To move graph objects to another page, first select one or more graph objects. Then select the Edit menu or right click on the editor to open a context menu. Choose the "Move graph objects..." submenu and select one of the available pages:

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_pages_move.png

Breakers allow connections to traverse across graph pages. Input breakers connect with output ports and signal emitters. Output breakers connect with input ports and slot acceptors. Each breaker has an associated node name. All breakers with the same node name are considered tied-together.

To create a new breaker, select the Edit menu or right click on the editor to open a context menu. Choose the "Graph page options..." submenu and click on "Insert input/output breaker":

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_breakers_menu.png

A dialog will appear asking the user to create a node name for the new breaker:

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_breakers_dialog.png

Breakers follow the same basic rules for creating connections. Click on the data provider, then click on the data acceptor. A new connection will be created.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_breakers_connected.png https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_breakers_connected_p2.png

Click the activate button in the toolbar or choose "Activate topology" from the "Execute menu". The design will begin to run and flow data across the connections. To deactivate the topology, simply click the button again.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_activate.png

The host explorer is a dockable widget that allows the user to browse through the available remote hosts. From the host explorer, the user can add and remove available hosts, and view information about each host. The host explorer is a dock widget, and can be moved and re-positioned within the main window. If the host explorer widget is not visible, make sure that "Host Explorer" is checked under the view menu.

https://raw.githubusercontent.com/wiki/pothosware/pothos-gui/images/tutorial_host_explorer.png