class FabriceTailRig(FabriceTail): """Fabrice Tail Component""" def __init__(self, name="fabriceTail", parent=None): Profiler.getInstance().push("Construct Tail Rig Component:" + name) super(FabriceTailRig, self).__init__(name, parent) # ========= # Controls # ========= # Tail Base # self.tailBaseCtrlSpace = CtrlSpace('tailBase', parent=self.ctrlCmpGrp) # self.tailBaseCtrl = Control('tailBase', parent=self.tailBaseCtrlSpace, shape="circle") # self.tailBaseCtrl.rotatePoints(90, 0, 0) # self.tailBaseCtrl.scalePoints(Vec3(2.0, 2.0, 2.0)) # self.tailBaseCtrl.setColor("greenBlue") # Tail Base Handle self.tailBaseHandleCtrlSpace = CtrlSpace('tailBaseHandle', parent=self.ctrlCmpGrp) self.tailBaseHandleCtrl = Control('tailBaseHandle', parent=self.tailBaseHandleCtrlSpace, shape="pin") self.tailBaseHandleCtrl.lockScale(x=True, y=True, z=True) self.tailBaseHandleCtrl.setColor("turqoise") # Tail End Handle self.tailEndHandleCtrlSpace = CtrlSpace('tailEndHandle', parent=self.ctrlCmpGrp) self.tailEndHandleCtrl = Control('tailEndHandle', parent=self.tailEndHandleCtrlSpace, shape="pin") self.tailEndHandleCtrl.lockScale(x=True, y=True, z=True) self.tailEndHandleCtrl.setColor("turqoise") # Tail End self.tailEndCtrlSpace = CtrlSpace('tailEnd', parent=self.tailEndHandleCtrl) self.tailEndCtrl = Control('tailEnd', parent=self.tailEndCtrlSpace, shape="pin") self.tailEndCtrl.lockScale(x=True, y=True, z=True) self.tailEndCtrl.setColor("greenBlue") # ========== # Deformers # ========== deformersLayer = self.getOrCreateLayer('deformers') self.defCmpGrp = ComponentGroup(self.getName(), self, parent=deformersLayer) self.deformerJoints = [] self.tailOutputs = [] self.setNumDeformers(1) # ===================== # Create Component I/O # ===================== # Setup component Xfo I/O's self.tailVertebraeOutput.setTarget(self.tailOutputs) # ============== # Constrain I/O # ============== # Constraint inputs self.tailBaseHandleInputConstraint = PoseConstraint('_'.join([self.tailBaseHandleCtrlSpace.getName(), 'To', self.spineEndCtrlInputTgt.getName()])) self.tailBaseHandleInputConstraint.addConstrainer(self.spineEndCtrlInputTgt) self.tailBaseHandleInputConstraint.setMaintainOffset(True) self.tailBaseHandleCtrlSpace.addConstraint(self.tailBaseHandleInputConstraint) self.tailEndHandleInputConstraint = PoseConstraint('_'.join([self.tailEndHandleCtrlSpace.getName(), 'To', self.cogInputTgt.getName()])) self.tailEndHandleInputConstraint.addConstrainer(self.cogInputTgt) self.tailEndHandleInputConstraint.setMaintainOffset(True) self.tailEndHandleCtrlSpace.addConstraint(self.tailEndHandleInputConstraint) # Constraint outputs self.tailBaseOutputConstraint = PoseConstraint('_'.join([self.tailBaseOutputTgt.getName(), 'To', 'spineBase'])) self.tailBaseOutputConstraint.addConstrainer(self.tailOutputs[0]) self.tailBaseOutputTgt.addConstraint(self.tailBaseOutputConstraint) self.tailEndOutputConstraint = PoseConstraint('_'.join([self.tailEndOutputTgt.getName(), 'To', 'spineEnd'])) self.tailEndOutputConstraint.addConstrainer(self.tailOutputs[0]) self.tailEndOutputTgt.addConstraint(self.tailEndOutputConstraint) # =============== # Add Splice Ops # =============== # Add Tail Splice Op self.bezierTailKLOp = KLOperator('tailKLOp', 'BezierSpineSolver', 'Kraken') self.addOperator(self.bezierTailKLOp) # Add Att Inputs self.bezierTailKLOp.setInput('drawDebug', self.drawDebugInputAttr) self.bezierTailKLOp.setInput('rigScale', self.rigScaleInputAttr) self.bezierTailKLOp.setInput('length', self.lengthInputAttr) # Add Xfo Inputs self.bezierTailKLOp.setInput('base', self.spineEndInputTgt) self.bezierTailKLOp.setInput('baseHandle', self.tailBaseHandleCtrl) self.bezierTailKLOp.setInput('tipHandle', self.tailEndHandleCtrl) self.bezierTailKLOp.setInput('tip', self.tailEndCtrl) # Add Xfo Outputs self.bezierTailKLOp.setOutput('outputs', self.tailOutputs) # Add Deformer Splice Op self.deformersToOutputsKLOp = KLOperator('tailDeformerKLOp', 'MultiPoseConstraintSolver', 'Kraken') self.addOperator(self.deformersToOutputsKLOp) # Add Att Inputs self.deformersToOutputsKLOp.setInput('drawDebug', self.drawDebugInputAttr) self.deformersToOutputsKLOp.setInput('rigScale', self.rigScaleInputAttr) # Add Xfo Outputs self.deformersToOutputsKLOp.setInput('constrainers', self.tailOutputs) # Add Xfo Outputs self.deformersToOutputsKLOp.setOutput('constrainees', self.deformerJoints) Profiler.getInstance().pop() def setNumDeformers(self, numDeformers): # Add new deformers and outputs for i in xrange(len(self.tailOutputs), numDeformers): name = 'tail' + str(i + 1).zfill(2) tailOutput = ComponentOutput(name, parent=self.outputHrcGrp) self.tailOutputs.append(tailOutput) for i in xrange(len(self.deformerJoints), numDeformers): name = 'tail' + str(i + 1).zfill(2) tailDef = Joint(name, parent=self.defCmpGrp) tailDef.setComponent(self) self.deformerJoints.append(tailDef) return True def loadData(self, data=None): """Load a saved guide representation from persisted data. Arguments: data -- object, The JSON data object. Return: True if successful. """ super(FabriceTailRig, self).loadData( data ) tailBasePos = data['tailBasePos'] tailBaseHandlePos = data['tailBaseHandlePos'] tailBaseHandleCtrlCrvData = data['tailBaseHandleCtrlCrvData'] tailEndHandlePos = data['tailEndHandlePos'] tailEndHandleCtrlCrvData = data['tailEndHandleCtrlCrvData'] tailEndPos = data['tailEndPos'] tailEndCtrlCrvData = data['tailEndCtrlCrvData'] numDeformers = data['numDeformers'] # Set Xfos self.spineEndInputTgt.xfo.tr = tailBasePos self.spineEndCtrlInputTgt.xfo.tr = tailBasePos self.tailBaseHandleCtrlSpace.xfo.tr = tailBaseHandlePos self.tailBaseHandleCtrl.xfo.tr = tailBaseHandlePos self.tailBaseHandleCtrl.setCurveData(tailBaseHandleCtrlCrvData) self.tailEndHandleCtrlSpace.xfo.tr = tailEndHandlePos self.tailEndHandleCtrl.xfo.tr = tailEndHandlePos self.tailEndHandleCtrl.setCurveData(tailEndHandleCtrlCrvData) self.tailEndCtrlSpace.xfo.tr = tailEndPos self.tailEndCtrl.xfo.tr = tailEndPos self.tailEndCtrl.setCurveData(tailEndCtrlCrvData) length = tailBasePos.distanceTo(tailBaseHandlePos) + tailBaseHandlePos.distanceTo(tailEndHandlePos) + tailEndHandlePos.distanceTo(tailEndPos) self.lengthInputAttr.setMax(length * 3.0) self.lengthInputAttr.setValue(length) # Update number of deformers and outputs self.setNumDeformers(numDeformers) # Updating constraint to use the updated last output. self.tailEndOutputConstraint.setConstrainer(self.tailOutputs[-1], index=0) # ============ # Set IO Xfos # ============ # ==================== # Evaluate Splice Ops # ==================== # evaluate the spine op so that all the output transforms are updated. self.bezierTailKLOp.evaluate() # evaluate the constraint op so that all the joint transforms are updated. self.deformersToOutputsKLOp.evaluate() # evaluate the constraints to ensure the outputs are now in the correct location. self.tailBaseHandleInputConstraint.evaluate() self.tailBaseOutputConstraint.evaluate() self.tailEndOutputConstraint.evaluate()
class FabriceTailRig(FabriceTail): """Fabrice Tail Component""" def __init__(self, name="fabriceTail", parent=None): Profiler.getInstance().push("Construct Tail Rig Component:" + name) super(FabriceTailRig, self).__init__(name, parent) # ========= # Controls # ========= # Tail Base # self.tailBaseCtrlSpace = CtrlSpace('tailBase', parent=self.ctrlCmpGrp) # self.tailBaseCtrl = Control('tailBase', parent=self.tailBaseCtrlSpace, shape="circle") # self.tailBaseCtrl.rotatePoints(90, 0, 0) # self.tailBaseCtrl.scalePoints(Vec3(2.0, 2.0, 2.0)) # self.tailBaseCtrl.setColor("greenBlue") # Tail Base Handle self.tailBaseHandleCtrlSpace = CtrlSpace('tailBaseHandle', parent=self.ctrlCmpGrp) self.tailBaseHandleCtrl = Control('tailBaseHandle', parent=self.tailBaseHandleCtrlSpace, shape="pin") self.tailBaseHandleCtrl.lockScale(x=True, y=True, z=True) self.tailBaseHandleCtrl.setColor("turqoise") # Tail End Handle self.tailEndHandleCtrlSpace = CtrlSpace('tailEndHandle', parent=self.ctrlCmpGrp) self.tailEndHandleCtrl = Control('tailEndHandle', parent=self.tailEndHandleCtrlSpace, shape="pin") self.tailEndHandleCtrl.lockScale(x=True, y=True, z=True) self.tailEndHandleCtrl.setColor("turqoise") # Tail End self.tailEndCtrlSpace = CtrlSpace('tailEnd', parent=self.tailEndHandleCtrl) self.tailEndCtrl = Control('tailEnd', parent=self.tailEndCtrlSpace, shape="pin") self.tailEndCtrl.lockScale(x=True, y=True, z=True) self.tailEndCtrl.setColor("greenBlue") # ========== # Deformers # ========== deformersLayer = self.getOrCreateLayer('deformers') self.defCmpGrp = ComponentGroup(self.getName(), self, parent=deformersLayer) self.deformerJoints = [] self.tailOutputs = [] self.setNumDeformers(1) # ===================== # Create Component I/O # ===================== # Setup component Xfo I/O's self.tailVertebraeOutput.setTarget(self.tailOutputs) # ============== # Constrain I/O # ============== # Constraint inputs self.tailBaseHandleInputConstraint = PoseConstraint('_'.join([self.tailBaseHandleCtrlSpace.getName(), 'To', self.spineEndCtrlInputTgt.getName()])) self.tailBaseHandleInputConstraint.addConstrainer(self.spineEndCtrlInputTgt) self.tailBaseHandleInputConstraint.setMaintainOffset(True) self.tailBaseHandleCtrlSpace.addConstraint(self.tailBaseHandleInputConstraint) self.tailEndHandleInputConstraint = PoseConstraint('_'.join([self.tailEndHandleCtrlSpace.getName(), 'To', self.cogInputTgt.getName()])) self.tailEndHandleInputConstraint.addConstrainer(self.cogInputTgt) self.tailEndHandleInputConstraint.setMaintainOffset(True) self.tailEndHandleCtrlSpace.addConstraint(self.tailEndHandleInputConstraint) # Constraint outputs self.tailBaseOutputConstraint = PoseConstraint('_'.join([self.tailBaseOutputTgt.getName(), 'To', 'spineBase'])) self.tailBaseOutputConstraint.addConstrainer(self.tailOutputs[0]) self.tailBaseOutputTgt.addConstraint(self.tailBaseOutputConstraint) self.tailEndOutputConstraint = PoseConstraint('_'.join([self.tailEndOutputTgt.getName(), 'To', 'spineEnd'])) self.tailEndOutputConstraint.addConstrainer(self.tailOutputs[0]) self.tailEndOutputTgt.addConstraint(self.tailEndOutputConstraint) # =============== # Add Splice Ops # =============== # Add Tail Splice Op self.bezierTailSpliceOp = SpliceOperator('tailSpliceOp', 'BezierSpineSolver', 'Kraken') self.addOperator(self.bezierTailSpliceOp) # Add Att Inputs self.bezierTailSpliceOp.setInput('drawDebug', self.drawDebugInputAttr) self.bezierTailSpliceOp.setInput('rigScale', self.rigScaleInputAttr) self.bezierTailSpliceOp.setInput('length', self.lengthInputAttr) # Add Xfo Inputs self.bezierTailSpliceOp.setInput('base', self.spineEndInputTgt) self.bezierTailSpliceOp.setInput('baseHandle', self.tailBaseHandleCtrl) self.bezierTailSpliceOp.setInput('tipHandle', self.tailEndHandleCtrl) self.bezierTailSpliceOp.setInput('tip', self.tailEndCtrl) # Add Xfo Outputs self.bezierTailSpliceOp.setOutput('outputs', self.tailOutputs) # Add Deformer Splice Op self.deformersToOutputsSpliceOp = SpliceOperator('tailDeformerSpliceOp', 'MultiPoseConstraintSolver', 'Kraken', alwaysEval=True) self.addOperator(self.deformersToOutputsSpliceOp) # Add Att Inputs self.deformersToOutputsSpliceOp.setInput('drawDebug', self.drawDebugInputAttr) self.deformersToOutputsSpliceOp.setInput('rigScale', self.rigScaleInputAttr) # Add Xfo Outputs self.deformersToOutputsSpliceOp.setInput('constrainers', self.tailOutputs) # Add Xfo Outputs self.deformersToOutputsSpliceOp.setOutput('constrainees', self.deformerJoints) Profiler.getInstance().pop() def setNumDeformers(self, numDeformers): # Add new deformers and outputs for i in xrange(len(self.tailOutputs), numDeformers): name = 'tail' + str(i + 1).zfill(2) tailOutput = ComponentOutput(name, parent=self.outputHrcGrp) self.tailOutputs.append(tailOutput) for i in xrange(len(self.deformerJoints), numDeformers): name = 'tail' + str(i + 1).zfill(2) tailDef = Joint(name, parent=self.defCmpGrp) tailDef.setComponent(self) self.deformerJoints.append(tailDef) return True def loadData(self, data=None): """Load a saved guide representation from persisted data. Arguments: data -- object, The JSON data object. Return: True if successful. """ super(FabriceTailRig, self).loadData( data ) tailBasePos = data['tailBasePos'] tailBaseHandlePos = data['tailBaseHandlePos'] tailBaseHandleCtrlCrvData = data['tailBaseHandleCtrlCrvData'] tailEndHandlePos = data['tailEndHandlePos'] tailEndHandleCtrlCrvData = data['tailEndHandleCtrlCrvData'] tailEndPos = data['tailEndPos'] tailEndCtrlCrvData = data['tailEndCtrlCrvData'] numDeformers = data['numDeformers'] # Set Xfos self.spineEndInputTgt.xfo.tr = tailBasePos self.spineEndCtrlInputTgt.xfo.tr = tailBasePos self.tailBaseHandleCtrlSpace.xfo.tr = tailBaseHandlePos self.tailBaseHandleCtrl.xfo.tr = tailBaseHandlePos self.tailBaseHandleCtrl.setCurveData(tailBaseHandleCtrlCrvData) self.tailEndHandleCtrlSpace.xfo.tr = tailEndHandlePos self.tailEndHandleCtrl.xfo.tr = tailEndHandlePos self.tailEndHandleCtrl.setCurveData(tailEndHandleCtrlCrvData) self.tailEndCtrlSpace.xfo.tr = tailEndPos self.tailEndCtrl.xfo.tr = tailEndPos self.tailEndCtrl.setCurveData(tailEndCtrlCrvData) length = tailBasePos.distanceTo(tailBaseHandlePos) + tailBaseHandlePos.distanceTo(tailEndHandlePos) + tailEndHandlePos.distanceTo(tailEndPos) self.lengthInputAttr.setMax(length * 3.0) self.lengthInputAttr.setValue(length) # Update number of deformers and outputs self.setNumDeformers(numDeformers) # Updating constraint to use the updated last output. self.tailEndOutputConstraint.setConstrainer(self.tailOutputs[-1], index=0) # ============ # Set IO Xfos # ============ # ==================== # Evaluate Splice Ops # ==================== # evaluate the spine op so that all the output transforms are updated. self.bezierTailSpliceOp.evaluate() # evaluate the constraint op so that all the joint transforms are updated. self.deformersToOutputsSpliceOp.evaluate() # evaluate the constraints to ensure the outputs are now in the correct location. self.tailBaseHandleInputConstraint.evaluate() self.tailBaseOutputConstraint.evaluate() self.tailEndOutputConstraint.evaluate()
class SpineComponentRig(SpineComponent): """Spine Component""" def __init__(self, name="spine", parent=None): Profiler.getInstance().push("Construct Spine Rig Component:" + name) super(SpineComponentRig, self).__init__(name, parent) # ========= # Controls # ========= # COG self.cogCtrlSpace = CtrlSpace('cog', parent=self.ctrlCmpGrp) self.cogCtrl = Control('cog', parent=self.cogCtrlSpace, shape="circle") self.cogCtrl.scalePoints(Vec3(6.0, 6.0, 6.0)) self.cogCtrl.setColor("orange") # Spine01 self.spine01CtrlSpace = CtrlSpace('spine01', parent=self.cogCtrl) self.spine01Ctrl = Control('spine01', parent=self.spine01CtrlSpace, shape="circle") self.spine01Ctrl.scalePoints(Vec3(4.0, 4.0, 4.0)) # Spine02 self.spine02CtrlSpace = CtrlSpace('spine02', parent=self.spine01Ctrl) self.spine02Ctrl = Control('spine02', parent=self.spine02CtrlSpace, shape="circle") self.spine02Ctrl.scalePoints(Vec3(4.5, 4.5, 4.5)) # Spine03 self.spine03CtrlSpace = CtrlSpace('spine03', parent=self.spine02Ctrl) self.spine03Ctrl = Control('spine03', parent=self.spine03CtrlSpace, shape="circle") self.spine03Ctrl.scalePoints(Vec3(4.5, 4.5, 4.5)) self.spine03Ctrl.setColor("blue") # Spine04 self.spine04CtrlSpace = CtrlSpace('spine04', parent=self.cogCtrl) self.spine04Ctrl = Control('spine04', parent=self.spine04CtrlSpace, shape="circle") self.spine04Ctrl.scalePoints(Vec3(6.0, 6.0, 6.0)) # Pelvis self.pelvisCtrlSpace = CtrlSpace('pelvis', parent=self.cogCtrl) self.pelvisCtrl = Control('pelvis', parent=self.pelvisCtrlSpace, shape="cube") self.pelvisCtrl.alignOnYAxis(negative=True) self.pelvisCtrl.scalePoints(Vec3(2.0, 1.5, 1.5)) # ========== # Deformers # ========== deformersLayer = self.getOrCreateLayer('deformers') self.defCmpGrp = ComponentGroup(self.getName(), self, parent=deformersLayer) self.deformerJoints = [] self.spineOutputs = [] self.setNumDeformers(1) pelvisDef = Joint('pelvis', parent=self.defCmpGrp) pelvisDef.setComponent(self) # ===================== # Create Component I/O # ===================== # Setup component Xfo I/O's self.spineVertebraeOutput.setTarget(self.spineOutputs) # ============== # Constrain I/O # ============== # Constraint inputs self.spineSrtInputConstraint = PoseConstraint('_'.join([ self.cogCtrlSpace.getName(), 'To', self.spineMainSrtInputTgt.getName() ])) self.spineSrtInputConstraint.addConstrainer(self.spineMainSrtInputTgt) self.spineSrtInputConstraint.setMaintainOffset(True) self.cogCtrlSpace.addConstraint(self.spineSrtInputConstraint) # Constraint outputs self.spineCogOutputConstraint = PoseConstraint('_'.join( [self.spineCogOutputTgt.getName(), 'To', self.cogCtrl.getName()])) self.spineCogOutputConstraint.addConstrainer(self.cogCtrl) self.spineCogOutputTgt.addConstraint(self.spineCogOutputConstraint) self.spineBaseOutputConstraint = PoseConstraint('_'.join( [self.spineBaseOutputTgt.getName(), 'To', 'spineBase'])) self.spineBaseOutputConstraint.addConstrainer(self.spineOutputs[0]) self.spineBaseOutputTgt.addConstraint(self.spineBaseOutputConstraint) self.pelvisOutputConstraint = PoseConstraint('_'.join( [self.pelvisOutputTgt.getName(), 'To', self.pelvisCtrl.getName()])) self.pelvisOutputConstraint.addConstrainer(self.pelvisCtrl) self.pelvisOutputTgt.addConstraint(self.pelvisOutputConstraint) self.spineEndOutputConstraint = PoseConstraint('_'.join( [self.spineEndOutputTgt.getName(), 'To', 'spineEnd'])) self.spineEndOutputConstraint.addConstrainer(self.spineOutputs[0]) self.spineEndOutputTgt.addConstraint(self.spineEndOutputConstraint) # =============== # Add Splice Ops # =============== # Add Spine Splice Op self.bezierSpineSpliceOp = SpliceOperator('spineSpliceOp', 'BezierSpineSolver', 'Kraken') self.addOperator(self.bezierSpineSpliceOp) # Add Att Inputs self.bezierSpineSpliceOp.setInput('drawDebug', self.drawDebugInputAttr) self.bezierSpineSpliceOp.setInput('rigScale', self.rigScaleInputAttr) self.bezierSpineSpliceOp.setInput('length', self.lengthInputAttr) # Add Xfo Inputs self.bezierSpineSpliceOp.setInput('base', self.spine01Ctrl) self.bezierSpineSpliceOp.setInput('baseHandle', self.spine02Ctrl) self.bezierSpineSpliceOp.setInput('tipHandle', self.spine03Ctrl) self.bezierSpineSpliceOp.setInput('tip', self.spine04Ctrl) # Add Xfo Outputs self.bezierSpineSpliceOp.setOutput('outputs', self.spineOutputs) # Add Deformer Splice Op self.deformersToOutputsSpliceOp = SpliceOperator( 'spineDeformerSpliceOp', 'MultiPoseConstraintSolver', 'Kraken') self.addOperator(self.deformersToOutputsSpliceOp) # Add Att Inputs self.deformersToOutputsSpliceOp.setInput('drawDebug', self.drawDebugInputAttr) self.deformersToOutputsSpliceOp.setInput('rigScale', self.rigScaleInputAttr) # Add Xfo Outputs self.deformersToOutputsSpliceOp.setInput('constrainers', self.spineOutputs) # Add Xfo Outputs self.deformersToOutputsSpliceOp.setOutput('constrainees', self.deformerJoints) # Add Pelvis Splice Op self.pelvisDefSpliceOp = SpliceOperator('pelvisDeformerSpliceOp', 'PoseConstraintSolver', 'Kraken') self.addOperator(self.pelvisDefSpliceOp) # Add Att Inputs self.pelvisDefSpliceOp.setInput('drawDebug', self.drawDebugInputAttr) self.pelvisDefSpliceOp.setInput('rigScale', self.rigScaleInputAttr) # Add Xfo Inputs self.pelvisDefSpliceOp.setInput('constrainer', self.pelvisOutputTgt) # Add Xfo Outputs self.pelvisDefSpliceOp.setOutput('constrainee', pelvisDef) Profiler.getInstance().pop() def setNumDeformers(self, numDeformers): # Add new deformers and outputs for i in xrange(len(self.spineOutputs), numDeformers): name = 'spine' + str(i + 1).zfill(2) spineOutput = ComponentOutput(name, parent=self.outputHrcGrp) self.spineOutputs.append(spineOutput) for i in xrange(len(self.deformerJoints), numDeformers): name = 'spine' + str(i + 1).zfill(2) spineDef = Joint(name, parent=self.defCmpGrp) spineDef.setComponent(self) self.deformerJoints.append(spineDef) return True def loadData(self, data=None): """Load a saved guide representation from persisted data. Arguments: data -- object, The JSON data object. Return: True if successful. """ super(SpineComponentRig, self).loadData(data) cogPosition = data['cogPosition'] spine01Position = data['spine01Position'] spine02Position = data['spine02Position'] spine03Position = data['spine03Position'] spine04Position = data['spine04Position'] numDeformers = data['numDeformers'] self.cogCtrlSpace.xfo.tr = cogPosition self.cogCtrl.xfo.tr = cogPosition self.pelvisCtrlSpace.xfo.tr = cogPosition self.pelvisCtrl.xfo.tr = cogPosition self.spine01CtrlSpace.xfo.tr = spine01Position self.spine01Ctrl.xfo.tr = spine01Position self.spine02CtrlSpace.xfo.tr = spine02Position self.spine02Ctrl.xfo.tr = spine02Position self.spine03CtrlSpace.xfo.tr = spine03Position self.spine03Ctrl.xfo.tr = spine03Position self.spine04CtrlSpace.xfo.tr = spine04Position self.spine04Ctrl.xfo.tr = spine04Position length = spine01Position.distanceTo( spine02Position) + spine02Position.distanceTo( spine03Position) + spine03Position.distanceTo(spine04Position) self.lengthInputAttr.setMax(length * 3.0) self.lengthInputAttr.setValue(length) # Update number of deformers and outputs self.setNumDeformers(numDeformers) # Updating constraint to use the updated last output. self.spineEndOutputConstraint.setConstrainer(self.spineOutputs[-1], index=0) # ============ # Set IO Xfos # ============ # ==================== # Evaluate Splice Ops # ==================== # evaluate the spine op so that all the output transforms are updated. self.bezierSpineSpliceOp.evaluate() # evaluate the constraint op so that all the joint transforms are updated. self.deformersToOutputsSpliceOp.evaluate() self.pelvisDefSpliceOp.evaluate() # evaluate the constraints to ensure the outputs are now in the correct location. self.spineCogOutputConstraint.evaluate() self.spineBaseOutputConstraint.evaluate() self.pelvisOutputConstraint.evaluate() self.spineEndOutputConstraint.evaluate()
class SpineComponentRig(SpineComponent): """Spine Component""" def __init__(self, name="spine", parent=None): Profiler.getInstance().push("Construct Spine Rig Component:" + name) super(SpineComponentRig, self).__init__(name, parent) # ========= # Controls # ========= # COG self.cogCtrlSpace = CtrlSpace('cog', parent=self.ctrlCmpGrp) self.cogCtrl = Control('cog', parent=self.cogCtrlSpace, shape="circle") self.cogCtrl.scalePoints(Vec3(6.0, 6.0, 6.0)) self.cogCtrl.setColor("orange") self.cogCtrl.lockScale(True, True, True) # Spine01 self.spine01CtrlSpace = CtrlSpace('spine01', parent=self.cogCtrl) self.spine01Ctrl = Control('spine01', parent=self.spine01CtrlSpace, shape="circle") self.spine01Ctrl.scalePoints(Vec3(4.0, 4.0, 4.0)) self.spine01Ctrl.lockScale(True, True, True) # Spine02 self.spine02CtrlSpace = CtrlSpace('spine02', parent=self.spine01Ctrl) self.spine02Ctrl = Control('spine02', parent=self.spine02CtrlSpace, shape="circle") self.spine02Ctrl.scalePoints(Vec3(4.5, 4.5, 4.5)) self.spine02Ctrl.lockScale(True, True, True) self.spine02Ctrl.setColor("blue") # Spine04 self.spine04CtrlSpace = CtrlSpace('spine04', parent=self.cogCtrl) self.spine04Ctrl = Control('spine04', parent=self.spine04CtrlSpace, shape="circle") self.spine04Ctrl.scalePoints(Vec3(6.0, 6.0, 6.0)) self.spine04Ctrl.lockScale(True, True, True) # Spine03 self.spine03CtrlSpace = CtrlSpace('spine03', parent=self.spine04Ctrl) self.spine03Ctrl = Control('spine03', parent=self.spine03CtrlSpace, shape="circle") self.spine03Ctrl.scalePoints(Vec3(4.5, 4.5, 4.5)) self.spine03Ctrl.lockScale(True, True, True) self.spine03Ctrl.setColor("blue") # Pelvis self.pelvisCtrlSpace = CtrlSpace('pelvis', parent=self.spine01Ctrl) self.pelvisCtrl = Control('pelvis', parent=self.pelvisCtrlSpace, shape="cube") self.pelvisCtrl.alignOnYAxis(negative=True) self.pelvisCtrl.scalePoints(Vec3(4.0, 0.375, 3.75)) self.pelvisCtrl.translatePoints(Vec3(0.0, -0.5, -0.25)) self.pelvisCtrl.lockTranslation(True, True, True) self.pelvisCtrl.lockScale(True, True, True) self.pelvisCtrl.setColor("blueLightMuted") # ========== # Deformers # ========== deformersLayer = self.getOrCreateLayer('deformers') self.defCmpGrp = ComponentGroup(self.getName(), self, parent=deformersLayer) self.addItem('defCmpGrp', self.defCmpGrp) self.deformerJoints = [] self.spineOutputs = [] self.setNumDeformers(1) pelvisDef = Joint('pelvis', parent=self.defCmpGrp) pelvisDef.setComponent(self) # ===================== # Create Component I/O # ===================== # Setup component Xfo I/O's self.spineVertebraeOutput.setTarget(self.spineOutputs) # ============== # Constrain I/O # ============== # Constraint inputs self.spineSrtInputConstraint = PoseConstraint('_'.join([self.cogCtrlSpace.getName(), 'To', self.globalSRTInputTgt.getName()])) self.spineSrtInputConstraint.addConstrainer(self.globalSRTInputTgt) self.spineSrtInputConstraint.setMaintainOffset(True) self.cogCtrlSpace.addConstraint(self.spineSrtInputConstraint) # Constraint outputs self.spineCogOutputConstraint = PoseConstraint('_'.join([self.spineCogOutputTgt.getName(), 'To', self.cogCtrl.getName()])) self.spineCogOutputConstraint.addConstrainer(self.cogCtrl) self.spineCogOutputTgt.addConstraint(self.spineCogOutputConstraint) self.spineBaseOutputConstraint = PoseConstraint('_'.join([self.spineBaseOutputTgt.getName(), 'To', 'spineBase'])) self.spineBaseOutputConstraint.addConstrainer(self.spineOutputs[0]) self.spineBaseOutputTgt.addConstraint(self.spineBaseOutputConstraint) self.pelvisOutputConstraint = PoseConstraint('_'.join([self.pelvisOutputTgt.getName(), 'To', self.pelvisCtrl.getName()])) self.pelvisOutputConstraint.addConstrainer(self.pelvisCtrl) self.pelvisOutputTgt.addConstraint(self.pelvisOutputConstraint) self.spineEndOutputConstraint = PoseConstraint('_'.join([self.spineEndOutputTgt.getName(), 'To', 'spineEnd'])) self.spineEndOutputConstraint.addConstrainer(self.spineOutputs[0]) self.spineEndOutputTgt.addConstraint(self.spineEndOutputConstraint) # =============== # Add Splice Ops # =============== # Add Spine Splice Op self.bezierSpineKLOp = KLOperator('spineKLOp', 'BezierSpineSolver', 'Kraken') self.addOperator(self.bezierSpineKLOp) # Add Att Inputs self.bezierSpineKLOp.setInput('drawDebug', self.drawDebugInputAttr) self.bezierSpineKLOp.setInput('rigScale', self.rigScaleInputAttr) self.bezierSpineKLOp.setInput('length', self.lengthInputAttr) # Add Xfo Inputs self.bezierSpineKLOp.setInput('base', self.spine01Ctrl) self.bezierSpineKLOp.setInput('baseHandle', self.spine02Ctrl) self.bezierSpineKLOp.setInput('tipHandle', self.spine03Ctrl) self.bezierSpineKLOp.setInput('tip', self.spine04Ctrl) # Add Xfo Outputs self.bezierSpineKLOp.setOutput('outputs', self.spineOutputs) # Add Deformer Splice Op self.deformersToOutputsKLOp = KLOperator('spineDeformerKLOp', 'MultiPoseConstraintSolver', 'Kraken') self.addOperator(self.deformersToOutputsKLOp) # Add Att Inputs self.deformersToOutputsKLOp.setInput('drawDebug', self.drawDebugInputAttr) self.deformersToOutputsKLOp.setInput('rigScale', self.rigScaleInputAttr) # Add Xfo Outputs self.deformersToOutputsKLOp.setInput('constrainers', self.spineOutputs) # Add Xfo Outputs self.deformersToOutputsKLOp.setOutput('constrainees', self.deformerJoints) # Add Pelvis Splice Op self.pelvisDefKLOp = KLOperator('pelvisDeformerKLOp', 'PoseConstraintSolver', 'Kraken') self.addOperator(self.pelvisDefKLOp) # Add Att Inputs self.pelvisDefKLOp.setInput('drawDebug', self.drawDebugInputAttr) self.pelvisDefKLOp.setInput('rigScale', self.rigScaleInputAttr) # Add Xfo Inputs self.pelvisDefKLOp.setInput('constrainer', self.pelvisOutputTgt) # Add Xfo Outputs self.pelvisDefKLOp.setOutput('constrainee', pelvisDef) Profiler.getInstance().pop() def setNumDeformers(self, numDeformers): # Add new deformers and outputs for i in xrange(len(self.spineOutputs), numDeformers): name = 'spine' + str(i + 1).zfill(2) spineOutput = ComponentOutput(name, parent=self.outputHrcGrp) self.spineOutputs.append(spineOutput) for i in xrange(len(self.deformerJoints), numDeformers): name = 'spine' + str(i + 1).zfill(2) spineDef = Joint(name, parent=self.defCmpGrp) spineDef.setComponent(self) self.deformerJoints.append(spineDef) return True def loadData(self, data=None): """Load a saved guide representation from persisted data. Arguments: data -- object, The JSON data object. Return: True if successful. """ super(SpineComponentRig, self).loadData( data ) cogPosition = data['cogPosition'] spine01Position = data['spine01Position'] spine02Position = data['spine02Position'] spine03Position = data['spine03Position'] spine04Position = data['spine04Position'] numDeformers = data['numDeformers'] self.cogCtrlSpace.xfo.tr = cogPosition self.cogCtrl.xfo.tr = cogPosition self.pelvisCtrlSpace.xfo.tr = cogPosition self.pelvisCtrl.xfo.tr = cogPosition self.spine01CtrlSpace.xfo.tr = spine01Position self.spine01Ctrl.xfo.tr = spine01Position self.spine02CtrlSpace.xfo.tr = spine02Position self.spine02Ctrl.xfo.tr = spine02Position self.spine03CtrlSpace.xfo.tr = spine03Position self.spine03Ctrl.xfo.tr = spine03Position self.spine04CtrlSpace.xfo.tr = spine04Position self.spine04Ctrl.xfo.tr = spine04Position length = spine01Position.distanceTo(spine02Position) + spine02Position.distanceTo(spine03Position) + spine03Position.distanceTo(spine04Position) self.lengthInputAttr.setMax(length * 3.0) self.lengthInputAttr.setValue(length) # Update number of deformers and outputs self.setNumDeformers(numDeformers) # Updating constraint to use the updated last output. self.spineEndOutputConstraint.setConstrainer(self.spineOutputs[-1], index=0) # ============ # Set IO Xfos # ============ # ==================== # Evaluate Splice Ops # ==================== # evaluate the spine op so that all the output transforms are updated. self.bezierSpineKLOp.evaluate() # evaluate the constraint op so that all the joint transforms are updated. self.deformersToOutputsKLOp.evaluate() self.pelvisDefKLOp.evaluate() # evaluate the constraints to ensure the outputs are now in the correct location. self.spineCogOutputConstraint.evaluate() self.spineBaseOutputConstraint.evaluate() self.pelvisOutputConstraint.evaluate() self.spineEndOutputConstraint.evaluate()