The Blur Studio Simplex Blendshape Combination System
Project description
SIMPLEX UI
For Artitsts
Simplex aims to provide an intuitive, cross-package UI that allows for building, editing, and controlling complex shapes, combos, and transitions for use in high-end blendshape facial rigs, or even PSD systems.
This tool was built with the full Facial Action Coding System (FACS) in mind. As such, it easily handles hundreds of shapes with arbitrary combo depth. Spline interpolation for in-between shapes, positive-negative shapes, in-between combo shapes, and combo transitions are supported. Arbitrary value combinations are also fully supported (eg. ComboX activates when SliderA is at 0.25 and SliderB is at 0.33).
For TD's
Simplex aims to be fully scriptable so that it can easily be inserted into any pipeline. The UI and API are fully Python, all content creation commands are abstracted (for multi-package use), and all systems are built as human readable JSON strings.
There is a suite of tools included that allow for manipulating .smpx files. Most of which can be run completely outside of a DCC. This includes vertex reordering, un-subdividing, splitting, and even shape-inversion. These .smpx files are nothing more than specially structured alembic caches
As long as your package supports Plugins, Python, and Qt (or PySide), you can use Simplex.
Simplex is NOT
- Simplex is not a modeling toolkit
- Modeling is done using whatever tools you choose on your current package
- Simplex is not a deformer
- It only informs a native blendshape deformer what values the current shapes should have
- In the future, I do have ideas for building an interface to an advanced deformer for dynamically previewing arbitrary splits, but the final output will always have the ability to bake down to a basic blendshape.
Basic Usage
Follow this youtube link to a basic walkthrough of Simplex usage. This video highlights an older version of Simplex, but the interaction remains basically the same. https://www.youtube.com/watch?v=LQwzsxU8z_Q
INSTALLATION
- Download the latest release
- Copy the
modules
folder from the zip file into your maya directory. On windows, that would mean copying into%USERPROFILE%\Documents\maya
so that the module file sits at%USERPROFILE%\Documents\maya\modules\simplex.mod
- Install numpy for mayapy using pip. If you're using a Maya with Python 3, you should just be able to install numpy. For Python 2 on Windows, you'll have to find a .whl file compiled for your version. I'm not sure about Mac or Linux for Py2.
- Run these two Python commands in Maya to start the tool. (This is probably what you should put into a shelf button)
from simplexui import runSimplexUI
runSimplexUI()
Compiling
Hopefully you don't need to do this, but if you have to, just take a look at .github/workflows/main.yml
and you should be able to piece together how to get a compile working using CMake. You aren't required to download the devkit or set its path for CMake if you've got maya installed on your machine. Also note, I use features from CMake 3.16+ so I can target python 2 and 3 separately.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
Hashes for simplex_solver-3.0.13-cp37-abi3-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7e36105e27fe52a93be41bf0829c8e494aa3dc3c2cf08749d3eb7f48614400b0 |
|
MD5 | ccb1d124a4aafcef5f4727e560fd3313 |
|
BLAKE2b-256 | c46cf71c7990c1c477cddae8722bd47e40802745c99d857c0dc64ac81034697e |
Hashes for simplex_solver-3.0.13-cp37-abi3-manylinux_2_17_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e3c4bfa1d255a944fa52f68a51f05d6f74b4278e980df3e91214e4b003b4c633 |
|
MD5 | 3770ec304a7a04607c9571bd433c2b2a |
|
BLAKE2b-256 | 30b6c8b7ab36550cde080422e339bbb9b7fba8b02f9efbe546ec8ed8d174a704 |
Hashes for simplex_solver-3.0.13-cp37-abi3-macosx_10_9_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 749640d04b466846a41c8c780b77b763f4cd770441385e25679fb556556f8c9a |
|
MD5 | 9ac1b8b5f6874bf1dcb04d6d50bf1609 |
|
BLAKE2b-256 | 458b8030945c0923f7bf2352035efb50c5f171e21bdd21c2569661c0c21d0284 |