mirror of https://github.com/H-uru/korman.git
Adam Johnson
10 years ago
5 changed files with 168 additions and 1 deletions
@ -0,0 +1,130 @@
|
||||
# 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 * |
||||
from collections import OrderedDict |
||||
from PyHSPlasma import * |
||||
|
||||
from .node_core import * |
||||
from ..properties.modifiers.physics import bounds_types, bounds_type_index |
||||
|
||||
class PlasmaExcludeRegionNode(PlasmaNodeBase, bpy.types.Node): |
||||
bl_category = "LOGIC" |
||||
bl_idname = "PlasmaExcludeRegionNode" |
||||
bl_label = "Exclude Region" |
||||
bl_width_default = 195 |
||||
|
||||
# ohey, this can be a Python attribute |
||||
pl_attribs = {"ptAttribExcludeRegion"} |
||||
|
||||
def _get_bounds(self): |
||||
bo = bpy.data.objects.get(self.region, None) |
||||
if bo is not None: |
||||
return bounds_type_index(bo.plasma_modifiers.collision.bounds) |
||||
return bounds_type_index("hull") |
||||
def _set_bounds(self, value): |
||||
bo = bpy.data.objects.get(self.region, None) |
||||
if bo is not None: |
||||
bo.plasma_modifiers.collision.bounds = value |
||||
|
||||
region = StringProperty(name="Region", |
||||
description="Region object's name") |
||||
bounds = EnumProperty(name="Bounds", |
||||
description="Region bounds", |
||||
items=bounds_types, |
||||
get=_get_bounds, |
||||
set=_set_bounds) |
||||
block_cameras = BoolProperty(name="Block Cameras", |
||||
description="The region blocks cameras when it has been cleared") |
||||
|
||||
input_sockets = OrderedDict([ |
||||
("safe_point", { |
||||
"type": "PlasmaExcludeSafePointSocket", |
||||
"text": "Safe Point", |
||||
"spawn_empty": True, |
||||
# This never links to anything... |
||||
"valid_link_sockets": frozenset(), |
||||
}), |
||||
("msg", { |
||||
"type": "PlasmaExcludeMessageSocket", |
||||
"text": "Message", |
||||
"spawn_empty": True, |
||||
}), |
||||
]) |
||||
|
||||
output_sockets = OrderedDict([ |
||||
("keyref", { |
||||
"text": "References", |
||||
"type": "PlasmaPythonReferenceNodeSocket", |
||||
"valid_link_nodes": {"PlasmaPythonFileNode"}, |
||||
}), |
||||
]) |
||||
|
||||
def draw_buttons(self, context, layout): |
||||
layout.prop_search(self, "region", bpy.data, "objects", icon="MESH_DATA") |
||||
layout.prop(self, "bounds") |
||||
layout.prop(self, "block_cameras") |
||||
|
||||
def get_key(self, exporter, parent_so): |
||||
region_bo = bpy.data.objects.get(self.region, None) |
||||
if region_bo is None: |
||||
self.raise_error("invalid region object '{}'".format(self.region)) |
||||
return exporter.mgr.find_create_key(plExcludeRegionModifier, bl=region_bo, name=self.key_name) |
||||
|
||||
def harvest_actors(self): |
||||
return [i.safepoint_name for i in self.find_input_sockets("safe_points")] |
||||
|
||||
def export(self, exporter, bo, parent_so): |
||||
region_bo = bpy.data.objects.get(self.region, None) |
||||
if region_bo is None: |
||||
self.raise_error("invalid region object '{}'".format(self.region)) |
||||
region_so = exporter.mgr.find_create_object(plSceneObject, bl=region_bo) |
||||
excludergn = exporter.mgr.find_create_object(plExcludeRegionModifier, so=region_so, name=self.key_name) |
||||
excludergn.setFlag(plExcludeRegionModifier.kBlockCameras, self.block_cameras) |
||||
|
||||
# Safe points |
||||
for i in self.find_input_sockets("safe_point"): |
||||
if not i.safepoint_name: |
||||
continue |
||||
safept = bpy.data.objects.get(i.safepoint_name, None) |
||||
if safept is None: |
||||
self.raise_error("invalid SafePoint '{}'".format(i.safepoint_name)) |
||||
excludergn.addSafePoint(exporter.mgr.find_create_key(plSceneObject, bl=safept)) |
||||
|
||||
# Ensure the region is exported |
||||
phys_name = "{}_XRgn".format(self.region) |
||||
simIface, physical = exporter.physics.generate_physical(region_bo, region_so, self.bounds, phys_name) |
||||
simIface.setProperty(plSimulationInterface.kPinned, True) |
||||
physical.setProperty(plSimulationInterface.kPinned, True) |
||||
physical.LOSDBs |= plSimDefs.kLOSDBUIBlockers |
||||
|
||||
|
||||
class PlasmaExcludeSafePointSocket(PlasmaNodeSocketBase, bpy.types.NodeSocket): |
||||
bl_color = (0.0, 0.0, 0.0, 1.0) |
||||
|
||||
safepoint_name = StringProperty(name="Safe Point", |
||||
description="A point outside of this exclude region to move the avatar to") |
||||
|
||||
def draw(self, context, layout, node, text): |
||||
layout.prop_search(self, "safepoint_name", bpy.data, "objects", icon="EMPTY_DATA") |
||||
|
||||
@property |
||||
def is_used(self): |
||||
return bpy.data.objects.get(self.safepoint_name, None) is not None |
||||
|
||||
|
||||
class PlasmaExcludeMessageSocket(PlasmaNodeSocketBase, bpy.types.NodeSocket): |
||||
bl_color = (0.467, 0.576, 0.424, 1.0) |
Loading…
Reference in new issue