• Stars
    star
    115
  • Rank 305,916 (Top 7 %)
  • Language
    Python
  • License
    GNU Lesser Genera...
  • Created about 10 years ago
  • Updated 3 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Pyblish QML frontend for Maya 2013+, Houdini 11+, Nuke 8+ and more

Pyblish QML

The Pyblish QML project provides a graphical frontend to Pyblish.

Build Status




Requirements

Pyblish QML works with..

  • Standalone
  • Maya 2013+
  • Nuke 8+
  • Houdini 11+
  • Blender 2.79-2.80+

..and requires an external Python (2 or 3) install with PyQt 5.6+ available.

Before use, point to your Python executable like this.

$ set PYBLISH_QML_PYTHON_EXECUTABLE=c:\python27\python.exe

This assumes the Python distribution has access to PyQt5 via e.g. python -c "import PyQt5". If not, you may point to the directory containing it like this.

$ set PYBLISH_QML_PYQT5=c:\path\to\pyqt



Installation

$ pip install pyblish-qml

Test out the installation with..

$ python -m pyblish_qml --demo



Usage

In any of the supported hosts, call show().

import pyblish_qml
pyblish_qml.show()

First you need to tell QML where Python and PyQt5 is.

from pyblish_qml import api, show

# Tell QML about dependencies
api.register_python_executable("C:/Python27/python.exe")
api.register_pyqt5("C:/modules/python-qt5")

show()

Alternatively, you may use environment variables instead.

$ set PYBLISH_QML_PYTHON_EXECUTABLE=c:\python27\python.exe
$ set PYBLISH_QML_PYQT5=c:\modules\python-qt5
$ maya  # for example..

Keep in mind that you don't have to register PyQt5 unless the Python executable you register isn't able to find it on its own. Also keep in mind that the directory you need to register is the parent directory of the PyQt5 Python package.

Either way, once QML is aware of where dependencies are, you may register it with pyblish-base and have it appear automatically in file-menus of software, like with pyblish-qml.

from pyblish import api
api.register_gui("pyblish_qml")

See pyblish-maya for an example.

Additional Environment Variables

  • PYBLISH_QML_MODAL=1 Block interactions to parent process, useful for headless publishing where you expect a process to remain alive for as long as QML is. Without this, Pyblish is at the mercy of the parent process, e.g. mayapy which quits at the first sign of EOF.



Documentation

Below is the current and full documentation of QML.


Supported Hosts

These are the hosts automatically recognised by pyblish-qml.

  • Maya
  • Nuke
  • Houdini
  • Hiero

Data

Some data within each Instance and Context are special to QML.

Member Applies to Behavior
publish Instance The on/off state of the toggle.
label Context/Instance Draw this instead of an instance's name
comment Context Display and edit comment in GUI

Perspective

Dive into any item to find a curated list of data related to a particular item.


Order

The order in which items are listed in the interface is a representation of how they are about to be processed. The top-most item processes first, and the bottom-most item processes last.

You can control the order by modifying the order attribute.


Optional

Plug-ins can be made optional by adding a particular attribute to your plug-ins.

class MyPlugin(...):
   optional = True

When a plug-in is optional, an artist may choose whether or not it should perform any processing.


Plug-in documentation

image

Provide your users with thorough information of what to expect of a plug-in.

Pyblish QML visualises documentation per-plugin, here are some best practices for writing it along with technical information about how the data is parsed before being displayed.

Purpose

The following are some guidelines to adhere to when writing documentation for your plug-in, but are in no way mandatory nor have any effect on the operation of Pyblish or Pyblish QML.

  1. Provide a general understanding of what the plug-in is doing.
  2. In case of a validator, propose general solutions and best-practices for how to avoid failing.
  3. Do not provide specific solutions; save those for Exception messages.

Behaviour

Documentation is taken from the __doc__ member of your plug-in class.

class MyValidator(...):
   """General description

   Longer description here.

   """

As per PEP08, the first line of the above docstring is treated as a summary of the below description and used in the GUI right after drawing the name of the plug-in.

image

The longer portion is then shown when expanded.

image

If a line should be too long to display in the GUI, the end of it is elided.

Parsing

Before showing the docstring, it is parsed. Parsing is currently very straightforward and operates on two rules.

  1. Remove all newlines
  2. Keep paragraphs

This happens so as to ensure that the maximum amount of space is used in the GUI and to get rid of the leading tabs present in any docstring.

Which means that this...

class MyValidator(...):
   """General description

   Longer description
   here.

   """

translates into..

General description

Longer description here.

Caveats

As a side-effect of the above two rules, you cannot make lists or other entries that depend on newlines.



Log messages

Provide users with information about what happens during the processing of a plug-in.

Logging uses the Python standard library logging module and is visualised graphically by its 5 levels of severity.

  1. Debug
  2. Info
  3. Warning
  4. Error
  5. Critical

Each produced via it's corresponding call to self.log within a plug-in.

class MyValidator(...):
    ...
    def process(...):
        self.log.debug("e=mc^2")
        self.log.info("Processing instance..")
        self.log.warning("Something may be wrong..")
        self.log.error("Something's *definitely* wrong!")
        self.log.critical("Call the president!")

Each level is then represented by its unique color, starting from Blue moving into Red.

Details

