Radium Engine  1.5.0
Feature Picking

Usage

The RadiumEngine's Ra::Engine::Rendering::Renderer provides a picking method for Ra::Engine::Rendering::RenderObject selection.

The FeaturePicking feature enables to enhance the selection process up to selecting vertices, edges and triangles. The result of a Ra::Engine::Rendering::Renderer::PickingQuery is a Ra::Engine::Rendering::Renderer::PickingResult containing the following data:

Right after a selection, the Ra::Engine::Rendering::Renderer::PickingResult are stored in the Ra::Gui::PickingManager and the Ra::Gui::SelectionManager emits Ra::Gui::SelectionManager::currentChanged signal so that Plugins are told a new selection has been made.

The selection of a mesh feature is activated by holding a specific key while selecting the object (see the KeyMappingManager configuration file for those). Multiple selection activation can be activated/de-activated by pressing the corresponding key, which would also make a circle shape, representing the selection area, appear on the screen.

MeshFeatureTracking Plugin

The MeshFeatureTracking Plugin (Radium Official Plugins (https://gitlab.com/Storm-IRIT/radium-official-plugins)) is an example of how mesh features information can be displayed either through the Gui or as displayed objects. The SelectionManager's currentChanged signal is connected to the slot onCurrentChanged.

When this slot is triggered, the MeshFeatureTracking Plugin accesses the picking data through the PickingManager and updates both its information widget with the new picking data and the tracking sphere. The MeshFeatureTracking plugin also keeps its information widget updated at the end of each frame.

The MeshFeatureTracking plugin only manage simple feature selection. For an example on how to deal with multiple selection, please see the MeshPaint Plugin.

MeshPaint Plugin

The MeshPaint Plugin (Radium Official Plugins (https://gitlab.com/Storm-IRIT/radium-official-plugins)) is an example of how to use mesh feature multi-selection. Here again, the SelectionManager's currentChanged signal is connected to the slot onCurrentChanged.

When this slot is triggered, and if the painting is enabled, the MeshPaint Plugin directly changes the render color of the vertices corresponding to the current picking data.