mirror of https://github.com/H-uru/korman.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
142 lines
5.2 KiB
142 lines
5.2 KiB
# This file is part of Korman. |
|
# |
|
# Korman is free software: you can redistribute it and/or modify |
|
# it under the terms of the GNU General Public License as published by |
|
# the Free Software Foundation, either version 3 of the License, or |
|
# (at your option) any later version. |
|
# |
|
# Korman is distributed in the hope that it will be useful, |
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
# GNU General Public License for more details. |
|
# |
|
# You should have received a copy of the GNU General Public License |
|
# along with Korman. If not, see <http://www.gnu.org/licenses/>. |
|
|
|
import bpy |
|
from bpy.props import * |
|
import itertools |
|
|
|
class NodeOperator: |
|
@classmethod |
|
def poll(cls, context): |
|
return context.scene.render.engine == "PLASMA_GAME" |
|
|
|
|
|
class SelectFileOperator(NodeOperator, bpy.types.Operator): |
|
bl_idname = "file.plasma_file_picker" |
|
bl_label = "Select" |
|
|
|
filter_glob = StringProperty(options={"HIDDEN"}) |
|
filepath = StringProperty(subtype="FILE_PATH") |
|
filename = StringProperty(options={"HIDDEN"}) |
|
|
|
data_path = StringProperty(options={"HIDDEN"}) |
|
filepath_property = StringProperty(description="Name of property to store filepath in", options={"HIDDEN"}) |
|
filename_property = StringProperty(description="Name of property to store filename in", options={"HIDDEN"}) |
|
|
|
def execute(self, context): |
|
dest = eval(self.data_path) |
|
if self.filepath_property: |
|
setattr(dest, self.filepath_property, self.filepath) |
|
if self.filename_property: |
|
setattr(dest, self.filename_property, self.filename) |
|
return {"FINISHED"} |
|
|
|
def invoke(self, context, event): |
|
context.window_manager.fileselect_add(self) |
|
return {"RUNNING_MODAL"} |
|
|
|
pyAttribArgMap= { |
|
"ptAttribute": |
|
["vislistid", "visliststates"], |
|
"ptAttribBoolean": |
|
["default"], |
|
"ptAttribInt": |
|
["default", "rang"], |
|
"ptAttribFloat": |
|
["default", "rang"], |
|
"ptAttribString": |
|
["default"], |
|
"ptAttribDropDownList": |
|
["options"], |
|
"ptAttribSceneobject": |
|
["netForce"], |
|
"ptAttribSceneobjectList": |
|
["byObject", "netForce"], |
|
"ptAttributeKeyList": |
|
["byObject", "netForce"], |
|
"ptAttribActivator": |
|
["byObject", "netForce"], |
|
"ptAttribActivatorList": |
|
["byObject", "netForce"], |
|
"ptAttribResponder": |
|
["stateList", "byObject", "netForce", "netPropagate"], |
|
"ptAttribResponderList": |
|
["stateList", "byObject", "netForce", "netPropagate"], |
|
"ptAttribNamedActivator": |
|
["byObject", "netForce"], |
|
"ptAttribNamedResponder": |
|
["stateList", "byObject", "netForce", "netPropagate"], |
|
"ptAttribDynamicMap": |
|
["netForce"], |
|
"ptAttribAnimation": |
|
["byObject", "netForce"], |
|
"ptAttribBehavior": |
|
["netForce", "netProp"], |
|
"ptAttribMaterialList": |
|
["byObject", "netForce"], |
|
} |
|
|
|
|
|
class PlPyAttributeNodeOperator(NodeOperator, bpy.types.Operator): |
|
bl_idname = "node.plasma_attributes_to_node" |
|
bl_label = "R" |
|
bl_options = {"INTERNAL"} |
|
|
|
python_path = StringProperty(subtype="FILE_PATH") |
|
node_path = StringProperty() |
|
|
|
def execute(self, context): |
|
from ..plasma_attributes import get_attributes |
|
attribs = get_attributes(self.python_path) |
|
|
|
node = eval(self.node_path) |
|
node_attrib_map = node.attribute_map |
|
node_attribs = node.attributes |
|
|
|
# Remove any that p00fed |
|
for cached in node.attributes: |
|
if cached.attribute_id not in attribs: |
|
node_attribs.remove(cached) |
|
|
|
# Update or create |
|
for idx, attrib in attribs.items(): |
|
cached = node_attrib_map.get(idx, None) |
|
if cached is None: |
|
cached = node_attribs.add() |
|
cached.attribute_id = idx |
|
cached.attribute_type = attrib["type"] |
|
cached.attribute_name = attrib["name"] |
|
cached.attribute_description = attrib["desc"] |
|
default = attrib.get("default", None) |
|
if default is not None and cached.is_simple_value: |
|
cached.simple_value = default |
|
|
|
argmap = {} |
|
args = attrib.get("args", None) |
|
# Load our default argument mapping |
|
if args is not None: |
|
if cached.attribute_type in pyAttribArgMap.keys(): |
|
argmap.update(dict(zip(pyAttribArgMap[cached.attribute_type], args))) |
|
else: |
|
print("Found ptAttribute type '{}' with unknown arguments: {}".format(cached.attribute_type, args)) |
|
# Add in/set any arguments provided by keyword |
|
if not set(pyAttribArgMap[cached.attribute_type]).isdisjoint(attrib.keys()): |
|
argmap.update({key: attrib[key] for key in attrib if key in pyAttribArgMap[cached.attribute_type]}) |
|
# Attach the arguments to the attribute |
|
if argmap: |
|
cached.attribute_arguments.set_arguments(argmap) |
|
|
|
node.update() |
|
return {"FINISHED"}
|
|
|