57 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			57 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|  | from lnx.logicnode.lnx_nodes import * | ||
|  | 
 | ||
|  | 
 | ||
|  | class TransformNode(LnxLogicVariableNodeMixin, LnxLogicTreeNode): | ||
|  |     """Stores the location, rotation and scale values as a transform.""" | ||
|  |     bl_idname = 'LNTransformNode' | ||
|  |     bl_label = 'Transform' | ||
|  |     lnx_version = 2 | ||
|  | 
 | ||
|  |     def lnx_init(self, context): | ||
|  |         self.add_input('LnxVectorSocket', 'Location') | ||
|  |         self.add_input('LnxRotationSocket', 'Rotation') | ||
|  |         self.add_input('LnxVectorSocket', 'Scale', default_value=[1.0, 1.0, 1.0]) | ||
|  |         self.add_output('LnxDynamicSocket', 'Transform', is_var=True) | ||
|  | 
 | ||
|  |     def synchronize_from_master(self, master_node: LnxLogicVariableNodeMixin): | ||
|  |         self.inputs[0].default_value_raw = master_node.inputs[0].get_default_value() | ||
|  |         self.inputs[2].default_value_raw = master_node.inputs[2].get_default_value() | ||
|  | 
 | ||
|  |         self.inputs[1].default_value_mode = master_node.inputs[1].default_value_mode | ||
|  |         self.inputs[1].default_value_unit = master_node.inputs[1].default_value_unit | ||
|  |         self.inputs[1].default_value_order = master_node.inputs[1].default_value_order | ||
|  |         self.inputs[1].default_value_s0 = master_node.inputs[1].default_value_s0 | ||
|  |         self.inputs[1].default_value_s1 = master_node.inputs[1].default_value_s1 | ||
|  |         self.inputs[1].default_value_s2 = master_node.inputs[1].default_value_s2 | ||
|  |         self.inputs[1].default_value_s3 = master_node.inputs[1].default_value_s3 | ||
|  | 
 | ||
|  |     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: make rotations their own sockets | ||
|  |         # this transition is a mess, I know. | ||
|  |         newself = self.id_data.nodes.new('LNTransformNode') | ||
|  |         ret = [newself] | ||
|  | 
 | ||
|  |         for link in self.inputs[0].links: | ||
|  |             self.id_data.links.new(link.from_socket, newself.inputs[0]) | ||
|  |         for link in self.inputs[2].links: | ||
|  |             self.id_data.links.new(link.from_socket, newself.inputs[2]) | ||
|  |         for link in self.outputs[0].links: | ||
|  |             self.id_data.links.new(newself.outputs[0], link.to_socket) | ||
|  | 
 | ||
|  |         links_rot = self.inputs[1].links | ||
|  |         if len(links_rot) > 0: | ||
|  |             converter = self.id_data.nodes.new('LNRotationNode') | ||
|  |             self.id_data.links.new(converter.outputs[0], newself.inputs[1]) | ||
|  |             converter.property0 = 'EulerAngles' | ||
|  |             converter.property1 = 'Rad' | ||
|  |             converter.property2 = 'XZY' | ||
|  |             ret.append(converter) | ||
|  |             for link in links_rot: | ||
|  |                 self.id_data.links.new(link.from_socket, converter.inputs[0]) | ||
|  | 
 | ||
|  |         return ret |