Skip to content

Latest commit

 

History

History
85 lines (55 loc) · 3.57 KB

File metadata and controls

85 lines (55 loc) · 3.57 KB

Python UI Extension Template

Overview

The Python UI Extension Template offers a simple starting point for developers looking to build Python-based extensions with performant User Interfaces. This template offers a best practices foundation and structure to easily integrate with the broader capabilities of the Omniverse Kit SDK.

Use Cases

This template is ideal for developers looking to build:

  • UI based extensions that can be easily integrated with Omniverse Kit SDK applications.

Key Features

  • A simple starter UI demonstrating how to build using the Omni UI framework.
  • Structure well suited for the build, test and packaging tooling within this repository.
  • All required setup code for use with the Omniverse Kit SDK.

Usage

This section provides instructions for the setup and use of the Python UI Extension Template.

Getting Started

To get started with the Python UI Extension, ensure your development environment meets the prerequisites outlined in the top-level README.

Cloning the Repository

git clone https://github.com/NVIDIA-Omniverse/kit-app-template.git
cd kit-app-template

Create New Extension

Linux:

./repo.sh template new

Windows:

.\repo.bat template new

Follow the prompt instructions:

  • ? Select with arrow keys what you want to create: Extension
  • ? Select with arrow keys your desired template:: Python UI Extension
  • ? Enter name of extension [name-spaced, lowercase, alphanumeric]:: [set extension name]
  • ? Enter extension_display_name:: [set extension display name]
  • ? Enter version:: [set extension version]

Build and Launch

While Python extensions typically do not require a build step in isolation, this template is structured to properly interact with the Omniverse Kit SDK application build and packaging tooling.

Launching the extension typically requires that they be a part of an Omniverse Service or Editor application.

Adding an Extension to an Application

To add your extension to an application, declare it in the dependencies section of the application's .kit file:

[dependencies]
"my_company.my_extension" = {}

Build with New Extensions

After a new extension has been added to the .kit file, the application should be rebuilt to ensure extensions are populated to the build directory.

Customization

Customization of a Python Extension might involve writing new Python modules, or integrating existing libraries.

As is the case with Applications, extensions can also depend on and be depended on by other extensions. These can be custom developed extensions or those provided by the NVIDIA managed extension registry. A view of available registry extensions can be found within the Extension Manager accessible via the developer bundle available when running ./repo.sh launch --dev-bundle(Linux) or .\repo.bat launch --dev-bundle(Windows) to launch the Base Editor or USD Explorer Application Templates (select Developer > Utilities > Extensions)

Additional Learning