Runtime

Important

As the functions and types below allow to interact with the CloudCompare app, they are only available in the python embedded within the plugin and not available when using standalone pycc module.

pycc.GetInstance() object

This function returns an object that allows to interact with the running CC instance to get access to already loaded PointCloud and Meshes.

Warning

on command line mode, the object returned will be of type pycc.ccCommandLineInterface.

on gui mode, the object returned will be of type pycc.ccPythonInstance

pycc.GetCmdLineInstance() pycc_runtime.ccCommandLineInterface

Returns the pycc.ccCommandLineInterface object if the script is ran from the command line mode, otherwise returns None.

pycc.GetGUIInstance() pycc_runtime.ccPythonInstance

Returns the pycc.ccPythonInstance object if the script is ran from the command line mode, otherwise returns None.

pycc.InitQApplication() None

Some functions and plugins always need to display GUI dialogs, thus they require an active QApplication. While this is not a problem when in plugin mode as CloudCompare is the QApplication, in stand alone mode it is a problem since CloudCompare is not running.

This function setups a QApplication so that dialogs can be displayed. Does nothing in plugin mode.

class pycc.PythonPluginInterface

The base class for Python plugins.

Every plugin must inherit from this.

import pycc

class MyPlugin(pycc.PythonPluginInterface):
     def __init__(self):
        super().__init__()
getActions(self: pycc_runtime.PythonPluginInterface) std::vector<Runtime::RegisteredPlugin::Action, std::allocator<Runtime::RegisteredPlugin::Action> >

Important

This method. must be implemented

The method shall return the list of actions the plugin can perform. Actions will get added to the context menu of the plugin.

The returned actions must be of type pycc.Action.

getIcon(self: pycc_runtime.PythonPluginInterface) object

It is not mandatory to implement this method.

When implemented, it shall return the icon that shall be used for the plugin sub menu.

see pycc.Action.

class pycc.Action

Represent an action of a plugin.

Parameters:
  • name (str) – The name of the action

  • target – method of the plugin that performs the action

  • icon (optional, either bytes, or tuple[bytes, str] or str default to None) –

    Icon of the action. - If the type is bytes, then they shall the bytes of the icon itself. - If the types is Tuple[bytes, str], then bytes shall be the bytes of the icon

    itself and str the format, e.g. (some_bytes, “PNG”)

    • If str then it shall be the path to a file.

pycc.RunInThread(callable: object, *args, **kwargs) object

Runs the function in a different thread to keep the UI responsive and returns the result of the function when the thread is done.

Example:

import time

def expensive_sum(a, b):
    time.sleep(10)
    return a + b

# if we ran expensive_sum directly, CloudCompare would
# become unresponsive for 10 seconds
result = pycc.RunInThread(expensive_sum, 1, 2)
assert result == 3

ccPythonInstance

class pycc.ccPythonInstance

Class to interact with the running GUI of CloudCompare.

The methods allow you to get/add objects to GUI DB Tree. Refresh/freeze/update the UI and display. Get selected objects, deselect/set selected state for entities…

addToDB(self: pycc_runtime.ccPythonInstance, obj: object, updateZoom: bool = False, autoExpandDBTree: bool = True, checkDimensions: bool = False, autoRedraw: bool = True) None

Adds the object to the GUI DB Tree

app(self: pycc_runtime.ccPythonInstance) pycc_runtime.ccMainAppInterface
dbRootObject(self: pycc_runtime.ccPythonInstance) pycc.ccHObject

Returns the root of the GUI DB Tree

disableAll(self: pycc_runtime.ccPythonInstance) None
enableAll(self: pycc_runtime.ccPythonInstance) None
freezeUI(self: pycc_runtime.ccPythonInstance, state: bool) None
getActiveGLWindow(self: pycc_runtime.ccPythonInstance) pycc.ccGLWindowInterface
getMainWindow(self: pycc_runtime.ccPythonInstance) pycc.QMainWindow
getSelectedEntities(self: pycc_runtime.ccPythonInstance) list[pycc.ccHObject]

Returns the list of selected entities in the GUI DB Tree

haveOneSelection(self: pycc_runtime.ccPythonInstance) bool

Returns True if exactly one entity is selected in the GUI DB Tree

haveSelection(self: pycc_runtime.ccPythonInstance) bool

Returns true if at least one entity is selected in the GUI DB Tree

loadFile(self: pycc_runtime.ccPythonInstance, filepath: str, loadParameters: pycc.FileIOFilter.LoadParameters) pycc.ccHObject

Loads the file located at the filepath.

Adds the file content of the file into the DBTree and then returns loaded object handle.

raises RuntimeError in case of error

pickingHub(self: pycc_runtime.ccPythonInstance) pycc_runtime.ccPickingHub

Returns the picking hub

redrawAll(self: pycc_runtime.ccPythonInstance, only2D: bool = False) None
refreshAll(self: pycc_runtime.ccPythonInstance, only2D: bool = False) None
removeFromDB(self: pycc_runtime.ccPythonInstance, entity: object) None
setSelectedInDB(self: pycc_runtime.ccPythonInstance, obj: pycc.ccHObject, selected: bool) None