A log message may be short or span multiple lines. Only the first line is visualised unless an item is expanded. Once expanded, similar rules apply to parsing as the parsing of docstring (See Plug-in Documentation for more information.

  • Short version

image

  • Expanded version

image

Example

image



Exception messages

Provide users with specifics about why a plug-in failed.

Exception messages are logged when exceptions are raised by plug-ins and are designed for describing the exact resort to take when plug-ins fail.

Contrary to Plug-in Documentation, Exception Messages may get very specific about a problem, such as naming items in a host relevant to the error, or point to a particular portion of the documentation.

Behaviour

As with Log Messages, the first line of the message is shown by default, subsequent lines are hidden until expanded and follow the same formatting rules as Plug-in Documentation.

raise ValidationError("""This is a long message

And this will appear once expanded.

""")

Pro tip: It's considered good practice to include as much information as is needed here, this is where users are meant to go for specifics about what to do about a particular problem.

Example



Settings

Customise Context label and Window title.

from pyblish_qml import settings
settings.WindowTitle = "My Title"
settings.WindowSize = (430, 600)
settings.WindowPosition = (100, 100)
settings.ContextLabel = "The World"
settings.HiddenSections = ["Collect"]

Each setting is applied when the GUI is shown, which means you can change them any time before then, including between subsequent runs.

Alternatively, set context label during processing.

class CollectContextLabel(pyblish.api.ContextPlugin):
  order = pyblish.api.CollectorOrder

  def process(self, context):
    context.data["label"] = "The World"

The GUI will read the current label after having processed all collectors. Any change after Collection will not be visible in the GUI.




Differences to Pyblish Lite

Pyblish QML fills the same gap as Pyblish Lite, with a few notable differences.

Pros

  • Asynchronous operation - use the GUI during intense processing
  • Smoother visuals - animations galore
  • Inspect individual items - tens of instances, hundreds of plug-ins? no problem
  • Filter terminal via keyword search - thousands of log entries? no problem

Cons

  • Requires PyQt5 (and either Python 2 or 3)

Development wise, Pyblish QML is written in.. you guessed it, QML. Whereas Pyblish Lite is written using classic widgets. QML is a new graphical user interface language for OpenGL developed by the same group, Qt.




Testing

Tests are automatically run at each commit to GitHub via Travis-CI. You can run these tests locally via Docker too.

$ git clone https://github.com/pyblish/pyblish-qml.git
$ cd pyblish-qml
$ . build_docker.sh  # Only needed once
$ . test_docker.sh
# Doctest: pyblish_qml.models.Item ... ok
# Doctest: pyblish_qml.util.ItemList ... ok
# Reset works ... ok
# Publishing works ... ok
# ...
# util.chain works with lambdas ... ok
# 
# ----------------------------------------------------------------------
# Ran 20 tests in 1.430s
# 
# OK

If you don't have Docker available you can test with these commands, for both Python 2 and Python 3:

$ cd pyblish-qml
$ python -m nose --verbose --with-doctest --exe --exclude=vendor

More Repositories

1

pyblish-base

Pyblish base library - see https://github.com/pyblish/pyblish for details.
Python
127
star
2

pyblish

Test-driven content creation, visit http://pyblish.com for the full scoop.
Python
120
star
3

pyblish-maya

Pyblish for Maya
Python
66
star
4

pyblish-lite

A community-driven alternative to pyblish-qml
Python
50
star
5

pyblish-houdini

Sidefx Houdini integration of Pyblish
Python
18
star
6

pyblish-photoshop

Pyblish for Photoshop
Python
17
star
7

pyblish-starter

A basic asset creation pipeline - batteries included. http://pyblish.com/pyblish-starter
Python
17
star
8

pyblish-magenta

Magenta kit for Pyblish
Python
10
star
9

pyblish-ftrack

Pyblish for FTrack
Python
10
star
10

pyblish-nuke

Pyblish for Nuke
Python
9
star
11

pyblish-deadline

Pyblish for Deadline
Python
7
star
12

pyblish-blender

Pyblish for Blender
5
star
13

pyblish-event

An intranet frontend for real-time updates of Pyblish events
CSS
5
star
14

pyblish-napoleon

An asset framework for Pyblish
Mathematica
5
star
15

pyblish-3dsmax

Pyblish for 3ds Max
Python
4
star
16

pyblish-tray

The Pyblish Control Panel
QML
4
star
17

pyblish-aftereffects

Pyblish for After Effects
4
star
18

pyblish-by-example

A hands-on introduction to Pyblish using short example programs. http://learn.pyblish.com
CSS
4
star
19

developer-guide

A maintainers and feature developers guide to Pyblish - https://pyblish.gitbooks.io/developer-guide/content/
CSS
3
star
20

pyblish-win

Pyblish for Windows
Python
3
star
21

pyblish-unreal

Pyblish for Unreal Engine 4 & 5
C++
3
star
22

apidocs

Source for API documentation at http://api.pyblish.com
Sass
2
star
23

pyblish-hiero

Pyblish for Hiero
Python
2
star
24

pyblish-rpc

An RPC interface to Pyblish (DEPRECATED)
Python
2
star
25

pyblish.github.io

pyblish.com website
CSS
2
star
26

pyblish-clarisse

Pyblish for Isotropix Clarisse
Python
2
star
27

pyblish-standalone

Pyblish Standalone
Python
2
star
28

pyblish-royalrender

Pyblish for Royal Render
Python
2
star
29

pyblish-universe

The upcoming Pyblish website - http://pyblish.github.io/pyblish-universe
Python
1
star
30

pyblish-ci

Pyblish Continuous Integration Platform
Python
1
star
31

pyblish-shell

Pyblish binaries on-the-go
Python
1
star
32

pyblish-mindbender

Pyblish for Mindbender
Mathematica
1
star
33

pyblish-nukestudio

Pyblish for NukeStudio
Python
1
star
34

pyblish-modo

The Foundry Modo integration of Pyblish
Python
1
star
35

pyblish-krita

Pyblish for Krita
1
star