mirror of
				https://github.com/sbrl/Minetest-WorldEditAdditions
				synced 2025-10-25 02:03:06 +02:00 
			
		
		
		
	Bugfix/torus: fix hollow implementation; improve clarity
This commit is contained in:
		
							parent
							
								
									45d5f74d0a
								
							
						
					
					
						commit
						639c2061ef
					
				| @ -1,5 +1,5 @@ | ||||
| --- Overlap command. Places a specified node on top of | ||||
| -- @module worldeditadditions.overlay | ||||
| --- Generates torus shapes. | ||||
| -- @module worldeditadditions.torus | ||||
| 
 | ||||
| --- Generates a torus shape at the given position with the given parameters. | ||||
| -- @param	position		Vector		The position at which to generate the torus. | ||||
| @ -57,8 +57,8 @@ function worldeditadditions.torus(position, major_radius, minor_radius, target_n | ||||
| 				-- (x^2+y^2+z^2-(a^2+b^2))^2-4 a b (b^2-z^2) | ||||
| 				-- Where: | ||||
| 				-- (x, y, z) is the point | ||||
| 				-- a is the major radius (centre to centre of circle) | ||||
| 				-- b is the minor radius (radius of circle) | ||||
| 				-- a is the major radius (centre of the ring to the centre of the torus) | ||||
| 				-- b is the minor radius (radius of the ring) | ||||
| 				local comp_a = (sq.x+sq.y+sq.z - (major_radius_sq+minor_radius_sq)) | ||||
| 				local test_value = comp_a*comp_a - 4*major_radius*minor_radius*(minor_radius_sq-sq.z) | ||||
| 				 | ||||
|  | ||||
| @ -39,8 +39,10 @@ local function parse_params_torus(params_text) | ||||
| 		return false, "Error: 2 or less axes must be specified. For example, xy is valid, but xzy is not." | ||||
| 	end | ||||
| 	 | ||||
| 	local hollow = parts[5] | ||||
| 	if hollow == "false" then hollow = false end | ||||
| 	local hollow = false | ||||
| 	if parts[5] == "hollow" or parts[5] == "h" then | ||||
| 		hollow = true | ||||
| 	end | ||||
| 	 | ||||
| 	-- Sort the axis names (this is important to ensure we can identify the direction properly) | ||||
| 	if axes == "yx" then axes = "xy" end | ||||
| @ -51,7 +53,7 @@ local function parse_params_torus(params_text) | ||||
| end | ||||
| 
 | ||||
| worldedit.register_command("torus", { | ||||
| 	params = "<major_radius> <minor_radius> <replace_node> [<axes=xy>] [h[ollow]]", | ||||
| 	params = "<major_radius> <minor_radius> <replace_node> [<axes=xy> [h[ollow]]]", | ||||
| 	description = "Creates a 3D torus with a major radius of <major_radius> and a minor radius of <minor_radius> at pos1, filled with <replace_node>, on axes <axes> (i.e. 2 axis names: xz, zy, etc).", | ||||
| 	privs = { worldedit = true }, | ||||
| 	require_pos = 1, | ||||
| @ -64,7 +66,13 @@ worldedit.register_command("torus", { | ||||
| 	end, | ||||
| 	func = function(name, target_node, major_radius, minor_radius, axes, hollow) | ||||
| 		local start_time = worldeditadditions.get_ms_time() | ||||
| 		local replaced = worldeditadditions.torus(worldedit.pos1[name], major_radius, minor_radius, target_node, axes, hollow) | ||||
| 		local replaced = worldeditadditions.torus( | ||||
| 			worldedit.pos1[name], | ||||
| 			major_radius, minor_radius, | ||||
| 			target_node, | ||||
| 			axes, | ||||
| 			hollow | ||||
| 		) | ||||
| 		local time_taken = worldeditadditions.get_ms_time() - start_time | ||||
| 		 | ||||
| 		minetest.log("action", name .. " used //torus at " .. worldeditadditions.vector.tostring(worldedit.pos1[name]) .. ", replacing " .. replaced .. " nodes in " .. time_taken .. "s") | ||||
| @ -85,9 +93,15 @@ worldedit.register_command("hollowtorus", { | ||||
| 	nodes_needed = function(name, target_node, major_radius, minor_radius, axes) | ||||
| 		return math.ceil(2 * math.pi*math.pi * major_radius * minor_radius*minor_radius) | ||||
| 	end, | ||||
| 	func = function(name, target_node, major_radius, minor_radius) | ||||
| 	func = function(name, target_node, major_radius, minor_radius, axes) | ||||
| 		local start_time = worldeditadditions.get_ms_time() | ||||
| 		local replaced = worldeditadditions.torus(worldedit.pos1[name], major_radius, minor_radius, target_node, axes, true) | ||||
| 		local replaced = worldeditadditions.torus( | ||||
| 			worldedit.pos1[name], | ||||
| 			major_radius, minor_radius, | ||||
| 			target_node, | ||||
| 			axes, | ||||
| 			true -- hollow | ||||
| 		) | ||||
| 		local time_taken = worldeditadditions.get_ms_time() - start_time | ||||
| 		 | ||||
| 		minetest.log("action", name .. " used //hollowtorus at " .. worldeditadditions.vector.tostring(worldedit.pos1[name]) .. ", replacing " .. replaced .. " nodes in " .. time_taken .. "s") | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user