我正在尝试获取任何给定maya命令的标志和默认值。在python中,我通常会使用inspect模块,但由于pymel只是一个包装器,我不认为这是一个选项。我希望api能够实现这一点,但还没有遇到任何问题。以下是一种贫民区方法,在本用例中有效,但它很粗糙,必须进行相当大的修改才能真正适用于所有命令(而不是我想走的路(:
def getMayaCmdFlagDefaults(cmd):
'''Get the flags and corresponding default values of a given MEL command.
:Parameters:
cmd (str) = A MEL command name.
:Return:
(dict) {'flag':<value>}
'''
obj_types = ['polyPlane', 'nurbsPlane'] #etc..
for obj in obj_types:
try:
temp = getattr(pm, obj)(ch=0)
node = getattr(pm, cmd)(temp)
if node:
result = Init.getAttributesMEL(node[0])
pm.delete(temp)
return result
except Exception as error:
print ('# Error: {}: {} #'.format(cmd, error))
pm.delete(temp)
print (getMayaCmdFlagDefaults('polyReduce'))
# returns: {u'keepQuadsWeight': 0.0, u'symmetryPlaneW': 0.0, u'symmetryPlaneZ': 0.0, u'symmetryPlaneX': 0.0, u'symmetryPlaneY': 0.0, u'sharpness': 0.0, u'keepBorderWeight': 0.5, u'vertexMapName': None, u'vertexWeights': None, u'border': 0.5, u'keepBorder': True, u'triangleCount': 0, u'keepHardEdgeWeight': 0.5, u'keepCreaseEdge': True, u'percentageAchieved': 0.0, u'keepColorBorder': True, u'version': 0, u'triangleCountIn': 200, u'percentage': 0.0, u'keepMapBorderWeight': 0.5, u'useVirtualSymmetry': 0, u'keepColorBorderWeight': 0.5, u'symmetryTolerance': 0.0, u'geomWeights': 1.0, u'detail': 0.5, u'invertVertexWeights': True, u'keepHardEdge': True, u'keepCreaseEdgeWeight': 0.5, u'uvWeights': 0.0, u'vertexCount': 0, u'termination': 0, u'line': 0.5, u'weightCoefficient': 10000.0, u'vertexCountIn': 121, u'keepFaceGroupBorderWeight': 0.5, u'keepMapBorder': True, u'vertexCountAchieved': 0, u'keepFaceGroupBorder': True, u'triangulate': True, u'cachingReduce': False, u'weights': [], u'compactness': 0.0, u'vertexWeightCoefficient': 1.0, u'triangleCountAchieved': 0, u'keepOriginalVertices': False, u'symmetryPlane': (0.0, 0.0, 0.0, 0.0), u'colorWeights': 0.0, u'preserveTopology': True}
使用Inspect(到目前为止首选的方法(:
print (inspect.getargspec(pm.polyReduce))
# returns: ArgSpec(args=[], varargs='args', keywords='kwargs', defaults=None)
print (inspect.getargspec(cmds.polyReduce))
# returns: TypeError: <built-in method polyReduce of module object at 0x000002B30DDE3078> is not a Python function
# Additional things of interest that I have tried:
# backport of inspect.signature for python 2.6+:
import funcsigs
bound_args = funcsigs.signature(pm.polyReduce)
# unwrap a decorated method:
def extract_wrapped(decorated):
closure = (c.cell_contents for c in decorated.__closure__)
return next((c for c in closure if isinstance(c, FunctionType)), None)
问题是命令没有提供这些信息。您需要了解cmds模块正是它的名称;填充/操纵场景的一系列命令。实际的默认值通过其属性嵌入到实际的节点类中。
该命令实际上是一个";函数";它调用一个特殊的类(MPxCommand(,它的工作是解析您在mel/python中传递的参数,并对这些参数进行处理。
例如,cmds.polyPlane接受传递给它的一系列参数,然后创建/修改节点并基本上对其进行包装,使其不可撤消。在没有任何参数的情况下,它通常会在场景中创建该对象的实例。默认值来自polyPlane本身的类,而不是用于创建它的cmd.polyPlane函数。当您将参数传递给cmds.polyPlane以更改其属性时,该命令只需创建polyPlane,然后修改其属性。。。明确地
我想你需要的是cmds.attrInfo。查看它的文档。他们在那里列出了一个可能有助于你入门的例子。你走在了正确的轨道上。。。
好消息是,这些数据需要解析一次(除非应用程序更改为新版本,否则对象的属性默认值不会更改(。一旦您有了创建并使用cmds.attrInfo检查节点的脚本,您就可以将该信息转储到文件中,然后在需要该信息时读取该文件。
例如,您可能想要启动一个简单的文本或json文件,其中包含要优先排序的节点列表,并运行一个脚本来读取节点列表,创建每个节点,解析其属性信息,并将这些详细信息转储到一个单独的文本或json文件中,以便稍后阅读。如果您需要有关其他节点的信息,只需使用新的节点名称更新前一个文件,即可运行更新后一个文件的脚本。从小处着手,根据需要进行修改。