forked from mtcontrib/homedecor_modpack
		
	Some fixes to proportional/HQ font support.
This commit is contained in:
		| @@ -10,8 +10,6 @@ end | |||||||
|  |  | ||||||
| -- CONSTANTS | -- CONSTANTS | ||||||
|  |  | ||||||
| local NUMBER_OF_LINES = 6 |  | ||||||
|  |  | ||||||
| local MP = minetest.get_modpath("homedecor") | local MP = minetest.get_modpath("homedecor") | ||||||
|  |  | ||||||
| -- Used by `build_char_db' to locate the file. | -- Used by `build_char_db' to locate the file. | ||||||
| @@ -23,7 +21,7 @@ local FONT_FMT_SIMPLE = "hdf_%02x.png" | |||||||
| -- Path to the textures. | -- Path to the textures. | ||||||
| local TP = MP.."/textures" | local TP = MP.."/textures" | ||||||
|  |  | ||||||
| local TEXT_SCALE = {x=0.9, y=0.7} | local TEXT_SCALE = {x=0.9, y=0.5} | ||||||
|  |  | ||||||
| -- Lots of overkill here. KISS advocates, go away, shoo! ;) -- kaeza | -- Lots of overkill here. KISS advocates, go away, shoo! ;) -- kaeza | ||||||
|  |  | ||||||
| @@ -48,6 +46,17 @@ local LINE_HEIGHT | |||||||
| local SIGN_WIDTH | local SIGN_WIDTH | ||||||
| local SIGN_PADDING | local SIGN_PADDING | ||||||
|  |  | ||||||
|  | -- Size of the canvas, in characters. | ||||||
|  | -- Please note that CHARS_PER_LINE is multiplied by the average character | ||||||
|  | -- width to get the total width of the canvas, so for proportional fonts, | ||||||
|  | -- either more or fewer characters may fit on a line. | ||||||
|  | local CHARS_PER_LINE = 30 | ||||||
|  | local NUMBER_OF_LINES = 6 | ||||||
|  |  | ||||||
|  | -- Separation between lines. 1.0 means no separation (ypos offset by text | ||||||
|  | -- height), 2.0 is one "line" (ypos offset by two times text height), etc. | ||||||
|  | local LINE_SEP = 1.2 | ||||||
|  |  | ||||||
| -- This holds the individual character widths. | -- This holds the individual character widths. | ||||||
| -- Indexed by the actual character (e.g. charwidth["A"]) | -- Indexed by the actual character (e.g. charwidth["A"]) | ||||||
| local charwidth = { } | local charwidth = { } | ||||||
| @@ -121,18 +130,12 @@ local function build_char_db() | |||||||
| 		end | 		end | ||||||
| 		cdbf:close() | 		cdbf:close() | ||||||
| 		if LINE_HEIGHT then | 		if LINE_HEIGHT then | ||||||
| 			-- XXX: Is there a better way to calc this? |  | ||||||
| 			-- XXX: Remember to change similar lines below if this changes. |  | ||||||
| 			SIGN_WIDTH = math.floor((total_width / char_count) * 16) |  | ||||||
| 			SIGN_PADDING = SIGN_WIDTH / 14 -- Totally arbitrary. |  | ||||||
|  |  | ||||||
| 			-- Check some random characters to see if the file on disk differs | 			-- Check some random characters to see if the file on disk differs | ||||||
| 			-- from the cached one. If so, then ditch cached data and rebuild | 			-- from the cached one. If so, then ditch cached data and rebuild | ||||||
| 			-- (font probably was changed). | 			-- (font probably was changed). | ||||||
| 			print("*** DEBUG: Randomly checking cache.") | 			print("*** DEBUG: Randomly checking cache.") | ||||||
| 			if not check_random_chars() then | 			if not check_random_chars() then | ||||||
| 				print("*** DEBUG: yey all ok.") | 				print("*** DEBUG: yey all ok.") | ||||||
| 				return |  | ||||||
| 			end | 			end | ||||||
| 			print("*** DEBUG: something's fucked up; rebuild cache.") | 			print("*** DEBUG: something's fucked up; rebuild cache.") | ||||||
| 		else | 		else | ||||||
| @@ -147,6 +150,7 @@ local function build_char_db() | |||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
|  | 	if not LINE_HEIGHT then | ||||||
| 		-- OK, something went wrong... try brute force loading from texture files. | 		-- OK, something went wrong... try brute force loading from texture files. | ||||||
|  |  | ||||||
| 		charwidth = { } | 		charwidth = { } | ||||||
| @@ -175,8 +179,12 @@ local function build_char_db() | |||||||
| 			error("Could not find font line height.") | 			error("Could not find font line height.") | ||||||
| 		end | 		end | ||||||
|  |  | ||||||
| 	SIGN_WIDTH = math.floor((total_width / char_count) * 16) | 	end | ||||||
| 	SIGN_PADDING = SIGN_WIDTH / 14 -- Totally arbitrary. |  | ||||||
|  | 	-- XXX: Is there a better way to calc this? | ||||||
|  | 	-- XXX: Remember to change similar lines below if this changes. | ||||||
|  | 	SIGN_WIDTH = math.floor((total_width / char_count) * CHARS_PER_LINE) | ||||||
|  | 	SIGN_PADDING = SIGN_WIDTH / 16 -- Totally arbitrary. | ||||||
|  |  | ||||||
| 	-- Try to save cached list back to disk. | 	-- Try to save cached list back to disk. | ||||||
|  |  | ||||||
| @@ -206,10 +214,10 @@ local signs = { | |||||||
| } | } | ||||||
|  |  | ||||||
| local signs_yard = { | local signs_yard = { | ||||||
|     {delta = {x =  0,     y = 0.05, z = -0.05}, yaw = 0}, |     {delta = {x =  0,     y = 0.15, z = -0.05}, yaw = 0}, | ||||||
|     {delta = {x = -0.05,  y = 0.05, z =  0}, yaw = math.pi / -2}, |     {delta = {x = -0.05,  y = 0.15, z =  0}, yaw = math.pi / -2}, | ||||||
|     {delta = {x =  0,     y = 0.05, z =  0.05}, yaw = math.pi}, |     {delta = {x =  0,     y = 0.15, z =  0.05}, yaw = math.pi}, | ||||||
|     {delta = {x =  0.05,  y = 0.05, z =  0}, yaw = math.pi / 2}, |     {delta = {x =  0.05,  y = 0.15, z =  0}, yaw = math.pi / 2}, | ||||||
| } | } | ||||||
|  |  | ||||||
| local signs_post = { | local signs_post = { | ||||||
| @@ -280,7 +288,7 @@ local homedecor_generate_line = function(s, lineno) | |||||||
| 		width = width + w + 1 | 		width = width + w + 1 | ||||||
| 		if width > max_line_w then | 		if width > max_line_w then | ||||||
| 			xpos = start_xpos | 			xpos = start_xpos | ||||||
| 			ypos = ypos + (LINE_HEIGHT * 1.05) | 			ypos = ypos + (LINE_HEIGHT * LINE_SEP) | ||||||
| 			width = 0 | 			width = 0 | ||||||
| 			lineno = lineno + 1 | 			lineno = lineno + 1 | ||||||
| 		end | 		end | ||||||
| @@ -303,7 +311,7 @@ local function copy ( t ) | |||||||
| end | end | ||||||
|  |  | ||||||
| local homedecor_generate_texture = function(lines) | local homedecor_generate_texture = function(lines) | ||||||
|     local texture = { ("[combine:%dx%d"):format(SIGN_WIDTH, SIGN_WIDTH) } |     local texture = { ("[combine:%dx%d"):format(SIGN_WIDTH, LINE_HEIGHT * NUMBER_OF_LINES * LINE_SEP) } | ||||||
|     local lineno = 0 |     local lineno = 0 | ||||||
|     for i = 1, #lines do |     for i = 1, #lines do | ||||||
| 		if lineno >= NUMBER_OF_LINES then break end | 		if lineno >= NUMBER_OF_LINES then break end | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user