Skip to main content

A library designed for quickly deploying a 3D viewer.

Reason this release was yanked:

use 1.1.4

Project description

q3dviewer

q3dviewer is a library designed for quickly deploying a 3D viewer. It is based on Qt (PySide6) and provides efficient OpenGL items for displaying 3D objects (e.g., point clouds, cameras, and 3D Gaussians). You can use it to visualize your 3D data or set up an efficient viewer application. It is inspired by PyQtGraph but focuses more on efficient 3D rendering.

Installation

To install q3dviewer, execute the following command in your terminal on either Linux or Windows:

pip install q3dviewer

Note for Windows Users

  • Ensure that you have a Python 3 environment set up:
    • Download and install Python 3 from the official Python website.
    • During installation, make sure to check the "Add Python to PATH" option.

Note for Linux Users

If you encounter an error related to loading the shared library libxcb-cursor.so.0 on Ubuntu 20.04 or 22.04, please install libxcb-cursor0:

sudo apt-get install libxcb-cursor0

Tools

Once installed, you can directly use the following tools:

1. Cloud Viewer

A tool for visualizing point cloud files. Launch it by executing the following command in your terminal:

cloud_viewer  # The viewer will be displayed

Alternatively, if the path is not set (though it's not recommended):

python3 -m q3dviewer.tools.cloud_viewer

After the viewer launches, you can drag and drop files onto the window to display the point clouds. Multiple files can be dropped simultaneously to view them together. Supported formats include LAS, PCD, PLY, and E57.

For example, you can download and view point clouds of Tokyo in LAS format from the following link:

Tokyo Point Clouds

Cloud Viewer Screenshot

Press M on your keyboard to display a menu on the screen, where you can modify visualization settings for each item. For example, you can adjust various settings such as shape, size, color, and transparency for CloudItem.

Cloud Viewer Settings

2. ROS Viewer

A high-performance SLAM viewer compatible with ROS, serving as an alternative to RVIZ.

roscore &
ros_viewer

3. Film Maker

Would you like to create a video from point cloud data? With Film Maker, you can easily create videos with simple operations. Just edit keyframes using the user-friendly GUI, and the software will automatically interpolate the keyframes to generate the video.

film_maker # drag and drop your cloud file to the window
  • Space key to add a keyframe.
  • Delete key to remove a keyframe.

Film Maker GUI:

Screenshot from 2025-02-02 18-20-51.png

4. Gaussian Viewer

A simple viewer for 3D Gaussians. See EasyGaussianSplatting for more information.

gaussian_viewer  # Drag and drop your Gaussian file onto the window

Gaussian Viewer GIF

5. LiDAR-LiDAR Calibration Tools

A tool to compute the relative pose between two LiDARs. It allows for both manual adjustment in the settings screen and automatic calibration.

lidar_calib --lidar0=/YOUR_LIDAR0_TOPIC --lidar1=/YOUR_LIDAR1_TOPIC

LiDAR Calibration

6. LiDAR-Camera Calibration Tools

A tool for calculating the relative pose between a LiDAR and a camera. It allows for manual adjustment in the settings screen and real-time verification of LiDAR point projection onto images.

lidar_cam_calib --lidar=/YOUR_LIDAR_TOPIC --camera=/YOUR_CAMERA_TOPIC --camera_info=/YOUR_CAMERA_INFO_TOPIC

LiDAR-Camera Calibration

Using as a Library

Using the examples above, you can easily customize and develop your own 3D viewer with q3dviewer. Below is a coding example.

Custom 3D Viewer

#!/usr/bin/env python3

import q3dviewer as q3d  # Import q3dviewer

def main():
    # Create a Qt application
    app = q3d.QApplication([])

    # Create various 3D items
    axis_item = q3d.AxisItem(size=0.5, width=5)
    grid_item = q3d.GridItem(size=10, spacing=1)

    # Create a viewer
    viewer = q3d.Viewer(name='example')

    # Add items to the viewer
    viewer.add_items({
        'grid': grid_item,
        'axis': axis_item,
    })

    # Show the viewer & run the Qt application
    viewer.show()
    app.exec()

if __name__ == '__main__':
    main()

q3dviewer provides the following 3D items:

  • AxisItem: Displays coordinate axes or the origin position.
  • CloudItem: Displays point clouds.
  • CloudIOItem: Displays point clouds with input/output capabilities.
  • GaussianItem: Displays 3D Gaussians.
  • GridItem: Displays grids.
  • ImageItem: Displays 2D images.
  • Text2DItem: Displays 2D text.
  • LineItem: Displays lines or trajectories.

Developing Custom Items

In addition to the standard 3D items provided, you can visualize custom 3D items with simple coding. Below is a sample:

from OpenGL.GL import *
import numpy as np
import q3dviewer as q3d
from PySide6.QtWidgets import QLabel, QSpinBox

class YourItem(q3d.BaseItem):
    def __init__(self):
        super(YourItem, self).__init__()
        # Necessary initialization

    def add_setting(self, layout):
        # Initialize the settings screen
        label = QLabel("Add your setting:")
        layout.addWidget(label)
        box = QSpinBox()
        layout.addWidget(box)

    def set_data(self, data):
        # Obtain the data you want to visualize
        pass

    def initialize_gl(self):
        # OpenGL initialization settings (if needed)
        pass

    def paint(self):
        # Visualize 3D objects using OpenGL
        pass

Enjoy using q3dviewer!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

q3dviewer-1.1.3.tar.gz (46.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

q3dviewer-1.1.3-py3-none-any.whl (70.1 kB view details)

Uploaded Python 3

File details

Details for the file q3dviewer-1.1.3.tar.gz.

File metadata

  • Download URL: q3dviewer-1.1.3.tar.gz
  • Upload date:
  • Size: 46.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.10

File hashes

Hashes for q3dviewer-1.1.3.tar.gz
Algorithm Hash digest
SHA256 b1b8437f7302fdd23e00b7395db6ff37df4f3576b75878ebac65bc991d66f03a
MD5 9ecd75cb14e92ab0f1a0278bf442868d
BLAKE2b-256 65908729f202b2d5dfac66c3343b4f6e8c3a2f4dfe08bdff49e63eb7aeaad3a0

See more details on using hashes here.

File details

Details for the file q3dviewer-1.1.3-py3-none-any.whl.

File metadata

  • Download URL: q3dviewer-1.1.3-py3-none-any.whl
  • Upload date:
  • Size: 70.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.10

File hashes

Hashes for q3dviewer-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 53c560d7af666d402b79ca89fce488c3f58012708c5d9a845dba9bfdaf39300a
MD5 788305fc7482918a1c1fc13515007c08
BLAKE2b-256 eb6c6b0a20a67c9aa76448ea69afadbdc3362f2fd56688859e5675dca8f2af35

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page