forked from LeenkxTeam/LNXSDK
		
	
		
			
				
	
	
		
			76 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from lnx.logicnode.lnx_nodes import *
 | 
						|
from mathutils import Vector
 | 
						|
 | 
						|
 | 
						|
@deprecated(message='Do not use quaternion sockets')
 | 
						|
class QuaternionNode(LnxLogicTreeNode):
 | 
						|
    """TO DO."""
 | 
						|
    bl_idname = 'LNQuaternionNode'
 | 
						|
    bl_label = 'Quaternion'
 | 
						|
    bl_description = 'Create a quaternion variable (transported through a vector socket)'
 | 
						|
    lnx_category = 'Variable'
 | 
						|
    lnx_section = 'quaternions'
 | 
						|
    lnx_version = 2  # deprecate
 | 
						|
 | 
						|
    def lnx_init(self, context):
 | 
						|
        self.add_input('LnxFloatSocket', 'X')
 | 
						|
        self.add_input('LnxFloatSocket', 'Y')
 | 
						|
        self.add_input('LnxFloatSocket', 'Z')
 | 
						|
        self.add_input('LnxFloatSocket', 'W', default_value=1.0)
 | 
						|
 | 
						|
        self.add_output('LnxVectorSocket', 'Quaternion')
 | 
						|
        self.add_output('LnxVectorSocket', 'XYZ')
 | 
						|
        self.add_output('LnxVectorSocket', 'W')
 | 
						|
 | 
						|
    def get_replacement_node(self, node_tree: bpy.types.NodeTree):
 | 
						|
        if self.lnx_version not in (0, 1):
 | 
						|
            raise LookupError()
 | 
						|
 | 
						|
        # transition from version 1 to version 2[deprecated]
 | 
						|
 | 
						|
        newnodes = []
 | 
						|
 | 
						|
        rawlinks = self.outputs[0].links
 | 
						|
        xyzlinks = self.outputs[1].links
 | 
						|
        wlinks = self.outputs[2].links
 | 
						|
        if len(rawlinks)>0 or len(xyzlinks)>0:
 | 
						|
            xyzcomb = node_tree.nodes.new('LNVectorNode')
 | 
						|
            newnodes.append(xyzcomb)
 | 
						|
 | 
						|
            xyzcomb.inputs[0].default_value = self.inputs[0].default_value
 | 
						|
            xyzcomb.inputs[1].default_value = self.inputs[1].default_value
 | 
						|
            xyzcomb.inputs[2].default_value = self.inputs[2].default_value
 | 
						|
            for link in self.inputs[0].links:
 | 
						|
                node_tree.links.new(link.from_socket, xyzcomb.inputs[0])
 | 
						|
            for link in self.inputs[1].links:
 | 
						|
                node_tree.links.new(link.from_socket, xyzcomb.inputs[1])
 | 
						|
            for link in self.inputs[2].links:
 | 
						|
                node_tree.links.new(link.from_socket, xyzcomb.inputs[2])
 | 
						|
 | 
						|
            for link in xyzlinks:
 | 
						|
                node_tree.links.new(xyzcomb.outputs[0], link.to_socket)
 | 
						|
            if len(rawlinks)>0:
 | 
						|
                rotnode = node_tree.nodes.new('LNRotationNode')
 | 
						|
                newnodes.append(rotnode)
 | 
						|
                rotnode.property0 = 'Quaternion'
 | 
						|
                rotnode.inputs[0].default_value = Vector(
 | 
						|
                    (self.inputs[0].default_value,
 | 
						|
                     self.inputs[1].default_value,
 | 
						|
                     self.inputs[2].default_value))
 | 
						|
                rotnode.inputs[1].default_value = self.inputs[3].default_value
 | 
						|
                node_tree.links.new(xyzcomb.outputs[0], rotnode.inputs[0])
 | 
						|
                for link in self.inputs[3].links:  # 0 or 1
 | 
						|
                    node_tree.links.new(link.from_socket, rotnode.inputs[1])
 | 
						|
                for link in rawlinks:
 | 
						|
                    node_tree.links.new(rotnode.outputs[0], link.to_socket)
 | 
						|
 | 
						|
        if len(self.inputs[3].links)>0:
 | 
						|
            fromval = self.inputs[3].links[0].from_socket
 | 
						|
            for link in self.outputs[2].links:
 | 
						|
                node_tree.links.new(fromval, link.to_socket)
 | 
						|
        else:
 | 
						|
            for link in self.outputs[2].links:
 | 
						|
                link.to_socket.default_value = self.inputs[3].default_value
 | 
						|
 | 
						|
        return newnodes
 |