Update
This commit is contained in:
parent
64ae5c7c64
commit
d0fba2b340
BIN
SuperRiggingEditor使用文档.pdf
Normal file
BIN
SuperRiggingEditor使用文档.pdf
Normal file
Binary file not shown.
@ -1,4 +1,26 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
from . import *
|
from .api import build_meshes, build_rig
|
||||||
|
from .builder.config import Config, RigConfig
|
||||||
|
from .builder.maya.skin_weights import (
|
||||||
|
get_skin_weights_from_scene,
|
||||||
|
set_skin_weights_to_scene,
|
||||||
|
)
|
||||||
|
from .dnalib.dnalib import DNA
|
||||||
|
from .dnalib.layer import Layer
|
||||||
|
from .MetaFusion import show
|
||||||
|
from .version import __version__
|
||||||
|
|
||||||
|
__all__ = [
|
||||||
|
"DNA",
|
||||||
|
"build_rig",
|
||||||
|
"build_meshes",
|
||||||
|
"show",
|
||||||
|
"get_skin_weights_from_scene",
|
||||||
|
"set_skin_weights_to_scene",
|
||||||
|
"Config",
|
||||||
|
"RigConfig",
|
||||||
|
"Layer",
|
||||||
|
"__version__",
|
||||||
|
]
|
||||||
|
42
scripts/api.py
Normal file
42
scripts/api.py
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
from typing import Optional
|
||||||
|
|
||||||
|
from .builder.builder import Builder, BuildResult
|
||||||
|
from .builder.config import Config, RigConfig
|
||||||
|
from .builder.rig_builder import RigBuilder
|
||||||
|
from .dnalib.dnalib import DNA
|
||||||
|
|
||||||
|
|
||||||
|
def build_rig(dna: DNA, config: RigConfig) -> BuildResult:
|
||||||
|
"""
|
||||||
|
Used for assembling the rig with provided configuration.
|
||||||
|
|
||||||
|
@type config: DNA
|
||||||
|
@param config: Instance of DNA
|
||||||
|
|
||||||
|
@type config: Config
|
||||||
|
@param config: Instance of configuration
|
||||||
|
|
||||||
|
@rtype: BuildResult
|
||||||
|
@returns: The object representing result of build
|
||||||
|
"""
|
||||||
|
|
||||||
|
return RigBuilder(dna, config).build()
|
||||||
|
|
||||||
|
|
||||||
|
def build_meshes(dna: DNA, config: Optional[Config] = None) -> BuildResult:
|
||||||
|
"""
|
||||||
|
Starts the mesh building process with the provided configuration.
|
||||||
|
|
||||||
|
@type config: DNA
|
||||||
|
@param config: Instance of DNA
|
||||||
|
|
||||||
|
@type config: Config
|
||||||
|
@param config: Instance of configuration
|
||||||
|
|
||||||
|
@rtype: BuildResult
|
||||||
|
@returns: The object representing result of build
|
||||||
|
"""
|
||||||
|
if config is None:
|
||||||
|
config = Config()
|
||||||
|
|
||||||
|
return Builder(dna, config).build()
|
11
scripts/common.py
Normal file
11
scripts/common.py
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
ANALOG_GUI_HOLDER = "analog_gui"
|
||||||
|
|
||||||
|
GUI_HOLDER = "gui"
|
||||||
|
|
||||||
|
RIG_LOGIC_PREFIX = "rl4Embedded_"
|
||||||
|
|
||||||
|
SKIN_WEIGHT_PRINT_RANGE = 2000
|
||||||
|
|
||||||
|
|
||||||
|
class DNAViewerError(Exception):
|
||||||
|
pass
|
175
scripts/model.py
Normal file
175
scripts/model.py
Normal file
@ -0,0 +1,175 @@
|
|||||||
|
from dataclasses import dataclass, field
|
||||||
|
from typing import Dict, List
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class Point3:
|
||||||
|
"""
|
||||||
|
A model class for representing a 3 dimensional point
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type x: float
|
||||||
|
@param x: The value of x
|
||||||
|
|
||||||
|
@type y: float
|
||||||
|
@param y: The value of y
|
||||||
|
|
||||||
|
@type z: float
|
||||||
|
@param z: The value of z
|
||||||
|
"""
|
||||||
|
|
||||||
|
x: float = field(default=0.0)
|
||||||
|
y: float = field(default=0.0)
|
||||||
|
z: float = field(default=0.0)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class UV:
|
||||||
|
"""
|
||||||
|
A model class for holding data about the UV
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type u: float
|
||||||
|
@param u: The value of u
|
||||||
|
|
||||||
|
@type v: float
|
||||||
|
@param v: The value of v
|
||||||
|
"""
|
||||||
|
|
||||||
|
u: float = field(default=0.0)
|
||||||
|
v: float = field(default=0.0)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class Layout:
|
||||||
|
"""
|
||||||
|
A model class for holding data about a single layout
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type position_index: int
|
||||||
|
@param position_index: An index representing position
|
||||||
|
|
||||||
|
@type texture_coordinate_index: int
|
||||||
|
@param texture_coordinate_index: A value representing the texture coordinate index
|
||||||
|
"""
|
||||||
|
|
||||||
|
position_index: int = field(default=0)
|
||||||
|
texture_coordinate_index: int = field(default=0)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class Topology:
|
||||||
|
"""
|
||||||
|
A model class for holding data about the topology
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type positions: List[Point3]
|
||||||
|
@param positions: List of points in space representing the positions
|
||||||
|
|
||||||
|
@type texture_coordinates: List[UV]
|
||||||
|
@param texture_coordinates: List of UVs representing the positions
|
||||||
|
|
||||||
|
@type layouts: List[Layout]
|
||||||
|
@param layouts: The list of Layout mappings
|
||||||
|
|
||||||
|
@type face_vertex_layouts: List[List[int]]
|
||||||
|
@param face_vertex_layouts: List of face vertex layout indices by face index
|
||||||
|
"""
|
||||||
|
|
||||||
|
positions: List[Point3] = field(default_factory=list)
|
||||||
|
texture_coordinates: List[UV] = field(default_factory=list)
|
||||||
|
layouts: List[Layout] = field(default_factory=list)
|
||||||
|
face_vertex_layouts: List[List[int]] = field(default_factory=list)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class BlendShape:
|
||||||
|
"""
|
||||||
|
A model class for holding data about the blend shape
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type channel: int
|
||||||
|
@param channel: The index pointing to the blend shape name
|
||||||
|
|
||||||
|
@type deltas: Dict[int, Point3]
|
||||||
|
@param deltas: A mapping of blend shape indices to the coordinate differences that are made by the blend shape
|
||||||
|
"""
|
||||||
|
|
||||||
|
channel: int = field(default=None)
|
||||||
|
deltas: Dict[int, Point3] = field(default_factory=dict)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class SkinWeightsData:
|
||||||
|
"""
|
||||||
|
A model class for holding data about the skin weights
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
|
||||||
|
@type values: List[List[float]]
|
||||||
|
@param values: The skin weight values per vertex index
|
||||||
|
|
||||||
|
@type joint_indices: List[List[int]]
|
||||||
|
@param joint_indices: The joint indces per vertex index
|
||||||
|
"""
|
||||||
|
|
||||||
|
values: List[List[float]] = field(default_factory=list)
|
||||||
|
joint_indices: List[List[int]] = field(default_factory=list)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class Mesh:
|
||||||
|
"""
|
||||||
|
A model class for holding data about the mesh
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type name: str
|
||||||
|
@param name: The name of the mesh
|
||||||
|
|
||||||
|
@type topology: Topology
|
||||||
|
@param topology: Data containing the topology of the mesh
|
||||||
|
|
||||||
|
@type skin_weights: SkinWeightsData
|
||||||
|
@param skin_weights: Data representing skin weights
|
||||||
|
|
||||||
|
@type blend_shapes: List[BlendShape]
|
||||||
|
@param blend_shapes: The list of blend shapes for the mesh
|
||||||
|
"""
|
||||||
|
|
||||||
|
name: str = field(default=None)
|
||||||
|
topology: Topology = field(default_factory=Topology)
|
||||||
|
skin_weights: SkinWeightsData = field(default_factory=SkinWeightsData)
|
||||||
|
blend_shapes: List[BlendShape] = field(default_factory=list)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class Joint:
|
||||||
|
"""
|
||||||
|
A model class for holding data about a single joint
|
||||||
|
|
||||||
|
Attributes
|
||||||
|
----------
|
||||||
|
@type name: str
|
||||||
|
@param name: The name of the joint
|
||||||
|
|
||||||
|
@type translation: Point3
|
||||||
|
@param translation: A point in 3 dimensional space which represents the translation of the joint
|
||||||
|
|
||||||
|
@type orientation: Point3
|
||||||
|
@param orientation: A point in 3 dimensional space which represents the orientation of the joint
|
||||||
|
|
||||||
|
@type parent_name: str
|
||||||
|
@param parent_name: The name of the parent joint
|
||||||
|
"""
|
||||||
|
|
||||||
|
name: str = field(default=None)
|
||||||
|
translation: Point3 = field(default_factory=Point3)
|
||||||
|
orientation: Point3 = field(default_factory=Point3)
|
||||||
|
parent_name: str = field(default=None)
|
1
scripts/version.py
Normal file
1
scripts/version.py
Normal file
@ -0,0 +1 @@
|
|||||||
|
__version__ = "2.1.1"
|
Loading…
Reference in New Issue
Block a user