forked from LeenkxTeam/LNXSDK
		
	
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from lnx.logicnode.lnx_nodes import *
 | 
						|
 | 
						|
 | 
						|
class RotationNode(LnxLogicVariableNodeMixin, LnxLogicTreeNode):
 | 
						|
    """A rotation, created from one of its possible mathematical representations"""
 | 
						|
    bl_idname = 'LNRotationNode'
 | 
						|
    bl_label = 'Rotation'
 | 
						|
    bl_description = 'Create a Rotation object, describing the difference between two orientations (internally represented as a quaternion for efficiency)'
 | 
						|
    #lnx_section = 'rotation'
 | 
						|
    lnx_version = 1
 | 
						|
 | 
						|
    def lnx_init(self, context):
 | 
						|
        self.add_input('LnxVectorSocket', 'Euler Angles / Vector XYZ')
 | 
						|
        self.add_input('LnxFloatSocket', 'Angle / W')
 | 
						|
 | 
						|
        self.add_output('LnxRotationSocket', 'Out', is_var=True)
 | 
						|
 | 
						|
    def on_property_update(self, context):
 | 
						|
        """called by the EnumProperty, used to update the node socket labels"""
 | 
						|
        if self.property0 == "Quaternion":
 | 
						|
            self.inputs[0].name = "Quaternion XYZ"
 | 
						|
            self.inputs[1].name = "Quaternion W"
 | 
						|
        elif self.property0 == "EulerAngles":
 | 
						|
            self.inputs[0].name = "Euler Angles"
 | 
						|
            self.inputs[1].name = "[unused for Euler input]"
 | 
						|
        elif self.property0 == "AxisAngle":
 | 
						|
            self.inputs[0].name = "Axis"
 | 
						|
            self.inputs[1].name = "Angle"
 | 
						|
        else:
 | 
						|
            raise ValueError('No nodesocket labels for current input mode: check self-consistancy of LN_rotation.py')
 | 
						|
 | 
						|
    def draw_content(self, context, layout):
 | 
						|
        coll = layout.column(align=True)
 | 
						|
        coll.prop(self, 'property0')
 | 
						|
        if self.property0 in ('EulerAngles','AxisAngle'):
 | 
						|
            coll.prop(self, 'property1')
 | 
						|
            if self.property0=='EulerAngles':
 | 
						|
                coll.prop(self, 'property2')
 | 
						|
 | 
						|
    property0: HaxeEnumProperty(
 | 
						|
        'property0',
 | 
						|
        items = [('EulerAngles', 'Euler Angles', 'Euler Angles'),
 | 
						|
                 ('AxisAngle', 'Axis/Angle', 'Axis/Angle'),
 | 
						|
                 ('Quaternion', 'Quaternion', 'Quaternion')],
 | 
						|
        name='', default='EulerAngles',
 | 
						|
        update=on_property_update)
 | 
						|
 | 
						|
    property1: HaxeEnumProperty(
 | 
						|
        'property1',
 | 
						|
        items=[('Deg', 'Degrees', 'Degrees'),
 | 
						|
               ('Rad', 'Radians', 'Radians')],
 | 
						|
        name='', default='Rad')
 | 
						|
    property2: HaxeEnumProperty(
 | 
						|
        'property2',
 | 
						|
        items=[('XYZ','XYZ','XYZ'),
 | 
						|
               ('XZY','XZY (legacy Leenkx euler order)','XZY (legacy Leenkx euler order)'),
 | 
						|
               ('YXZ','YXZ','YXZ'),
 | 
						|
               ('YZX','YZX','YZX'),
 | 
						|
               ('ZXY','ZXY','ZXY'),
 | 
						|
               ('ZYX','ZYX','ZYX')],
 | 
						|
        name='', default='XYZ'
 | 
						|
    )
 | 
						|
 | 
						|
    def synchronize_from_master(self, master_node: LnxLogicVariableNodeMixin):
 | 
						|
        self.property0 = master_node.property0
 | 
						|
        self.property1 = master_node.property1
 | 
						|
        self.property2 = master_node.property2
 | 
						|
 | 
						|
        for i in range(len(self.inputs)):
 | 
						|
            self.inputs[i].default_value_raw = master_node.inputs[i].get_default_value()
 |