mirror of
https://github.com/minetest-mods/craftguide.git
synced 2024-11-26 20:43:42 +01:00
Formspec improvements (fixes #39)
This commit is contained in:
parent
44ebb84e89
commit
ed861ea1b9
109
init.lua
109
init.lua
@ -23,6 +23,7 @@ local MIN_LIMIT, MAX_LIMIT = 9, 12
|
|||||||
DEFAULT_SIZE = min(MAX_LIMIT, max(MIN_LIMIT, DEFAULT_SIZE))
|
DEFAULT_SIZE = min(MAX_LIMIT, max(MIN_LIMIT, DEFAULT_SIZE))
|
||||||
|
|
||||||
local GRID_LIMIT = 5
|
local GRID_LIMIT = 5
|
||||||
|
local BUTTON_SIZE = 1.1
|
||||||
|
|
||||||
local group_stereotypes = {
|
local group_stereotypes = {
|
||||||
wool = "wool:white",
|
wool = "wool:white",
|
||||||
@ -103,13 +104,16 @@ function craftguide:get_tooltip(item, recipe_type, cooktime, groups)
|
|||||||
return has_extras and tooltip .. "]" or ""
|
return has_extras and tooltip .. "]" or ""
|
||||||
end
|
end
|
||||||
|
|
||||||
function craftguide:get_recipe(iY, xoffset, recipe_num, recipes, show_usage)
|
function craftguide:get_recipe(iX, iY, xoffset, recipe_num, recipes, show_usage)
|
||||||
local formspec, recipes_total = "", #recipes
|
local formspec, recipes_total = "", #recipes
|
||||||
if recipes_total > 1 then
|
if recipes_total > 1 then
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"button[0," .. (iY + (sfinv_only and 3.8 or 3.3)) ..
|
"button[" .. (iX - (sfinv_only and 2 or 2.4)) .. "," ..
|
||||||
|
(iY + (sfinv_only and 3.9 or 3.3)) ..
|
||||||
";2,1;alternate;" .. S("Alternate") .. "]" ..
|
";2,1;alternate;" .. S("Alternate") .. "]" ..
|
||||||
"label[0," .. (iY + (sfinv_only and 3.3 or 2.8)) .. ";" ..
|
|
||||||
|
"label[" .. (iX - (sfinv_only and 2 or 2.4)) .. "," ..
|
||||||
|
(iY + (sfinv_only and 3.5 or 2.9)) .. ";" ..
|
||||||
(show_usage and S("Usage") or S("Recipe")) .. " " ..
|
(show_usage and S("Usage") or S("Recipe")) .. " " ..
|
||||||
S("@1 of @2", recipe_num, recipes_total) .. "]"
|
S("@1 of @2", recipe_num, recipes_total) .. "]"
|
||||||
end
|
end
|
||||||
@ -121,11 +125,15 @@ function craftguide:get_recipe(iY, xoffset, recipe_num, recipes, show_usage)
|
|||||||
if recipe_type == "cooking" or (recipe_type == "normal" and width == 0) then
|
if recipe_type == "cooking" or (recipe_type == "normal" and width == 0) then
|
||||||
local icon = recipe_type == "cooking" and "furnace" or "shapeless"
|
local icon = recipe_type == "cooking" and "furnace" or "shapeless"
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"image[" .. (xoffset - 0.8) .. "," .. (iY + (sfinv_only and 2.2 or 1.7)) ..
|
"image[" .. (xoffset + 0.2) .. "," ..
|
||||||
";0.5,0.5;craftguide_" .. icon .. ".png]"
|
(iY + (sfinv_only and 2.2 or 1.7)) ..
|
||||||
|
";0.5,0.5;craftguide_" .. icon .. ".png" ..
|
||||||
|
(icon == "shapeless" and "^[transformFX" or "") .. "]"
|
||||||
end
|
end
|
||||||
|
|
||||||
if width == 0 then
|
if recipe_type == "cooking" then
|
||||||
|
width = 1
|
||||||
|
elseif width == 0 then
|
||||||
width = min(3, #items)
|
width = min(3, #items)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -133,18 +141,17 @@ function craftguide:get_recipe(iY, xoffset, recipe_num, recipes, show_usage)
|
|||||||
|
|
||||||
if recipe_type == "normal" and (width > GRID_LIMIT or rows > GRID_LIMIT) then
|
if recipe_type == "normal" and (width > GRID_LIMIT or rows > GRID_LIMIT) then
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"label[" .. xoffset .. "," .. (iY + 2) .. ";" ..
|
"label[" .. (xoffset - 2.3) .. "," .. (iY + 2.2) .. ";" ..
|
||||||
S("Recipe is too big to\nbe displayed (@1x@2)", width, rows) .. "]"
|
S("Recipe is too big to\nbe displayed (@1x@2)", width, rows) .. "]"
|
||||||
else
|
else
|
||||||
local btn_size = 1
|
|
||||||
for i, v in pairs(items) do
|
for i, v in pairs(items) do
|
||||||
local X = (i - 1) % width + xoffset
|
local X = (i - 1) % width + xoffset - width
|
||||||
local Y = ceil(i / width + (iY + 2) - min(2, rows))
|
local Y = ceil(i / width + (iY + 2) - min(2, rows))
|
||||||
|
|
||||||
if recipe_type == "normal" and (width > 3 or rows > 3) then
|
if recipe_type == "normal" and (width > 3 or rows > 3) then
|
||||||
btn_size = width > 3 and 3 / width or 3 / rows
|
BUTTON_SIZE = width > 3 and 3 / width or 3 / rows
|
||||||
X = btn_size * (i % width) + xoffset
|
X = BUTTON_SIZE * (i % width) + xoffset - 3
|
||||||
Y = btn_size * floor((i - 1) / width) + (iY + 3) - min(2, rows)
|
Y = BUTTON_SIZE * floor((i - 1) / width) + (iY + 3) - min(2, rows)
|
||||||
end
|
end
|
||||||
|
|
||||||
local groups = extract_groups(v)
|
local groups = extract_groups(v)
|
||||||
@ -155,18 +162,40 @@ function craftguide:get_recipe(iY, xoffset, recipe_num, recipes, show_usage)
|
|||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"item_image_button[" .. X .. "," ..
|
"item_image_button[" .. X .. "," ..
|
||||||
(Y + (sfinv_only and 0.7 or 0.2)) .. ";" ..
|
(Y + (sfinv_only and 0.7 or 0.2)) .. ";" ..
|
||||||
btn_size .. "," .. btn_size .. ";" .. item_r ..
|
BUTTON_SIZE .. "," .. BUTTON_SIZE .. ";" .. item_r ..
|
||||||
";" .. item_r .. ";" .. label .. "]" .. tltip
|
";" .. item_r .. ";" .. label .. "]" .. tltip
|
||||||
end
|
end
|
||||||
|
|
||||||
|
BUTTON_SIZE = 1.1
|
||||||
end
|
end
|
||||||
|
|
||||||
local output = recipes[recipe_num].output:match("%S+")
|
local output = recipes[recipe_num].output:match("%S+")
|
||||||
return formspec ..
|
local output_is_fuel = get_fueltime(output) > 0
|
||||||
"image[" .. (xoffset - 1) .. "," .. (iY + (sfinv_only and 2.85 or 2.35)) ..
|
|
||||||
";0.9,0.7;craftguide_arrow.png]" ..
|
formspec = formspec ..
|
||||||
"item_image_button[" .. (xoffset - 2) .. "," ..
|
"image[" .. (xoffset + 0.08) .. "," ..
|
||||||
(iY + (sfinv_only and 2.7 or 2.2)) .. ";1,1;" ..
|
(iY + (sfinv_only and 2.85 or 2.35)) ..
|
||||||
output .. ";" .. output .. ";]" .. self:get_tooltip(output)
|
";0.9,0.7;craftguide_arrow.png^[transformFX]" ..
|
||||||
|
|
||||||
|
"item_image_button[" .. (xoffset + 1) .. "," ..
|
||||||
|
(iY + (sfinv_only and 2.7 or 2.2)) .. ";" ..
|
||||||
|
BUTTON_SIZE .. "," .. BUTTON_SIZE .. ";" ..
|
||||||
|
output .. ";" .. output .. ";]" ..
|
||||||
|
|
||||||
|
self:get_tooltip(output)
|
||||||
|
|
||||||
|
if output_is_fuel then
|
||||||
|
formspec = formspec ..
|
||||||
|
"image[" .. (xoffset + 2) .. "," ..
|
||||||
|
(iY + (sfinv_only and 2.83 or 2.33)) ..
|
||||||
|
";0.6,0.4;craftguide_arrow.png^[transformFX]" ..
|
||||||
|
|
||||||
|
"image[" .. (xoffset + 2.6) .. "," ..
|
||||||
|
(iY + (sfinv_only and 2.68 or 2.18)) ..
|
||||||
|
";0.6,0.6;craftguide_fire.png]"
|
||||||
|
end
|
||||||
|
|
||||||
|
return formspec
|
||||||
end
|
end
|
||||||
|
|
||||||
function craftguide:get_formspec(player_name, is_fuel)
|
function craftguide:get_formspec(player_name, is_fuel)
|
||||||
@ -187,8 +216,8 @@ function craftguide:get_formspec(player_name, is_fuel)
|
|||||||
"background[1,1;1,1;craftguide_bg.png;true]" ..
|
"background[1,1;1,1;craftguide_bg.png;true]" ..
|
||||||
"tooltip[size_inc;" .. S("Increase window size") .. "]" ..
|
"tooltip[size_inc;" .. S("Increase window size") .. "]" ..
|
||||||
"tooltip[size_dec;" .. S("Decrease window size") .. "]" ..
|
"tooltip[size_dec;" .. S("Decrease window size") .. "]" ..
|
||||||
"button[" .. (data.iX * 0.48) .. ",-0.02;0.7,1;size_inc;+]" ..
|
"button[" .. (data.iX * 0.48) .. ",0;0.7,1;size_inc;+]" ..
|
||||||
"button[" .. ((data.iX * 0.48) + 0.5) .. ",-0.02;0.7,1;size_dec;-]"
|
"button[" .. ((data.iX * 0.48) + 0.5) .. ",0;0.7,1;size_dec;-]"
|
||||||
end
|
end
|
||||||
|
|
||||||
formspec = formspec .. [[
|
formspec = formspec .. [[
|
||||||
@ -200,19 +229,19 @@ function craftguide:get_formspec(player_name, is_fuel)
|
|||||||
"tooltip[clear;" .. S("Reset") .. "]" ..
|
"tooltip[clear;" .. S("Reset") .. "]" ..
|
||||||
"tooltip[prev;" .. S("Previous page") .. "]" ..
|
"tooltip[prev;" .. S("Previous page") .. "]" ..
|
||||||
"tooltip[next;" .. S("Next page") .. "]" ..
|
"tooltip[next;" .. S("Next page") .. "]" ..
|
||||||
"button[" .. (data.iX - 3.1) .. ",0;0.8,0.95;prev;<]" ..
|
"button[" .. (data.iX - (sfinv_only and 2.6 or 3.1)) ..
|
||||||
"label[" .. (data.iX - 2.2) .. ",0.18;" ..
|
",0.03;0.8,0.95;prev;<]" ..
|
||||||
|
"label[" .. (data.iX - (sfinv_only and 1.7 or 2.2)) .. ",0.21;" ..
|
||||||
colorize(data.pagenum) .. " / " .. data.pagemax .. "]" ..
|
colorize(data.pagenum) .. " / " .. data.pagemax .. "]" ..
|
||||||
"button[" .. (data.iX - 1.2) .. ",0;0.8,0.95;next;>]" ..
|
"button[" .. (data.iX - (sfinv_only and 0.7 or 1.2) -
|
||||||
|
(data.iX >= 11 and 0.08 or 0)) .. ",0.03;0.8,0.95;next;>]" ..
|
||||||
"field[0.3,0.32;2.5,1;filter;;" .. mt.formspec_escape(data.filter) .. "]"
|
"field[0.3,0.32;2.5,1;filter;;" .. mt.formspec_escape(data.filter) .. "]"
|
||||||
|
|
||||||
local even_num = data.iX % 2 == 0
|
local xoffset = data.iX / 2.15
|
||||||
local xoffset = data.iX / 2 + (even_num and 0.5 or 0)
|
|
||||||
|
|
||||||
if not next(data.items) then
|
if not next(data.items) then
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"label[" .. (xoffset - (even_num and 1.5 or 1)) .. ",2;" ..
|
"label[" .. ((data.iX / 2) - 1) .. ",2;" .. S("No item to show") .. "]"
|
||||||
S("No item to show") .. "]"
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local first_item = (data.pagenum - 1) * ipp
|
local first_item = (data.pagenum - 1) * ipp
|
||||||
@ -223,27 +252,35 @@ function craftguide:get_formspec(player_name, is_fuel)
|
|||||||
local Y = (i % ipp - X) / data.iX + 1
|
local Y = (i % ipp - X) / data.iX + 1
|
||||||
|
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"item_image_button[" .. (X - (X * 0.05)) .. "," .. Y .. ";1.1,1.1;" ..
|
"item_image_button[" ..
|
||||||
|
(X - (sfinv_only and 0 or (X * 0.05))) .. "," ..
|
||||||
|
Y .. ";" .. BUTTON_SIZE .. "," .. BUTTON_SIZE .. ";" ..
|
||||||
name .. ";" .. name .. "_inv;]"
|
name .. ";" .. name .. "_inv;]"
|
||||||
end
|
end
|
||||||
|
|
||||||
if data.item and reg_items[data.item] then
|
if data.item and reg_items[data.item] then
|
||||||
if not data.recipes_item or (is_fuel and not get_recipe(data.item).items) then
|
if not data.recipes_item or (is_fuel and not get_recipe(data.item).items) then
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
"image[" .. (xoffset - 1) .. "," ..
|
"image[" .. (xoffset + 0.08) .. "," ..
|
||||||
(iY + (sfinv_only and 2.85 or 2.35)) ..
|
(iY + (sfinv_only and 2.85 or 2.35)) ..
|
||||||
";0.9,0.7;craftguide_arrow.png]" ..
|
";0.9,0.7;craftguide_arrow.png^[transformFX]" ..
|
||||||
"item_image_button[" .. xoffset .. "," ..
|
|
||||||
|
"item_image_button[" .. (xoffset - 1) .. "," ..
|
||||||
(iY + (sfinv_only and 2.7 or 2.2)) ..
|
(iY + (sfinv_only and 2.7 or 2.2)) ..
|
||||||
";1,1;" .. data.item .. ";" .. data.item .. ";]" ..
|
";" .. BUTTON_SIZE .. "," .. BUTTON_SIZE ..
|
||||||
|
";" .. data.item .. ";" .. data.item .. ";]" ..
|
||||||
|
|
||||||
self:get_tooltip(data.item) ..
|
self:get_tooltip(data.item) ..
|
||||||
"image[" .. (xoffset - 2) .. "," ..
|
|
||||||
|
"image[" .. (xoffset + 1) .. "," ..
|
||||||
(iY + (sfinv_only and 2.68 or 2.18)) ..
|
(iY + (sfinv_only and 2.68 or 2.18)) ..
|
||||||
";1,1;craftguide_fire.png]"
|
";1.1,1.1;craftguide_fire.png]"
|
||||||
else
|
else
|
||||||
local show_usage = data.show_usage
|
local show_usage = data.show_usage
|
||||||
formspec = formspec ..
|
formspec = formspec ..
|
||||||
self:get_recipe(iY, xoffset,
|
self:get_recipe(data.iX,
|
||||||
|
iY,
|
||||||
|
xoffset,
|
||||||
data.rnum,
|
data.rnum,
|
||||||
(show_usage and data.usages or data.recipes_item),
|
(show_usage and data.usages or data.recipes_item),
|
||||||
show_usage)
|
show_usage)
|
||||||
|
Loading…
Reference in New Issue
Block a user