51 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from lnx.logicnode.lnx_nodes import *
 | 
						|
 | 
						|
 | 
						|
@deprecated('Get Cursor Location')
 | 
						|
class MouseCoordsNode(LnxLogicTreeNode):
 | 
						|
    """Deprecated. It is recommended to use 'Get Cursor Location' node and the 'Get Mouse Movement' node instead."""
 | 
						|
    bl_idname = 'LNMouseCoordsNode'
 | 
						|
    bl_label = 'Mouse Coords'
 | 
						|
    bl_description = "Please use the \"Get Cursor Location\" and \"Get Mouse Movement\" nodes instead"
 | 
						|
    lnx_category = 'Input'
 | 
						|
    lnx_section = 'mouse'
 | 
						|
    lnx_version = 2
 | 
						|
 | 
						|
    def lnx_init(self, context):
 | 
						|
        self.add_output('LnxVectorSocket', 'Coords')
 | 
						|
        self.add_output('LnxVectorSocket', 'Movement')
 | 
						|
        self.add_output('LnxIntSocket', 'Wheel')
 | 
						|
 | 
						|
    def get_replacement_node(self, node_tree: bpy.types.NodeTree):
 | 
						|
        if self.lnx_version not in (0, 1):
 | 
						|
            raise LookupError()
 | 
						|
 | 
						|
        all_new_nodes = []
 | 
						|
        if len(self.outputs[0].links) > 0:
 | 
						|
            # "coords": use the cursor coordinates
 | 
						|
            newmain = node_tree.nodes.new('LNGetCursorLocationNode')
 | 
						|
            new_secondary = node_tree.nodes.new('LNVectorNode')
 | 
						|
            node_tree.links.new(newmain.outputs[0], new_secondary.inputs[0])
 | 
						|
            node_tree.links.new(newmain.outputs[1], new_secondary.inputs[1])
 | 
						|
            for link in self.outputs[0].links:
 | 
						|
                node_tree.links.new(new_secondary.outputs[0], link.to_socket)
 | 
						|
            all_new_nodes += [newmain, new_secondary]
 | 
						|
 | 
						|
        if len(self.outputs[1].links) > 0 or len(self.outputs[2].links) > 0:
 | 
						|
            # "movement": use the mouse movement
 | 
						|
            # "wheel": use data from mouse movement as well
 | 
						|
            newmain = node_tree.nodes.new('LNGetMouseMovementNode')
 | 
						|
            all_new_nodes.append(newmain)
 | 
						|
            if len(self.outputs[1].links) > 0:
 | 
						|
                new_secondary = node_tree.nodes.new('LNVectorNode')
 | 
						|
                all_new_nodes.append(new_secondary)
 | 
						|
                node_tree.links.new(newmain.outputs[0], new_secondary.inputs[0])
 | 
						|
                node_tree.links.new(newmain.outputs[1], new_secondary.inputs[1])
 | 
						|
                for link in self.outputs[1].links:
 | 
						|
                    node_tree.links.new(new_secondary.outputs[0], link.to_socket)
 | 
						|
 | 
						|
            for link in self.outputs[2].links:
 | 
						|
                node_tree.links.new(newmain.outputs[2], link.to_socket)
 | 
						|
 | 
						|
        return all_new_nodes
 |