Set the selection state of the object in the GUI DB Tree

updateUI(self: pycc_runtime.ccPythonInstance) None

ccCommandLineInterface

class pycc.ccCommandLineInterface
class ExportOption

Members:

property name
property value
class GlobalShiftOptions
class Mode

Members:

NO_GLOBAL_SHIFT

AUTO_GLOBAL_SHIFT

FIRST_GLOBAL_SHIFT

CUSTOM_GLOBAL_SHIFT

AUTO_GLOBAL_SHIFT = <Mode.AUTO_GLOBAL_SHIFT: 1>
CUSTOM_GLOBAL_SHIFT = <Mode.CUSTOM_GLOBAL_SHIFT: 3>
FIRST_GLOBAL_SHIFT = <Mode.FIRST_GLOBAL_SHIFT: 2>
NO_GLOBAL_SHIFT = <Mode.NO_GLOBAL_SHIFT: 0>
property name
property value
AUTO_GLOBAL_SHIFT = <Mode.AUTO_GLOBAL_SHIFT: 1>
CUSTOM_GLOBAL_SHIFT = <Mode.CUSTOM_GLOBAL_SHIFT: 3>
FIRST_GLOBAL_SHIFT = <Mode.FIRST_GLOBAL_SHIFT: 2>
NO_GLOBAL_SHIFT = <Mode.NO_GLOBAL_SHIFT: 0>
property customGlobalShift
property mode
clouds(self: pycc_runtime.ccCommandLineInterface) pycc_runtime.CLCloudDescVector
exportEntity(self: pycc_runtime.ccCommandLineInterface, entityDesc: pycc_runtime.CLEntityDesc, suffix: QString = '', outputFilename: QString = None, options: QFlags<ccCommandLineInterface::ExportOption> = <ExportOption.???: 0>) QString
getExportFilename(self: pycc_runtime.ccCommandLineInterface, entityDesc: pycc_runtime.CLEntityDesc, extension: QString = '', suffix: QString = '', baseOutputFilename: QString = None, forceNoTimestamp: bool = False) QString
importFile(self: pycc_runtime.ccCommandLineInterface, filename: QString, opts: pycc_runtime.ccCommandLineInterface.GlobalShiftOptions) bool
meshes(self: pycc_runtime.ccCommandLineInterface) pycc_runtime.CLMeshDescVector
saveCloud(self: pycc_runtime.ccCommandLineInterface, suffix: QString = '', allAtOnce: bool = False, allAtOnceFileName: QString = None) bool
saveMeshes(self: pycc_runtime.ccCommandLineInterface, suffix: QString = '', allAtOnce: bool = False, allAtOnceFileName: QString = None) bool

ccPickingHub

class pycc.ccPickingHub

Point/triangle picking hub

activeWindow(self: pycc_runtime.ccPickingHub) pycc.ccGLWindowInterface

Returns the currently active window

addListener(self: pycc_runtime.ccPickingHub, listener: object, exclusive: bool = False, autoStartPicking: bool = True, mode: pycc.ccGLWindowInterface.PICKING_MODE = <PICKING_MODE.POINT_OR_TRIANGLE_PICKING: 6>) None

Adds a listener

Parameters:
  • listener (listener to be registered) –

  • exclusive (prevents new listeners from registering) –

  • autoStartPicking (automatically enables the picking mode on the active window (if any)) –

  • mode (sets the picking mode (warning: may be rejected if another listener is currently registered with another mode)) –

Raises:

RuntimeError – if failed to add listener:

isLocked(self: pycc_runtime.ccPickingHub) bool

Returns whether the picking hub is locked (i.e. an exclusive listener is registered)

listenerCount(self: pycc_runtime.ccPickingHub) int

Returns the number of currently registered listeners

removeListener(self: pycc_runtime.ccPickingHub, listener: object, autoStopPickingIfLast: bool = True) None

Removes a listener

listener: listener to be removed autoStopPickingIfLast: automatically disables the picking mode on the active window (if any) if no other listener is registered

togglePickingMode(self: pycc_runtime.ccPickingHub, state: bool) None

Manual start / stop of the picking mode on the active window

ccPickingListener

class pycc.ccPickingListener

Point/triangle picking listener interface

import pycc

class PickingListener(pycc.ccPickingListener):
    def __init__(self):
        super().__init__()
class PickedItem
property P3D

Picked point in 3D (if any)

property clickPoint

Position of the user click

property entity

Picked entity (if any)

property entityCenter

The point doesn’t correspond to a real ‘item’ but to the entity center

property itemIndex

e.g. point or triangle index

property uvw

Picked point barycentric coordinates (if picked on a triangle)

onItemPicked(self: pycc_runtime.ccPickingListener, pi: ccPickingListener::PickedItem) None

Method called whenever an item is picked