Edit in GitHubLog an issue

Creating a Python plugin

This step by step guide describes how to create a simple Python plugin that allows to export channels of a Texture Set with a specific export preset.

1 - Navigate to the plugins folder

To add a new Python plugin, a simple script file can be created into the plugin folder of Substance 3D Painter.

To access the python folder, navigate to:

PlatformVersionPath
Windows
7.2 or newer
C:\Users\username\Documents\Adobe\Adobe Substance 3D Painter
Legacy
C:\Users\username\Documents\Allegorithmic\Substance Painter
Mac
7.2 or newer
/Users/username/Documents/Adobe/Adobe Substance 3D Painter
Legacy
/Users/username/Documents/Allegorithmic/Substance Painter
Linux
7.2 or newer
/home/username/Documents/Adobe/Adobe Substance 3D Painter
Legacy
/home/username/Documents/Allegorithmic/Substance Painter

Note: The folder "plugins" is for Javascript plugins. Python plugins need to go under the "python/plugins" folder.

2 - Creating the new plugin file

At the root of the plugin folder, create a new text file and give it the name of custom_export.py.

3 - Script content

Open the empty script file into a text editor and paste the following code snippet. Take a look at the code comments for more details on its behavior.

Copied to your clipboard
import os
# Substance 3D Painter modules
import substance_painter.ui
import substance_painter.export
import substance_painter.project
import substance_painter.textureset
# PySide module to build custom UI
from PySide2 import QtWidgets
plugin_widgets = []
def export_textures() :
# Verify if a project is open before trying to export something
if not substance_painter.project.is_open() :
return
# Get the currently active layer stack (paintable)
stack = substance_painter.textureset.get_active_stack()
# Get the parent Texture Set of this layer stack
material = stack.material()
# Build Export Preset resource URL
# - Context: name of the library where the resource is located
# - Name: name of the resource (filename without extension or Substance graph path)
export_preset = substance_painter.resource.ResourceID(
context="starter_assets",
name="PBR Metallic Roughness" )
print( "Preset:" )
print( export_preset.url() )
# Setup the export settings
resolution = material.get_resolution()
# Setup the export path, in this case the textures
# will be put next to the spp project file on the disk
Path = substance_painter.project.file_path()
Path = os.path.dirname(Path) + "/"
# Build the configuration
config = {
"exportShaderParams" : False,
"exportPath" : Path,
"exportList" : [ { "rootPath" : str(stack) } ],
"exportPresets" : [ { "name" : "default", "maps" : [] } ],
"defaultExportPreset" : export_preset.url(),
"exportParameters" : [
{
"parameters" : { "paddingAlgorithm": "infinite" }
}
]
}
substance_painter.export.export_project_textures( config )
def start_plugin():
# Create a text widget for a menu
Action = QtWidgets.QAction("Custom Python Export",
triggered=export_textures)
# Add this widget to the existing File menu of the application
substance_painter.ui.add_action(
substance_painter.ui.ApplicationMenu.File,
Action )
# Store the widget for proper cleanup later when stopping the plugin
plugin_widgets.append(Action)
def close_plugin():
# Remove all widgets that have been added to the UI
for widget in plugin_widgets:
substance_painter.ui.delete_ui_element(widget)
plugin_widgets.clear()
if __name__ == "__main__":
start_plugin()

4 - Loading and enabling the plugin

Launch Substance 3D Painter to make the application discover the plugin.

Click on the Python menu and then click on the plugin name to enable it:

Enable plugin

Finally click on the File menu and select Custom Python Export to trigger the export function of the script:

Run plugin

  • Privacy
  • Terms of Use
  • Do not sell or share my personal information
  • AdChoices
Copyright © 2024 Adobe. All rights reserved.