Refactor books
This commit is contained in:
parent
17e7a95a39
commit
7adb8429ba
@ -53,6 +53,7 @@ These groups are mainly used for a better item sorting in Creative Mode.
|
|||||||
* `food`: Can be eaten by player. Rating: 2 = eatable, 3 = drinkable, 1 = unknown food type
|
* `food`: Can be eaten by player. Rating: 2 = eatable, 3 = drinkable, 1 = unknown food type
|
||||||
* `nav_compass`: Compass. Rating: 1 = normal compass, 2 = magnocompass
|
* `nav_compass`: Compass. Rating: 1 = normal compass, 2 = magnocompass
|
||||||
* `spawn_egg`: Item that spawns mobs
|
* `spawn_egg`: Item that spawns mobs
|
||||||
|
* `book`: Book. Rating: 1 = unspecific book, 2 = writable book
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,33 +19,51 @@ local F = minetest.formspec_escape
|
|||||||
local BOOK_MAX_TITLE_LENGTH = 64
|
local BOOK_MAX_TITLE_LENGTH = 64
|
||||||
local BOOK_MAX_TEXT_LENGTH = 4500
|
local BOOK_MAX_TEXT_LENGTH = 4500
|
||||||
|
|
||||||
|
local on_use = function(itemstack, player, pointed_thing)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local data = itemstack:get_meta()
|
||||||
|
|
||||||
|
local title = ""
|
||||||
|
local text = ""
|
||||||
|
|
||||||
|
if data then
|
||||||
|
text = data:get_string("book:text")
|
||||||
|
title = data:get_string("book:title")
|
||||||
|
end
|
||||||
|
|
||||||
|
local form = rp_formspec.get_page("rp_formspec:default")
|
||||||
|
form = form .. "field[0.5,1.25;8,0;title;"..F(S("Title:"))..";"..F(title).."]"
|
||||||
|
form = form .. "textarea[0.5,1.75;8,6.75;text;"..F(S("Contents:"))..";"..F(text).."]"
|
||||||
|
form = form .. rp_formspec.button_exit(2.75, 7.75, 3, 1, "write", S("Write"))
|
||||||
|
|
||||||
|
minetest.show_formspec(name, "rp_book:book", form)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Unwritten book (stackable)
|
||||||
|
minetest.register_craftitem(
|
||||||
|
":rp_default:book_empty",
|
||||||
|
{
|
||||||
|
description = S("Book"),
|
||||||
|
_tt_help = S("Write down some notes"),
|
||||||
|
inventory_image = "rp_book_book_empty.png",
|
||||||
|
groups = { book = 2, tool = 1 },
|
||||||
|
|
||||||
|
on_use = function(itemstack, player, pointed_thing)
|
||||||
|
on_use(itemstack, player, pointed_thing)
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Writable book (not stackable)
|
||||||
minetest.register_craftitem(
|
minetest.register_craftitem(
|
||||||
":rp_default:book",
|
":rp_default:book",
|
||||||
{
|
{
|
||||||
description = S("Unnamed Book"),
|
description = S("Unnamed Book"),
|
||||||
_tt_help = S("Write down some notes"),
|
|
||||||
inventory_image = "default_book.png",
|
inventory_image = "default_book.png",
|
||||||
stack_max = 1,
|
stack_max = 1,
|
||||||
groups = { tool = 1 },
|
groups = { book = 2, tool = 1, not_in_creative_inventory = 1 },
|
||||||
|
|
||||||
on_use = function(itemstack, player, pointed_thing)
|
on_use = function(itemstack, player, pointed_thing)
|
||||||
local name = player:get_player_name()
|
on_use(itemstack, player, pointed_thing)
|
||||||
local data = itemstack:get_meta()
|
|
||||||
|
|
||||||
local title = ""
|
|
||||||
local text = ""
|
|
||||||
|
|
||||||
if data then
|
|
||||||
text = data:get_string("book:text")
|
|
||||||
title = data:get_string("book:title")
|
|
||||||
end
|
|
||||||
|
|
||||||
local form = rp_formspec.get_page("rp_formspec:default")
|
|
||||||
form = form .. "field[0.5,1.25;8,0;title;"..F(S("Title:"))..";"..F(title).."]"
|
|
||||||
form = form .. "textarea[0.5,1.75;8,6.75;text;"..F(S("Contents:"))..";"..F(text).."]"
|
|
||||||
form = form .. rp_formspec.button_exit(2.75, 7.75, 3, 1, "write", S("Write"))
|
|
||||||
|
|
||||||
minetest.show_formspec(name, "rp_book:book", form)
|
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -55,22 +73,79 @@ minetest.register_on_player_receive_fields(
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local itemstack = player:get_wielded_item()
|
local wieldstack = player:get_wielded_item()
|
||||||
|
local iname = wieldstack:get_name()
|
||||||
|
if minetest.get_item_group(iname, "book") ~= 2 then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local meta = itemstack:get_meta()
|
local title = fields.title
|
||||||
|
local text = fields.text
|
||||||
|
|
||||||
-- Limit title and text length
|
-- Limit title and text length
|
||||||
if string.len(fields.title) > BOOK_MAX_TITLE_LENGTH then
|
if string.len(title) > BOOK_MAX_TITLE_LENGTH then
|
||||||
fields.title = string.sub(fields.title, 1, BOOK_MAX_TITLE_LENGTH)
|
title = string.sub(title, 1, BOOK_MAX_TITLE_LENGTH)
|
||||||
end
|
end
|
||||||
if string.len(fields.text) > BOOK_MAX_TEXT_LENGTH then
|
if string.len(text) > BOOK_MAX_TEXT_LENGTH then
|
||||||
fields.text= string.sub(fields.text, 1, BOOK_MAX_TEXT_LENGTH)
|
text= string.sub(text, 1, BOOK_MAX_TEXT_LENGTH)
|
||||||
end
|
end
|
||||||
|
|
||||||
meta:set_string("description", S("Book: “@1”", minetest.colorize("#ffff00", fields.title))) -- Set the item description
|
local function set_book_meta(item, title, text)
|
||||||
|
local meta = item:get_meta()
|
||||||
|
if title ~= "" then
|
||||||
|
meta:set_string("description", S("Book: “@1”", minetest.colorize("#ffff00", title))) -- Set the item description
|
||||||
|
else
|
||||||
|
meta:set_string("description", "")
|
||||||
|
end
|
||||||
|
meta:set_string("book:title", title)
|
||||||
|
meta:set_string("book:text", text)
|
||||||
|
end
|
||||||
|
|
||||||
meta:set_string("book:title", fields.title)
|
if wieldstack:get_name() ~= "rp_default:book" then
|
||||||
meta:set_string("book:text", fields.text)
|
if wieldstack:get_count() == 1 then
|
||||||
|
wieldstack:set_name("rp_default:book")
|
||||||
player:set_wielded_item(itemstack)
|
set_book_meta(wieldstack, title, text)
|
||||||
|
player:set_wielded_item(wieldstack)
|
||||||
|
else
|
||||||
|
local newstack = wieldstack:take_item()
|
||||||
|
newstack:set_count(1)
|
||||||
|
newstack:set_name("rp_default:book")
|
||||||
|
set_book_meta(newstack, title, text)
|
||||||
|
local inv = player:get_inventory()
|
||||||
|
if inv:room_for_item("main", newstack) then
|
||||||
|
inv:add_item("main", newstack)
|
||||||
|
else
|
||||||
|
minetest.add_item(player:get_pos(), newstack)
|
||||||
|
end
|
||||||
|
player:set_wielded_item(wieldstack)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
set_book_meta(wieldstack, title, text)
|
||||||
|
player:set_wielded_item(wieldstack)
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
minetest.register_craft(
|
||||||
|
{
|
||||||
|
type = "fuel",
|
||||||
|
recipe = "rp_default:book_empty",
|
||||||
|
burntime = 2,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft(
|
||||||
|
{
|
||||||
|
type = "fuel",
|
||||||
|
recipe = "rp_default:book",
|
||||||
|
burntime = 2,
|
||||||
|
})
|
||||||
|
|
||||||
|
crafting.register_craft(
|
||||||
|
{
|
||||||
|
output = "rp_default:book_empty",
|
||||||
|
items = {
|
||||||
|
"rp_default:paper 3",
|
||||||
|
"rp_default:stick",
|
||||||
|
"rp_default:fiber",
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
name = rp_book
|
name = rp_book
|
||||||
depends = rp_default, rp_formspec
|
depends = rp_crafting, rp_default, rp_formspec
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 197 B After Width: | Height: | Size: 139 B |
BIN
mods/rp_book/textures/rp_book_book_empty.png
Normal file
BIN
mods/rp_book/textures/rp_book_book_empty.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 131 B |
@ -180,13 +180,6 @@ minetest.register_craft(
|
|||||||
burntime = 12,
|
burntime = 12,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft(
|
|
||||||
{
|
|
||||||
type = "fuel",
|
|
||||||
recipe = "rp_default:book",
|
|
||||||
burntime = 2,
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_craft(
|
minetest.register_craft(
|
||||||
{
|
{
|
||||||
type = "fuel",
|
type = "fuel",
|
||||||
@ -549,16 +542,6 @@ crafting.register_craft(
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
crafting.register_craft(
|
|
||||||
{
|
|
||||||
output = "rp_default:book",
|
|
||||||
items = {
|
|
||||||
"rp_default:paper 3",
|
|
||||||
"rp_default:stick",
|
|
||||||
"rp_default:fiber",
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
crafting.register_craft(
|
crafting.register_craft(
|
||||||
{
|
{
|
||||||
output = "rp_default:flint_and_steel",
|
output = "rp_default:flint_and_steel",
|
||||||
@ -907,7 +890,7 @@ crafting.register_craft(
|
|||||||
{
|
{
|
||||||
output = "rp_default:bookshelf",
|
output = "rp_default:bookshelf",
|
||||||
items = {
|
items = {
|
||||||
"rp_default:book 3",
|
"rp_default:book_empty 3",
|
||||||
"group:planks 6",
|
"group:planks 6",
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -515,9 +515,9 @@ minetest.register_craftitem(
|
|||||||
{
|
{
|
||||||
description = S("Trading Book"),
|
description = S("Trading Book"),
|
||||||
_tt_help = S("Show this to a villager to trade"),
|
_tt_help = S("Show this to a villager to trade"),
|
||||||
inventory_image = "default_book.png^gold_bookribbon.png",
|
inventory_image = "gold_book.png^gold_bookribbon.png",
|
||||||
stack_max = 1,
|
stack_max = 1,
|
||||||
groups = { tool = 1 },
|
groups = { book = 1, tool = 1 },
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craftitem(
|
minetest.register_craftitem(
|
||||||
@ -577,7 +577,7 @@ crafting.register_craft(
|
|||||||
{
|
{
|
||||||
output = "rp_gold:trading_book",
|
output = "rp_gold:trading_book",
|
||||||
items = {
|
items = {
|
||||||
"rp_default:book",
|
"rp_default:book_empty",
|
||||||
"rp_gold:ingot_gold",
|
"rp_gold:ingot_gold",
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
BIN
mods/rp_gold/textures/gold_book.png
Normal file
BIN
mods/rp_gold/textures/gold_book.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 139 B |
@ -27,7 +27,7 @@ goodies.types["FURNACE_DST_general"] = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
goodies.types["BOOKSHELF"] = {
|
goodies.types["BOOKSHELF"] = {
|
||||||
["rp_default:book"] = { chance = 4, max_stack = 1 },
|
["rp_default:book_empty"] = { chance = 4, max_stack = 1 },
|
||||||
["rp_default:paper"] = 16,
|
["rp_default:paper"] = 16,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user