mirror of
				https://github.com/mt-mods/unifieddyes.git
				synced 2025-10-26 21:45:27 +01:00 
			
		
		
		
	Compare commits
	
		
			7 Commits
		
	
	
		
			2018-11-09
			...
			2019-05-25
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 10ab87bf65 | ||
|  | f59c8affc1 | ||
|  | 667bce80b9 | ||
|  | 5039a8ce07 | ||
|  | 13a8cbb38f | ||
|  | 58dd71e561 | ||
|  | 1fd850d37c | 
							
								
								
									
										53
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								init.lua
									
									
									
									
									
								
							| @@ -128,7 +128,7 @@ unifieddyes.GREYS = { | ||||
| unifieddyes.GREYS_EXTENDED = table.copy(unifieddyes.GREYS) | ||||
|  | ||||
| for i = 1, 14 do | ||||
| 	if i ~= 0 and i ~= 3 and i ~= 7 and i ~= 11 and i ~= 15 then | ||||
| 	if i ~= 0 and i ~= 4 and i ~= 8 and i ~= 11 and i ~= 15 then | ||||
| 		table.insert(unifieddyes.GREYS_EXTENDED, "grey_"..i) | ||||
| 	end | ||||
| end | ||||
| @@ -449,7 +449,7 @@ function unifieddyes.getpaletteidx(color, palette_type) | ||||
| 		["grey_14"] = 1, | ||||
| 		["grey_13"] = 2, | ||||
| 		["grey_12"] = 3, | ||||
| 		["light_grey"] = 3, | ||||
| 		["light_grey"] = 4, | ||||
| 		["grey_11"] = 4, | ||||
| 		["grey_10"] = 5, | ||||
| 		["grey_9"] = 6, | ||||
| @@ -630,6 +630,19 @@ function unifieddyes.getpaletteidx(color, palette_type) | ||||
| 	end | ||||
| end | ||||
|  | ||||
| function unifieddyes.get_color_from_dye_name(name) | ||||
| 	if name == "dye:black" then | ||||
| 		return "000000" | ||||
| 	elseif name == "dye:white" then | ||||
| 		return "ffffff" | ||||
| 	end | ||||
| 	local item = minetest.registered_items[name] | ||||
| 	if not item then return end | ||||
| 	local inv_image = item.inventory_image | ||||
| 	if not inv_image then return end | ||||
| 	return string.match(inv_image,"colorize:#(......):200") | ||||
| end | ||||
|  | ||||
| -- punch-to-recolor using the airbrush | ||||
|  | ||||
| function unifieddyes.on_airbrush(itemstack, player, pointed_thing) | ||||
| @@ -640,8 +653,30 @@ function unifieddyes.on_airbrush(itemstack, player, pointed_thing) | ||||
| 		painting_with = unifieddyes.player_current_dye[player_name] | ||||
| 	end | ||||
|  | ||||
| 	if not painting_with then | ||||
| 		minetest.chat_send_player(player_name, "*** You need to set a color first.") | ||||
| 		minetest.chat_send_player(player_name, "*** Right-click any random node to open the color selector,") | ||||
| 		minetest.chat_send_player(player_name, "*** or shift+right-click a colorized node to use its color.") | ||||
| 		minetest.chat_send_player(player_name, "*** Be sure to click \"Accept\", or the color you select will be ignored.") | ||||
| 		return | ||||
| 	end | ||||
|  | ||||
| 	local pos = minetest.get_pointed_thing_position(pointed_thing) | ||||
| 	if not pos then return end | ||||
| 	if not pos then | ||||
| 		local look_angle = player:get_look_vertical() | ||||
| 		if look_angle > -1.55 then | ||||
| 			minetest.chat_send_player(player_name, "*** No node selected") | ||||
| 		else | ||||
| 			local hexcolor = unifieddyes.get_color_from_dye_name(painting_with) | ||||
| 			if hexcolor then | ||||
| 				local r = tonumber(string.sub(hexcolor,1,2),16) | ||||
| 				local g = tonumber(string.sub(hexcolor,3,4),16) | ||||
| 				local b = tonumber(string.sub(hexcolor,5,6),16) | ||||
| 				player:set_sky({r=r,g=g,b=b,a=255},"plain") | ||||
| 			end | ||||
| 		end | ||||
| 		return | ||||
| 	end | ||||
|  | ||||
| 	local node = minetest.get_node(pos) | ||||
| 	local def = minetest.registered_items[node.name] | ||||
| @@ -652,14 +687,6 @@ function unifieddyes.on_airbrush(itemstack, player, pointed_thing) | ||||
| 		return | ||||
| 	end | ||||
|  | ||||
| 	if not painting_with then | ||||
| 		minetest.chat_send_player(player_name, "*** You need to set a color first.") | ||||
| 		minetest.chat_send_player(player_name, "*** Right-click any random node to open the color selector,") | ||||
| 		minetest.chat_send_player(player_name, "*** or shift+right-click a colorized node to use its color.") | ||||
| 		minetest.chat_send_player(player_name, "*** Be sure to click \"Accept\", or the color you select will be ignored.") | ||||
| 		return | ||||
| 	end | ||||
|  | ||||
| 	if not (def.groups and def.groups.ud_param2_colorable and def.groups.ud_param2_colorable > 0) then | ||||
| 		minetest.chat_send_player(player_name, "*** That node can't be colored.") | ||||
| 		return | ||||
| @@ -1102,7 +1129,7 @@ minetest.register_tool("unifieddyes:airbrush", { | ||||
| minetest.register_craft( { | ||||
| 	output = "unifieddyes:airbrush", | ||||
| 	recipe = { | ||||
| 		{ "default:gold_ingot", "",                    "bucket:bucket_empty" }, | ||||
| 		{ "basic_materials:brass_ingot", "",           "basic_materials:plastic_sheet" }, | ||||
| 		{ "",                   "default:steel_ingot", ""                              }, | ||||
| 		{ "",                   "",                    "default:steel_ingot"           } | ||||
| 	}, | ||||
| @@ -1406,7 +1433,7 @@ for _,i in ipairs(unifieddyes.base_color_crafts) do | ||||
|  | ||||
| 			minetest.register_craft( { | ||||
| 				type = "shapeless", | ||||
| 				output = "dye:"..j[1]..color..j[2].." "..yield, | ||||
| 				output = "dye:"..j[1]..color..j[2].." "..j[6], | ||||
| 				recipe = { | ||||
| 					"dye:"..color, | ||||
| 					firstdye, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user