Add uppercase letters, and add support for coloured stone bricks
This commit breaks nodes from the previous commits. As I haven't released it officially yet, I have not made allaises. You have been warned!
@ -1,2 +1,3 @@
|
|||||||
default
|
default
|
||||||
darkage?
|
darkage?
|
||||||
|
colouredstonebricks?
|
||||||
|
327
init.lua
@ -1,30 +1,30 @@
|
|||||||
letters = {
|
letters = {
|
||||||
{"a", "al"},
|
{"al", "au", "a", "A"},
|
||||||
{"b", "bl"},
|
{"bl", "bu", "b", "B"},
|
||||||
{"c", "cl"},
|
{"cl", "cu", "c", "C"},
|
||||||
{"d", "dl"},
|
{"dl", "du", "d", "D"},
|
||||||
{"e", "el"},
|
{"el", "eu", "e", "E"},
|
||||||
{"f", "fl"},
|
{"fl", "fu", "f", "F"},
|
||||||
{"g", "gl"},
|
{"gl", "gu", "g", "G"},
|
||||||
{"h", "hl"},
|
{"hl", "hu", "h", "H"},
|
||||||
{"i", "il"},
|
{"il", "iu", "i", "I"},
|
||||||
{"j", "jl"},
|
{"jl", "ju", "j", "J"},
|
||||||
{"k", "kl"},
|
{"kl", "ku", "k", "K"},
|
||||||
{"l", "ll"},
|
{"ll", "lu", "l", "L"},
|
||||||
{"m", "ml"},
|
{"ml", "mu", "m", "M"},
|
||||||
{"n", "nl"},
|
{"nl", "nu", "n", "N"},
|
||||||
{"o", "ol"},
|
{"ol", "ou", "o", "O"},
|
||||||
{"p", "pl"},
|
{"pl", "pu", "p", "P"},
|
||||||
{"q", "ql"},
|
{"ql", "qu", "q", "Q"},
|
||||||
{"r", "rl"},
|
{"rl", "ru", "r", "R"},
|
||||||
{"s", "sl"},
|
{"sl", "su", "s", "S"},
|
||||||
{"t", "tl"},
|
{"tl", "tu", "t", "T"},
|
||||||
{"u", "ul"},
|
{"ul", "uu", "u", "U"},
|
||||||
{"v", "vl"},
|
{"vl", "vu", "v", "V"},
|
||||||
{"w", "wl"},
|
{"wl", "wu", "w", "W"},
|
||||||
{"x", "xl"},
|
{"xl", "xu", "x", "X"},
|
||||||
{"y", "yl"},
|
{"yl", "yu", "y", "Y"},
|
||||||
{"z", "zl"},
|
{"zl", "zu", "z", "Z"},
|
||||||
}
|
}
|
||||||
|
|
||||||
letter_cutter = {}
|
letter_cutter = {}
|
||||||
@ -32,16 +32,39 @@ letter_cutter.known_nodes = {}
|
|||||||
|
|
||||||
function letters.register_letters(modname, subname, from_node, description, tiles)
|
function letters.register_letters(modname, subname, from_node, description, tiles)
|
||||||
for _, row in ipairs(letters) do
|
for _, row in ipairs(letters) do
|
||||||
local name = subname.. "_letter_" ..row[1]
|
local namel = subname.. "_letter_" ..row[1]
|
||||||
local desc = description.. " " ..row[1]
|
local nameu = subname.. "_letter_" ..row[2]
|
||||||
local tiles = tiles.. "^letters_" ..row[2].. "_overlay.png^[makealpha:255,126,126"
|
local descl = description.. " " ..row[3]
|
||||||
|
local descu = description.. " " ..row[4]
|
||||||
|
local tilesl = tiles.. "^letters_" ..row[1].. "_overlay.png^[makealpha:255,126,126"
|
||||||
|
local tilesu = tiles.. "^letters_" ..row[2].. "_overlay.png^[makealpha:255,126,126"
|
||||||
local groups = {not_in_creative_inventory=1, not_in_craft_guide=1, oddly_breakable_by_hand=1, attached_node=1}
|
local groups = {not_in_creative_inventory=1, not_in_craft_guide=1, oddly_breakable_by_hand=1, attached_node=1}
|
||||||
minetest.register_node(":" ..modname..":"..name, {
|
minetest.register_node(":" ..modname..":"..namel, {
|
||||||
description = desc,
|
description = descl,
|
||||||
drawtype = "signlike",
|
drawtype = "signlike",
|
||||||
tiles = {tiles},
|
tiles = {tilesl},
|
||||||
inventory_image = tiles,
|
inventory_image = tilesl,
|
||||||
wield_image = tiles,
|
wield_image = tilesl,
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "wallmounted",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
is_ground_content = false,
|
||||||
|
walkable = false,
|
||||||
|
selection_box = {
|
||||||
|
type = "wallmounted",
|
||||||
|
--wall_top = <default>
|
||||||
|
--wall_bottom = <default>
|
||||||
|
--wall_side = <default>
|
||||||
|
},
|
||||||
|
groups = groups,
|
||||||
|
legacy_wallmounted = false,
|
||||||
|
})
|
||||||
|
minetest.register_node(":" ..modname..":"..nameu, {
|
||||||
|
description = descu,
|
||||||
|
drawtype = "signlike",
|
||||||
|
tiles = {tilesu},
|
||||||
|
inventory_image = tilesu,
|
||||||
|
wield_image = tilesu,
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "wallmounted",
|
paramtype2 = "wallmounted",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
@ -70,43 +93,86 @@ end
|
|||||||
|
|
||||||
cost = 0.110
|
cost = 0.110
|
||||||
|
|
||||||
letter_cutter.names = {
|
letter_cutter.names_lower = {
|
||||||
{"letter_a"},
|
{"letter_al"},
|
||||||
{"letter_b"},
|
{"letter_bl"},
|
||||||
{"letter_c"},
|
{"letter_cl"},
|
||||||
{"letter_d"},
|
{"letter_dl"},
|
||||||
{"letter_e"},
|
{"letter_el"},
|
||||||
{"letter_f"},
|
{"letter_fl"},
|
||||||
{"letter_g"},
|
{"letter_gl"},
|
||||||
{"letter_h"},
|
{"letter_hl"},
|
||||||
{"letter_i"},
|
{"letter_il"},
|
||||||
{"letter_j"},
|
{"letter_jl"},
|
||||||
{"letter_k"},
|
{"letter_kl"},
|
||||||
{"letter_l"},
|
{"letter_ll"},
|
||||||
{"letter_m"},
|
{"letter_ml"},
|
||||||
{"letter_n"},
|
{"letter_nl"},
|
||||||
{"letter_o"},
|
{"letter_ol"},
|
||||||
{"letter_p"},
|
{"letter_pl"},
|
||||||
{"letter_q"},
|
{"letter_ql"},
|
||||||
{"letter_r"},
|
{"letter_rl"},
|
||||||
{"letter_s"},
|
{"letter_sl"},
|
||||||
{"letter_t"},
|
{"letter_tl"},
|
||||||
{"letter_u"},
|
{"letter_ul"},
|
||||||
{"letter_v"},
|
{"letter_vl"},
|
||||||
{"letter_w"},
|
{"letter_wl"},
|
||||||
{"letter_x"},
|
{"letter_xl"},
|
||||||
{"letter_y"},
|
{"letter_yl"},
|
||||||
{"letter_z"},
|
{"letter_zl"},
|
||||||
}
|
}
|
||||||
|
|
||||||
function letter_cutter:get_output_inv(modname, subname, amount, max)
|
letter_cutter.names_upper = {
|
||||||
|
{"letter_au"},
|
||||||
|
{"letter_bu"},
|
||||||
|
{"letter_cu"},
|
||||||
|
{"letter_du"},
|
||||||
|
{"letter_eu"},
|
||||||
|
{"letter_fu"},
|
||||||
|
{"letter_gu"},
|
||||||
|
{"letter_hu"},
|
||||||
|
{"letter_iu"},
|
||||||
|
{"letter_ju"},
|
||||||
|
{"letter_ku"},
|
||||||
|
{"letter_lu"},
|
||||||
|
{"letter_mu"},
|
||||||
|
{"letter_nu"},
|
||||||
|
{"letter_ou"},
|
||||||
|
{"letter_pu"},
|
||||||
|
{"letter_qu"},
|
||||||
|
{"letter_ru"},
|
||||||
|
{"letter_su"},
|
||||||
|
{"letter_tu"},
|
||||||
|
{"letter_uu"},
|
||||||
|
{"letter_vu"},
|
||||||
|
{"letter_wu"},
|
||||||
|
{"letter_xu"},
|
||||||
|
{"letter_yu"},
|
||||||
|
{"letter_zu"},
|
||||||
|
}
|
||||||
|
|
||||||
|
function letter_cutter:get_output_inv_lower(modname, subname, amount, max)
|
||||||
|
|
||||||
local list = {}
|
local list = {}
|
||||||
if amount < 1 then
|
if amount < 1 then
|
||||||
return list
|
return list
|
||||||
end
|
end
|
||||||
|
|
||||||
for i, t in ipairs(letter_cutter.names) do
|
for i, t in ipairs(letter_cutter.names_lower) do
|
||||||
|
table.insert(list, modname .. ":" .. subname .. "_" .. t[1]
|
||||||
|
.. " " .. math.min(math.floor(amount/cost), max))
|
||||||
|
end
|
||||||
|
return list
|
||||||
|
end
|
||||||
|
|
||||||
|
function letter_cutter:get_output_inv_upper(modname, subname, amount, max)
|
||||||
|
|
||||||
|
local list = {}
|
||||||
|
if amount < 1 then
|
||||||
|
return list
|
||||||
|
end
|
||||||
|
|
||||||
|
for i, t in ipairs(letter_cutter.names_upper) do
|
||||||
table.insert(list, modname .. ":" .. subname .. "_" .. t[1]
|
table.insert(list, modname .. ":" .. subname .. "_" .. t[1]
|
||||||
.. " " .. math.min(math.floor(amount/cost), max))
|
.. " " .. math.min(math.floor(amount/cost), max))
|
||||||
end
|
end
|
||||||
@ -126,7 +192,7 @@ function letter_cutter:reset(pos)
|
|||||||
meta:get_string("owner")..")")
|
meta:get_string("owner")..")")
|
||||||
end
|
end
|
||||||
|
|
||||||
function letter_cutter:update_inventory(pos, amount)
|
function letter_cutter:update_inventory_lower(pos, amount)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
|
|
||||||
@ -154,7 +220,7 @@ function letter_cutter:update_inventory(pos, amount)
|
|||||||
|
|
||||||
-- Display:
|
-- Display:
|
||||||
inv:set_list("output",
|
inv:set_list("output",
|
||||||
self:get_output_inv(modname, material, amount,
|
self:get_output_inv_lower(modname, material, amount,
|
||||||
meta:get_int("max_offered")))
|
meta:get_int("max_offered")))
|
||||||
-- Store how many microblocks are available:
|
-- Store how many microblocks are available:
|
||||||
meta:set_int("anz", amount)
|
meta:set_int("anz", amount)
|
||||||
@ -164,17 +230,43 @@ function letter_cutter:update_inventory(pos, amount)
|
|||||||
meta:get_string("owner")..")")
|
meta:get_string("owner")..")")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function letter_cutter:update_inventory_upper(pos, amount)
|
||||||
--[[ The amount of items offered per shape can be configured:
|
|
||||||
function letter_cutter.on_receive_fields(pos, formname, fields, sender)
|
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local max = tonumber(fields.max_offered)
|
local inv = meta:get_inventory()
|
||||||
if max and max > 0 then
|
|
||||||
meta:set_string("max_offered", max)
|
amount = meta:get_int("anz") + amount
|
||||||
-- Update to show the correct number of items:
|
|
||||||
letter_cutter:update_inventory(pos, 0)
|
if amount < 1 then -- If the last block is taken out.
|
||||||
|
self:reset(pos)
|
||||||
|
return
|
||||||
end
|
end
|
||||||
end]]
|
|
||||||
|
local stack = inv:get_stack("input", 1)
|
||||||
|
if stack:is_empty() then
|
||||||
|
self:reset(pos)
|
||||||
|
return
|
||||||
|
|
||||||
|
end
|
||||||
|
local node_name = stack:get_name() or ""
|
||||||
|
local name_parts = letter_cutter.known_nodes[node_name] or ""
|
||||||
|
local modname = name_parts[1] or ""
|
||||||
|
local material = name_parts[2] or ""
|
||||||
|
|
||||||
|
inv:set_list("input", {
|
||||||
|
node_name.. " " .. math.floor(amount)
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Display:
|
||||||
|
inv:set_list("output",
|
||||||
|
self:get_output_inv_upper(modname, material, amount,
|
||||||
|
meta:get_int("max_offered")))
|
||||||
|
-- Store how many microblocks are available:
|
||||||
|
meta:set_int("anz", amount)
|
||||||
|
|
||||||
|
meta:set_string("infotext",
|
||||||
|
"Letter Cutter is working (owned by "..
|
||||||
|
meta:get_string("owner")..")")
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
function letter_cutter.allow_metadata_inventory_move(
|
function letter_cutter.allow_metadata_inventory_move(
|
||||||
@ -211,7 +303,7 @@ function letter_cutter.allow_metadata_inventory_put(
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function letter_cutter.on_metadata_inventory_put(
|
function letter_cutter.on_metadata_inventory_put_lower(
|
||||||
pos, listname, index, stack, player)
|
pos, listname, index, stack, player)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
@ -219,18 +311,42 @@ function letter_cutter.on_metadata_inventory_put(
|
|||||||
local count = stack:get_count()
|
local count = stack:get_count()
|
||||||
|
|
||||||
if listname == "input" then
|
if listname == "input" then
|
||||||
letter_cutter:update_inventory(pos, count)
|
letter_cutter:update_inventory_lower(pos, count)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function letter_cutter.on_metadata_inventory_take(
|
function letter_cutter.on_metadata_inventory_put_upper(
|
||||||
|
pos, listname, index, stack, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local inv = meta:get_inventory()
|
||||||
|
local stackname = stack:get_name()
|
||||||
|
local count = stack:get_count()
|
||||||
|
|
||||||
|
if listname == "input" then
|
||||||
|
letter_cutter:update_inventory_upper(pos, count)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function letter_cutter.on_metadata_inventory_take_lower(
|
||||||
pos, listname, index, stack, player)
|
pos, listname, index, stack, player)
|
||||||
if listname == "output" then
|
if listname == "output" then
|
||||||
-- We do know how much each block at each position costs:
|
-- We do know how much each block at each position costs:
|
||||||
letter_cutter:update_inventory(pos, 8 * -cost)
|
letter_cutter:update_inventory_lower(pos, 8 * -cost)
|
||||||
elseif listname == "input" then
|
elseif listname == "input" then
|
||||||
-- Each normal (= full) block taken costs 8 microblocks:
|
-- Each normal (= full) block taken costs 8 microblocks:
|
||||||
letter_cutter:update_inventory(pos, 8 * -stack:get_count())
|
letter_cutter:update_inventory_lower(pos, 8 * -stack:get_count())
|
||||||
|
end
|
||||||
|
-- The recycle field plays no role here since it is processed immediately.
|
||||||
|
end
|
||||||
|
|
||||||
|
function letter_cutter.on_metadata_inventory_take_upper(
|
||||||
|
pos, listname, index, stack, player)
|
||||||
|
if listname == "output" then
|
||||||
|
-- We do know how much each block at each position costs:
|
||||||
|
letter_cutter:update_inventory_upper(pos, 8 * -cost)
|
||||||
|
elseif listname == "input" then
|
||||||
|
-- Each normal (= full) block taken costs 8 microblocks:
|
||||||
|
letter_cutter:update_inventory_upper(pos, 8 * -stack:get_count())
|
||||||
end
|
end
|
||||||
-- The recycle field plays no role here since it is processed immediately.
|
-- The recycle field plays no role here since it is processed immediately.
|
||||||
end
|
end
|
||||||
@ -266,7 +382,7 @@ function letter_cutter.can_dig(pos,player)
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_node("letters:letter_cutter", {
|
minetest.register_node("letters:letter_cutter_lower", {
|
||||||
description = "Leter Cutter",
|
description = "Leter Cutter",
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
node_box = {
|
node_box = {
|
||||||
@ -309,8 +425,55 @@ minetest.register_node("letters:letter_cutter", {
|
|||||||
allow_metadata_inventory_put = letter_cutter.allow_metadata_inventory_put,
|
allow_metadata_inventory_put = letter_cutter.allow_metadata_inventory_put,
|
||||||
-- Taking is allowed from all slots (even the internal microblock slot). Moving is forbidden.
|
-- Taking is allowed from all slots (even the internal microblock slot). Moving is forbidden.
|
||||||
-- Putting something in is slightly more complicated than taking anything because we have to make sure it is of a suitable material:
|
-- Putting something in is slightly more complicated than taking anything because we have to make sure it is of a suitable material:
|
||||||
on_metadata_inventory_put = letter_cutter.on_metadata_inventory_put,
|
on_metadata_inventory_put = letter_cutter.on_metadata_inventory_put_lower,
|
||||||
on_metadata_inventory_take = letter_cutter.on_metadata_inventory_take,
|
on_metadata_inventory_take = letter_cutter.on_metadata_inventory_take_lower,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("letters:letter_cutter_upper", {
|
||||||
|
description = "Leter Cutter",
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.4375, -0.5, -0.4375, -0.3125, 0.125, -0.3125}, -- NodeBox1
|
||||||
|
{-0.4375, -0.5, 0.3125, -0.3125, 0.125, 0.4375}, -- NodeBox2
|
||||||
|
{0.3125, -0.5, 0.3125, 0.4375, 0.125, 0.4375}, -- NodeBox3
|
||||||
|
{0.3125, -0.5, -0.4375, 0.4375, 0.125, -0.3125}, -- NodeBox4
|
||||||
|
{-0.5, 0.0625, -0.5, 0.5, 0.25, 0.5}, -- NodeBox5
|
||||||
|
{0.125, 0.25, -0.1875, 0.3125, 0.3125, -0.125}, -- NodeBox6
|
||||||
|
{-0.125, 0.25, -0.125, 0.125, 0.3125, -0.0625}, -- NodeBox7
|
||||||
|
{-0.3125, 0.25, -0.0625, -0.0625, 0.3125, 0.0625}, -- NodeBox8
|
||||||
|
{-0.125, 0.25, 0.0625, 0.125, 0.3125, 0.125}, -- NodeBox9
|
||||||
|
{0.125, 0.25, 0.125, 0.3125, 0.3125, 0.1875}, -- NodeBox10
|
||||||
|
{0.125, 0.25, -0.125, 0.1875, 0.3125, 0.125}, -- NodeBox11
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tiles = {"letters_letter_cutter_top.png",
|
||||||
|
"default_tree.png",
|
||||||
|
"letters_letter_cutter_side.png"},
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {choppy = 2,oddly_breakable_by_hand = 2},
|
||||||
|
sounds = default.node_sound_wood_defaults(),
|
||||||
|
on_construct = letter_cutter.on_construct,
|
||||||
|
can_dig = letter_cutter.can_dig,
|
||||||
|
-- Set the owner of this circular saw.
|
||||||
|
after_place_node = function(pos, placer)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local owner = placer and placer:get_player_name() or ""
|
||||||
|
meta:set_string("owner", owner)
|
||||||
|
meta:set_string("infotext",
|
||||||
|
"Letter Cutter is empty (owned by "
|
||||||
|
..meta:get_string("owner")..")")
|
||||||
|
end,
|
||||||
|
allow_metadata_inventory_move = letter_cutter.allow_metadata_inventory_move,
|
||||||
|
-- Only input- and recycle-slot are intended as input slots:
|
||||||
|
allow_metadata_inventory_put = letter_cutter.allow_metadata_inventory_put,
|
||||||
|
-- Taking is allowed from all slots (even the internal microblock slot). Moving is forbidden.
|
||||||
|
-- Putting something in is slightly more complicated than taking anything because we have to make sure it is of a suitable material:
|
||||||
|
on_metadata_inventory_put = letter_cutter.on_metadata_inventory_put_upper,
|
||||||
|
on_metadata_inventory_take = letter_cutter.on_metadata_inventory_take_upper,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
@ -17,3 +17,20 @@ if minetest.get_modpath("darkage") then
|
|||||||
letters.register_letters("darkage", "marble_tile", "darkage:marble_tile", "Marble Tile", "darkage_marble_tile.png")
|
letters.register_letters("darkage", "marble_tile", "darkage:marble_tile", "Marble Tile", "darkage_marble_tile.png")
|
||||||
letters.register_letters("darkage", "slate_tile", "darkage:slate_tile", "Slate Tile", "darkage_slate_tile.png")
|
letters.register_letters("darkage", "slate_tile", "darkage:slate_tile", "Slate Tile", "darkage_slate_tile.png")
|
||||||
end
|
end
|
||||||
|
if minetest.get_modpath("colouredstonebricks") then
|
||||||
|
letters.register_letters("colouredstonebricks", "black", "colouredstonebricks:black", "Black", "colouredstonebricks_black.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "cyan", "colouredstonebricks:cyan", "Cyan", "colouredstonebricks_cyan.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "brown", "colouredstonebricks:brown", "Brown", "colouredstonebricks_brown.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "dark_blue", "colouredstonebricks:dark_blue", "Dark Blue", "colouredstonebricks_dark_blue.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "dark_green", "colouredstonebricks:dark_green", "Dark Green", "colouredstonebricks_dark_green.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "dark_grey", "colouredstonebricks:dark_grey", "Dark Gey", "colouredstonebricks_dark_grey.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "dark_pink", "colouredstonebricks:dark_pink", "Dark Pink", "colouredstonebricks_dark_pink.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "green", "colouredstonebricks:green", "Green", "colouredstonebricks_green.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "grey", "colouredstonebricks:grey", "Grey", "colouredstonebricks_grey.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "orange", "colouredstonebricks:orange", "Orange", "colouredstonebricks_orange.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "pink", "colouredstonebricks:pink", "Pink", "colouredstonebricks_pink.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "purple", "colouredstonebricks:purple", "Purple", "colouredstonebricks_purple.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "red", "colouredstonebricks:red", "Red", "colouredstonebricks_red.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "white", "colouredstonebricks:white", "White", "colouredstonebricks_white.png")
|
||||||
|
letters.register_letters("colouredstonebricks", "yellow", "colouredstonebricks:yellow", "Yellow", "colouredstonebricks_yellow.png")
|
||||||
|
end
|
||||||
|
BIN
textures/letters_au_overlay.png
Normal file
After Width: | Height: | Size: 200 B |
BIN
textures/letters_bu_overlay.png
Normal file
After Width: | Height: | Size: 194 B |
BIN
textures/letters_cu_overlay.png
Normal file
After Width: | Height: | Size: 201 B |
BIN
textures/letters_du_overlay.png
Normal file
After Width: | Height: | Size: 186 B |
BIN
textures/letters_eu_overlay.png
Normal file
After Width: | Height: | Size: 179 B |
BIN
textures/letters_fu_overlay.png
Normal file
After Width: | Height: | Size: 176 B |
BIN
textures/letters_gu_overlay.png
Normal file
After Width: | Height: | Size: 213 B |
BIN
textures/letters_hu_overlay.png
Normal file
After Width: | Height: | Size: 191 B |
BIN
textures/letters_iu_overlay.png
Normal file
After Width: | Height: | Size: 172 B |
BIN
textures/letters_ju_overlay.png
Normal file
After Width: | Height: | Size: 169 B |
BIN
textures/letters_ku_overlay.png
Normal file
After Width: | Height: | Size: 203 B |
BIN
textures/letters_lu_overlay.png
Normal file
After Width: | Height: | Size: 169 B |
BIN
textures/letters_mu_overlay.png
Normal file
After Width: | Height: | Size: 204 B |
BIN
textures/letters_nu_overlay.png
Normal file
After Width: | Height: | Size: 191 B |
BIN
textures/letters_ou_overlay.png
Normal file
After Width: | Height: | Size: 189 B |
BIN
textures/letters_pu_overlay.png
Normal file
After Width: | Height: | Size: 186 B |
BIN
textures/letters_qu_overlay.png
Normal file
After Width: | Height: | Size: 202 B |
BIN
textures/letters_ru_overlay.png
Normal file
After Width: | Height: | Size: 192 B |
BIN
textures/letters_su_overlay.png
Normal file
After Width: | Height: | Size: 209 B |
BIN
textures/letters_tu_overlay.png
Normal file
After Width: | Height: | Size: 172 B |
BIN
textures/letters_uu_overlay.png
Normal file
After Width: | Height: | Size: 180 B |
BIN
textures/letters_vu_overlay.png
Normal file
After Width: | Height: | Size: 202 B |
BIN
textures/letters_wu_overlay.png
Normal file
After Width: | Height: | Size: 208 B |
BIN
textures/letters_xu_overlay.png
Normal file
After Width: | Height: | Size: 211 B |
BIN
textures/letters_yu_overlay.png
Normal file
After Width: | Height: | Size: 197 B |
BIN
textures/letters_zu_overlay.png
Normal file
After Width: | Height: | Size: 199 B |