diff --git a/addons/io_hubs_addon/components/definitions/ammo_shape.py b/addons/io_hubs_addon/components/definitions/ammo_shape.py index ad3d8cd9..ba588c67 100644 --- a/addons/io_hubs_addon/components/definitions/ammo_shape.py +++ b/addons/io_hubs_addon/components/definitions/ammo_shape.py @@ -7,7 +7,7 @@ class AmmoShape(HubsComponent): _definition = { 'name': 'ammo-shape', - 'display_name': 'Ammo Shape (deprecated)', + 'display_name': 'Ammo Shape', 'category': Category.OBJECT, 'node_type': NodeType.NODE, 'panel_type': [PanelType.OBJECT, PanelType.BONE], diff --git a/addons/io_hubs_addon/components/definitions/grabbable.py b/addons/io_hubs_addon/components/definitions/grabbable.py deleted file mode 100644 index 0b93ad3f..00000000 --- a/addons/io_hubs_addon/components/definitions/grabbable.py +++ /dev/null @@ -1,44 +0,0 @@ -from bpy.props import BoolProperty -from ..hubs_component import HubsComponent -from ..types import NodeType, PanelType, Category -from ..utils import remove_component, add_component -from .networked_transform import NetworkedTransform - - -class Grabbable(HubsComponent): - _definition = { - 'name': 'grabbable', - 'display_name': 'Grabbable', - 'category': Category.OBJECT, - 'node_type': NodeType.NODE, - 'panel_type': [PanelType.OBJECT], - 'icon': 'VIEW_PAN', - 'deps': ['rigidbody', 'networked-transform'], - 'version': (1, 0, 1) - } - - cursor: BoolProperty( - name="By Cursor", description="Can be grabbed by a cursor", default=True) - - hand: BoolProperty( - name="By Hand", description="Can be grabbed by VR hands", default=True) - - @classmethod - def init(cls, obj): - obj.hubs_component_list.items.get('rigidbody').isDependency = True - - def migrate(self, migration_type, panel_type, instance_version, host, migration_report, ob=None): - migration_occurred = False - if instance_version <= (1, 0, 0): - migration_occurred = True - - # This was a component that has disappeared but it was usually added together with grababble so we try to remove those instances. - if "capturable" in host.hubs_component_list.items: - remove_component(host, "capturable") - - if "networked-object-properties" in host.hubs_component_list.items: - remove_component(host, "networked-object-properties") - - add_component(host, NetworkedTransform.get_name()) - - return migration_occurred diff --git a/addons/io_hubs_addon/components/definitions/networked_transform.py b/addons/io_hubs_addon/components/definitions/networked_transform.py deleted file mode 100644 index 4883ffd6..00000000 --- a/addons/io_hubs_addon/components/definitions/networked_transform.py +++ /dev/null @@ -1,14 +0,0 @@ -from io_hubs_addon.components.hubs_component import HubsComponent -from io_hubs_addon.components.types import NodeType, PanelType - - -class NetworkedTransform(HubsComponent): - _definition = { - 'name': 'networked-transform', - 'display_name': 'Networked Transform', - 'node_type': NodeType.NODE, - 'panel_type': [PanelType.OBJECT], - 'icon': 'EMPTY_AXIS', - 'deps': ['networked'], - 'version': (1, 0, 0) - } diff --git a/addons/io_hubs_addon/components/definitions/physics_shape.py b/addons/io_hubs_addon/components/definitions/physics_shape.py deleted file mode 100644 index e2194a51..00000000 --- a/addons/io_hubs_addon/components/definitions/physics_shape.py +++ /dev/null @@ -1,134 +0,0 @@ -from bpy.props import BoolProperty, FloatProperty, EnumProperty, FloatVectorProperty -from ..hubs_component import HubsComponent -from ..types import NodeType, PanelType, Category -from mathutils import Vector -from ...io.utils import import_component, assign_property - - -class PhysicsShape(HubsComponent): - _definition = { - 'name': 'physics-shape', - 'display_name': 'Physics Shape', - 'category': Category.OBJECT, - 'node_type': NodeType.NODE, - 'panel_type': [PanelType.OBJECT, PanelType.BONE], - 'icon': 'SCENE_DATA', - 'version': (1, 0, 1) - } - - type: EnumProperty( - name="Type", description="Type", - items=[("box", "Box Collider", "A box-shaped primitive collision shape"), - ("sphere", "Sphere Collider", "A primitive collision shape which represents a sphere"), - ("hull", "Convex Hull", - "A convex hull wrapped around the object's vertices. A good analogy for a convex hull is an elastic membrane or balloon under pressure which is placed around a given set of vertices. When released the membrane will assume the shape of the convex hull"), - ("mesh", "Mesh Collider", - "A shape made of the actual vertices of the object. This can be expensive for large meshes")], - default="hull") - - fit: EnumProperty( - name="Fit Mode", - description="Shape fitting mode", - items=[("all", "Automatic fit all", "Automatically match the shape to fit the object's vertices"), - ("manual", "Manual", "Use the manually specified dimensions to define the shape, ignoring the object's vertices")], - default="all") - - halfExtents: FloatVectorProperty( - name="Half Extents", - description="Half dimensions of the collider. (Only used when fit is set to \"manual\" and type is set to \"box\")", - unit='LENGTH', - subtype="XYZ", - default=(0.5, 0.5, 0.5)) - - minHalfExtent: FloatProperty( - name="Min Half Extent", - description="The minimum size to use when automatically generating half extents. (Only used when fit is set to \"all\" and type is set to \"box\")", - unit="LENGTH", - default=0.0) - - maxHalfExtent: FloatProperty( - name="Max Half Extent", - description="The maximum size to use when automatically generating half extents. (Only used when fit is set to \"all\" and type is set to \"box\")", - unit="LENGTH", - default=1000.0) - - sphereRadius: FloatProperty( - name="Sphere Radius", - description="Radius of the sphere collider. (Only used when fit is set to \"manual\" and type is set to \"sphere\")", - unit="LENGTH", default=0.5) - - offset: FloatVectorProperty( - name="Offset", description="An offset to apply to the collider relative to the object's origin", - unit='LENGTH', - subtype="XYZ", - default=(0.0, 0.0, 0.0)) - - includeInvisible: BoolProperty( - name="Include Invisible", - description="Include invisible objects when generating a collider. (Only used if \"fit\" is set to \"all\")", - default=False) - - def draw(self, context, layout, panel): - layout.prop(self, "type") - layout.prop(self, "fit") - if self.fit == "manual": - if self.type == "box": - layout.prop(self, "halfExtents") - elif self.type == "sphere": - layout.prop(self, "sphereRadius") - else: - if self.type == "box": - layout.prop(self, "minHalfExtent") - layout.prop(self, "maxHalfExtent") - layout.prop(self, "includeInvisible") - layout.prop(self, "offset") - - if self.fit == "manual" and (self.type == "mesh" or self.type == "hull"): - col = layout.column() - col.alert = True - col.label( - text="'Hull' and 'Mesh' do not support 'manual' fit mode", icon='ERROR') - - def gather(self, export_settings, object): - props = super().gather(export_settings, object) - props['offset'] = { - 'x': self.offset.x, - 'y': self.offset.z if export_settings['gltf_yup'] else self.offset.y, - 'z': self.offset.y if export_settings['gltf_yup'] else self.offset.z, - } - props['halfExtents'] = { - 'x': self.halfExtents.x, - 'y': self.halfExtents.z if export_settings['gltf_yup'] else self.halfExtents.y, - 'z': self.halfExtents.y if export_settings['gltf_yup'] else self.halfExtents.z, - } - return props - - def migrate(self, migration_type, panel_type, instance_version, host, migration_report, ob=None): - migration_occurred = False - if instance_version <= (1, 0, 0): - migration_occurred = True - - offset = self.offset.copy() - offset = Vector((offset.x, offset.z, offset.y)) - self.offset = offset - - halfExtents = self.halfExtents.copy() - halfExtents = Vector((halfExtents.x, halfExtents.z, halfExtents.y)) - self.halfExtents = halfExtents - - return migration_occurred - - @classmethod - def gather_import(cls, gltf, blender_host, component_name, component_value, import_report, blender_ob=None): - gltf_yup = gltf.import_settings.get('gltf_yup', True) - - blender_component = import_component(component_name, blender_host) - for property_name, property_value in component_value.items(): - if property_name == 'offset' and gltf_yup: - property_value['y'], property_value['z'] = property_value['z'], property_value['y'] - - elif property_name == 'halfExtents' and gltf_yup: - property_value['y'], property_value['z'] = property_value['z'], property_value['y'] - - assign_property(gltf.vnodes, blender_component, - property_name, property_value) diff --git a/addons/io_hubs_addon/components/definitions/rigid_body.py b/addons/io_hubs_addon/components/definitions/rigid_body.py deleted file mode 100644 index 8e5df85b..00000000 --- a/addons/io_hubs_addon/components/definitions/rigid_body.py +++ /dev/null @@ -1,193 +0,0 @@ -from bpy.props import BoolProperty, FloatProperty, EnumProperty, BoolVectorProperty, FloatVectorProperty -from ..hubs_component import HubsComponent -from ..types import NodeType, PanelType, Category -from mathutils import Vector -from ...io.utils import import_component, assign_property - - -collision_masks = [ - ("objects", "Objects", "Interactive objects"), - ("triggers", "Triggers", "Trigger Colliders"), - ("environment", "Environment", "Environment geometry"), - ("avatars", "Avatars", "Player Avatars"), - ("media-frames", "Media Frames", "Media Frames"), -] - - -class RigidBody(HubsComponent): - _definition = { - 'name': 'rigidbody', - 'display_name': 'RigidBody', - 'category': Category.OBJECT, - 'node_type': NodeType.NODE, - 'panel_type': [PanelType.OBJECT], - 'icon': 'PHYSICS', - 'deps': ['physics-shape'], - 'version': (1, 0, 1) - } - - type: EnumProperty( - name="Body Type", - description="RigidBody Type", - items=[("static", "Static", "Will not ever move."), - ("dynamic", "Dynamic", "Effected by physics and gravity"), - ("kinematic", "Kinematic", "Not effected by gravity or collisions, but can be moved.")], - default="dynamic") - - disableCollision: BoolProperty( - name="Is Trigger", - description="Disable collision response, act as a trigger only", - default=False) - - collisionGroup: EnumProperty( - name="Collision Group", - description="What collision group this object belongs to. This effects what objects will collide with it.", - items=[g for g in collision_masks if g[0] != "avatars"], - default="objects") - - collisionMask: BoolVectorProperty( - name="Collision Mask", - description="What collision groups this object will collide with. Note: the other object must also be set to collide with this object's group.", - size=5, subtype='LAYER', options={'ANIMATABLE'}, - default=[value in ["objects", "triggers", "environment"] for (value, _label, _desc) in collision_masks]) - - mass: FloatProperty( - name="Mass", - description="Object's Mass", - default=1) - - linearDamping: FloatProperty( - name="Linear Damping", - description="Amount of linear damping", - default=0, - min=0.0, - soft_max=1.0, - ) - - angularDamping: FloatProperty( - name="Angular Damping", - description="Amount of angular damping", - default=0, - min=0.0, - soft_max=1.0, - ) - - linearSleepingThreshold: FloatProperty( - name="Linear Sleeping Threshold", - description="Linear velocity threshold below which the object starts to sleep", - default=0.8, - min=0.0, - soft_max=10.0, - ) - - angularSleepingThreshold: FloatProperty( - name="Angular Sleeping Threshold", - description="Angular velocity threshold below which the object starts to sleep", - default=1.0, - min=0.0, - soft_max=10.0, - ) - - angularFactor: FloatVectorProperty( - name="Angular Factor", - description="Influence of the object's rotation along the X, Y, and Z axes", - size=3, - subtype="XYZ", - default=(1.0, 1.0, 1.0), - min=0.0, - soft_max=10.0, - ) - - gravity: FloatVectorProperty( - name="Gravity", description="Object's Gravity", - unit="ACCELERATION", - subtype="ACCELERATION", - default=(0.0, 0.0, -9.8)) - - def gather(self, export_settings, object): - props = super().gather(export_settings, object) - props['collisionMask'] = [value for i, (value, _label, _desc) in enumerate( - collision_masks) if self.collisionMask[i]] - - # prefer to store as an array for new components - props['angularFactor'] = [ - self.angularFactor.x, - self.angularFactor.z if export_settings['gltf_yup'] else self.angularFactor.y, - self.angularFactor.y if export_settings['gltf_yup'] else self.angularFactor.z, - ] - props['gravity'] = [ - self.gravity.x, - self.gravity.z if export_settings['gltf_yup'] else self.gravity.y, - self.gravity.y if export_settings['gltf_yup'] else self.gravity.z, - ] - return props - - def draw(self, context, layout, panel): - layout.prop(self, "type") - - if (self.disableCollision and self.collisionGroup != "triggers") or (self.collisionGroup == "triggers" and not self.disableCollision): - col = layout.column() - # col.alert = True - col.label( - text="When making triggers you likely want 'Is Trigger' checked and collision group set to 'Triggers'", - icon='INFO') - layout.prop(self, "collisionGroup") - layout.label(text="Collision Mask:") - col = layout.column(align=True) - for i, (_value, label, _desc) in enumerate(collision_masks): - col.prop(self, "collisionMask", text=label, index=i, toggle=True) - layout.prop(self, "disableCollision") - - layout.prop(self, "mass") - layout.prop(self, "linearDamping") - layout.prop(self, "angularDamping") - layout.prop(self, "linearSleepingThreshold") - layout.prop(self, "angularSleepingThreshold") - layout.prop(self, "angularFactor") - layout.prop(self, "gravity") - - @classmethod - def init(cls, obj): - obj.hubs_component_list.items.get('physics-shape').isDependency = True - - def migrate(self, migration_type, panel_type, instance_version, host, migration_report, ob=None): - migration_occurred = False - if instance_version <= (1, 0, 0): - migration_occurred = True - - angularFactor = self.angularFactor.copy() - angularFactor = Vector((angularFactor.x, angularFactor.z, angularFactor.y)) - self.angularFactor = angularFactor - - # If the gravity property has not changed, it will take the default value so we don't swizzle - # in that case. - if self.get('gravity') is not None: - gravity = self.gravity.copy() - gravity = Vector((gravity.x, gravity.z, gravity.y)) - self.gravity = gravity - - return migration_occurred - - @classmethod - def gather_import(cls, gltf, blender_host, component_name, component_value, import_report, blender_ob=None): - gltf_yup = gltf.import_settings.get('gltf_yup', True) - - blender_component = import_component(component_name, blender_host) - for property_name, property_value in component_value.items(): - if property_name == 'gravity' and gltf_yup: - property_value[1], property_value[2] = property_value[2], property_value[1] - - elif property_name == 'angularFactor' and gltf_yup: - property_value[1], property_value[2] = property_value[2], property_value[1] - - elif property_name == 'collisionMask': - property_value = [ - 'objects' in property_value, - 'triggers' in property_value, - 'environment' in property_value, - 'avatars' in property_value, - 'media-frames' in property_value, - ] - - assign_property(gltf.vnodes, blender_component, - property_name, property_value) diff --git a/tests/scenes/rigid-body.blend b/tests/scenes/rigid-body.blend deleted file mode 100644 index eafbd239..00000000 Binary files a/tests/scenes/rigid-body.blend and /dev/null differ diff --git a/tests/test/tests/rigid-body.js b/tests/test/tests/rigid-body.js deleted file mode 100644 index a20acd56..00000000 --- a/tests/test/tests/rigid-body.js +++ /dev/null @@ -1,65 +0,0 @@ -const fs = require('fs'); -const path = require('path'); -const assert = require('assert'); -const utils = require('../utils.js'); - -module.exports = { - description: 'can export rigid-body', - test: outDirPath => { - let gltfPath = path.resolve(outDirPath, 'rigid-body.gltf'); - const asset = JSON.parse(fs.readFileSync(gltfPath)); - - assert.strictEqual(asset.extensionsUsed.includes('MOZ_hubs_components'), true); - assert.strictEqual(utils.checkExtensionAdded(asset, 'MOZ_hubs_components'), true); - - const node = asset.nodes[0]; - assert.strictEqual(utils.checkExtensionAdded(node, 'MOZ_hubs_components'), true); - - const ext = node.extensions['MOZ_hubs_components']; - assert.deepStrictEqual(ext, { - "rigidbody":{ - "type":"dynamic", - "disableCollision":false, - "collisionGroup":"objects", - "collisionMask":[ - "objects", - "triggers", - "environment" - ], - "mass":1, - "linearDamping":0, - "angularDamping":0, - "linearSleepingThreshold":0.800000011920929, - "angularSleepingThreshold":1, - "angularFactor":[ - 1, - 1, - 1 - ], - "gravity":[ - 0, - -9.800000190734863, - 0 - ] - }, - "physics-shape":{ - "type":"hull", - "fit":"all", - "halfExtents":{ - "x":0.5, - "y":0.5, - "z":0.5 - }, - "minHalfExtent":0, - "maxHalfExtent":1000, - "sphereRadius":0.5, - "offset":{ - "x":0, - "y":0, - "z":0 - }, - "includeInvisible":false - } - }); - } -}; \ No newline at end of file