mirror of
https://github.com/minetest-mods/skinsdb.git
synced 2025-01-22 13:50:27 +01:00
started work on skin_meta_api
This commit is contained in:
parent
b267cf2657
commit
28d28390ce
33
api.lua
33
api.lua
@ -1,18 +1,25 @@
|
|||||||
-- get current skin
|
-- get current skin
|
||||||
skins.get_player_skin = function(player)
|
skins.get_player_skin = function(player)
|
||||||
local skin = player:get_attribute("skin")
|
local skin = player:get_attribute("skin")
|
||||||
if not skins.textures[skin] then
|
return skins.get(skin) or skins.get(skins.default)
|
||||||
skin = skins.default
|
|
||||||
end
|
|
||||||
return skin
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Set skin
|
-- Set skin
|
||||||
skins.set_player_skin = function(player, skin)
|
skins.set_player_skin = function(player, skin)
|
||||||
if skin == skins.default then
|
local skin_obj
|
||||||
skin = ""
|
local skin_key
|
||||||
|
if type(skin) == "string" then
|
||||||
|
skin_obj = skins.get(skin) or skins.get(skins.default)
|
||||||
|
else
|
||||||
|
skin_obj = skin
|
||||||
end
|
end
|
||||||
player:set_attribute("skin", skin)
|
skin_key = skin:get_meta("_key")
|
||||||
|
|
||||||
|
if skin_key == skins.default then
|
||||||
|
skin_key = ""
|
||||||
|
end
|
||||||
|
|
||||||
|
player:set_attribute("skin", skin_key)
|
||||||
skins.update_player_skin(player)
|
skins.update_player_skin(player)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -20,7 +27,7 @@ end
|
|||||||
skins.update_player_skin = function(player)
|
skins.update_player_skin = function(player)
|
||||||
local skin = skins.get_player_skin(player)
|
local skin = skins.get_player_skin(player)
|
||||||
player:set_properties({
|
player:set_properties({
|
||||||
textures = {skins.textures[skin]},
|
textures = {skin:get_texture()},
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -28,13 +35,3 @@ end
|
|||||||
minetest.register_on_joinplayer(function(player)
|
minetest.register_on_joinplayer(function(player)
|
||||||
skins.update_player_skin(player)
|
skins.update_player_skin(player)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
-- 3d_armor compatibility
|
|
||||||
if minetest.global_exists("armor") then
|
|
||||||
armor.get_player_skin = function(self, name)
|
|
||||||
return skins.get_player_skin(minetest.get_player_by_name(name))
|
|
||||||
end
|
|
||||||
armor.get_preview = function(self, name)
|
|
||||||
return skins.preview[skins.get_player_skin(minetest.get_player_by_name(name))]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
13
init.lua
13
init.lua
@ -9,6 +9,7 @@ skins = {}
|
|||||||
skins.modpath = minetest.get_modpath(minetest.get_current_modname())
|
skins.modpath = minetest.get_modpath(minetest.get_current_modname())
|
||||||
skins.default = "character_1"
|
skins.default = "character_1"
|
||||||
|
|
||||||
|
dofile(skins.modpath.."skin_meta_api.lua")
|
||||||
dofile(skins.modpath.."/api.lua")
|
dofile(skins.modpath.."/api.lua")
|
||||||
dofile(skins.modpath.."/skinlist.lua")
|
dofile(skins.modpath.."/skinlist.lua")
|
||||||
|
|
||||||
@ -20,3 +21,15 @@ end
|
|||||||
if minetest.get_modpath("sfinv") then
|
if minetest.get_modpath("sfinv") then
|
||||||
dofile(skins.modpath.."/sfinv_page.lua")
|
dofile(skins.modpath.."/sfinv_page.lua")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- 3d_armor compatibility
|
||||||
|
if minetest.global_exists("armor") then
|
||||||
|
armor.get_player_skin = function(self, name)
|
||||||
|
local skin = skins.get_player_skin(minetest.get_player_by_name(name))
|
||||||
|
return skin:get_meta("_key") --3d_armor adds a ".png" but it should be compatible in most cases
|
||||||
|
end
|
||||||
|
armor.get_preview = function(self, name)
|
||||||
|
local skin = skins.get_player_skin(minetest.get_player_by_name(name))
|
||||||
|
return skin:get_meta("preview")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
@ -6,16 +6,13 @@ else
|
|||||||
end
|
end
|
||||||
|
|
||||||
local dropdown_values = {}
|
local dropdown_values = {}
|
||||||
local skins_reftab = {}
|
--local skins_reftab = {} --skins.list
|
||||||
local skins_reftab_byskin = {}
|
|
||||||
|
|
||||||
-- collect skins data
|
-- collect skins data
|
||||||
local total_pages = 1
|
local total_pages = 1
|
||||||
for i, skin in ipairs(skins.list) do
|
for i, skin in ipairs(skins.list) do
|
||||||
local page = math.floor((i-1) / 16)+1
|
skin:set_meta("inv_page", math.floor((i-1) / 16)+1)
|
||||||
local index_p = (i-1)%16+1
|
skin:set_meta("inv_page_index", (i-1)%16+1)
|
||||||
skins_reftab[i] = { index = i, page = page, index_p = index_p, skin = skin }
|
|
||||||
skins_reftab_byskin[skin] = skins_reftab[i]
|
|
||||||
total_pages = page
|
total_pages = page
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -25,37 +22,37 @@ local function get_formspec(player, context)
|
|||||||
local skin = skins.get_player_skin(player)
|
local skin = skins.get_player_skin(player)
|
||||||
|
|
||||||
-- overview page
|
-- overview page
|
||||||
local formspec = "image[0,.75;1,2;"..skins.preview[skin].."]"
|
local formspec = "image[0,.75;1,2;"..skin:get_preview().."]"
|
||||||
.."label[6,.5;"..S("Raw texture")..":]"
|
.."label[6,.5;"..S("Raw texture")..":]"
|
||||||
.."image[6,1;2,1;"..skins.textures[skin].."]"
|
.."image[6,1;2,1;"..skin:get_texture().."]"
|
||||||
|
|
||||||
local meta = skins.meta[skin]
|
local m_name = skin:get_meta_string("name")
|
||||||
if meta then
|
local m_author = skin:get_meta_string("author")
|
||||||
if meta.name ~= "" then
|
local m_license = skin:get_meta_string("license")
|
||||||
formspec = formspec.."label[2,.5;"..S("Name")..": "..minetest.formspec_escape(meta.name).."]"
|
if m_name ~= "" then
|
||||||
|
formspec = formspec.."label[2,.5;"..S("Name")..": "..minetest.formspec_escape(m_name).."]"
|
||||||
end
|
end
|
||||||
if meta.author ~= "" then
|
if m_author ~= "" then
|
||||||
formspec = formspec.."label[2,1;"..S("Author")..": "..minetest.formspec_escape(meta.author).."]"
|
formspec = formspec.."label[2,1;"..S("Author")..": "..minetest.formspec_escape(m_author).."]"
|
||||||
end
|
|
||||||
if meta.license ~= "" then
|
|
||||||
formspec = formspec.."label[2,1.5;"..S("License")..": "..minetest.formspec_escape(meta.license).."]"
|
|
||||||
end
|
|
||||||
if meta.description ~= "" then --what's that??
|
|
||||||
formspec = formspec.."label[2,2;"..S("Description")..": "..minetest.formspec_escape(meta.description).."]"
|
|
||||||
end
|
end
|
||||||
|
if m_license ~= "" then
|
||||||
|
formspec = formspec.."label[2,1.5;"..S("License")..": "..minetest.formspec_escape(m_license).."]"
|
||||||
end
|
end
|
||||||
|
|
||||||
local page = 1
|
local page = 1
|
||||||
if context.skins_page then
|
if context.skins_page then
|
||||||
page = context.skins_page
|
page = context.skins_page
|
||||||
elseif skins_reftab_byskin[skin] then
|
else
|
||||||
page = skins_reftab_byskin[skin].page
|
page = skin:get_meta("inv_page") or 1
|
||||||
end
|
end
|
||||||
|
|
||||||
for i = (page-1)*16+1, page*16 do
|
for i = (page-1)*16+1, page*16 do
|
||||||
if not skins_reftab[i] then
|
local skin = skins.list[i]
|
||||||
|
if not skin then
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
local index_p = skins_reftab[i].index_p
|
|
||||||
|
local index_p = skin:get_meta("inv_page_index")
|
||||||
local x = (index_p-1) % 8
|
local x = (index_p-1) % 8
|
||||||
local y
|
local y
|
||||||
if index_p > 8 then
|
if index_p > 8 then
|
||||||
@ -64,8 +61,8 @@ local function get_formspec(player, context)
|
|||||||
y = 3.2
|
y = 3.2
|
||||||
end
|
end
|
||||||
formspec = formspec.."image_button["..x..","..y..";1,2;"..
|
formspec = formspec.."image_button["..x..","..y..";1,2;"..
|
||||||
skins.preview[skins_reftab[i].skin]..";skins_set$"..i..";]"..
|
skin:get_preview()..";skins_set$"..i..";]"..
|
||||||
"tooltip[skins_set$"..i..";"..minetest.formspec_escape(skins.meta[skins_reftab[i].skin].name).."]"
|
"tooltip[skins_set$"..i..";"..minetest.formspec_escape(skin:get_meta_string("name")).."]"
|
||||||
end
|
end
|
||||||
local page_prev = page - 1
|
local page_prev = page - 1
|
||||||
local page_next = page + 1
|
local page_next = page + 1
|
||||||
@ -100,7 +97,7 @@ sfinv.register_page("skins:overview", {
|
|||||||
for field, _ in pairs(fields) do
|
for field, _ in pairs(fields) do
|
||||||
local current = string.split(field, "$", 2)
|
local current = string.split(field, "$", 2)
|
||||||
if current[1] == "skins_set" then
|
if current[1] == "skins_set" then
|
||||||
skins.set_player_skin(player, skins_reftab[tonumber(current[2])].skin)
|
skins.set_player_skin(player, skins.list[tonumber(current[2])])
|
||||||
sfinv.set_player_inventory_formspec(player)
|
sfinv.set_player_inventory_formspec(player)
|
||||||
return
|
return
|
||||||
elseif current[1] == "skins_page" then
|
elseif current[1] == "skins_page" then
|
||||||
|
56
skin_meta_api.lua
Normal file
56
skin_meta_api.lua
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
skins.meta = {}
|
||||||
|
|
||||||
|
local skin_class = {}
|
||||||
|
skin_class.__index = skin_class
|
||||||
|
-----------------------
|
||||||
|
-- Class methods
|
||||||
|
-----------------------
|
||||||
|
-- constructor
|
||||||
|
function skins.new(key, object)
|
||||||
|
assert(key, 'Unique skins key required, like "character_1"')
|
||||||
|
local self = object or {}
|
||||||
|
setmetatable(self, skin_class)
|
||||||
|
self.__index = skin_class
|
||||||
|
|
||||||
|
self._key, key)
|
||||||
|
self._sort_id = 0
|
||||||
|
skins.meta[key]
|
||||||
|
return self
|
||||||
|
end
|
||||||
|
|
||||||
|
-- getter
|
||||||
|
function skins.get(key)
|
||||||
|
return skins.meta[key]
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Skin methods
|
||||||
|
-- In this implementation it is just access to attrubutes wrapped
|
||||||
|
-- but this way allow to redefine the functionality for more complex skins provider
|
||||||
|
function skin_class:set_meta(key, value)
|
||||||
|
self[key] = value
|
||||||
|
end
|
||||||
|
|
||||||
|
function skin_class:get_meta(key)
|
||||||
|
return self[key]
|
||||||
|
end
|
||||||
|
|
||||||
|
function skin_class:get_meta_string(key)
|
||||||
|
return tostring(self[key] or "")
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function skin_class:set_texture(value)
|
||||||
|
self._texture = value
|
||||||
|
end
|
||||||
|
|
||||||
|
function skin_class:get_texture()
|
||||||
|
return self._texture
|
||||||
|
end
|
||||||
|
|
||||||
|
function skin_class:set_preview(value)
|
||||||
|
self._preview = value
|
||||||
|
end
|
||||||
|
|
||||||
|
function skin_class:get_preview()
|
||||||
|
return self._preview or "player.png"
|
||||||
|
end
|
22
skinlist.lua
22
skinlist.lua
@ -1,7 +1,4 @@
|
|||||||
skins.list = {}
|
skins.list = {}
|
||||||
skins.textures = {}
|
|
||||||
skins.meta = {}
|
|
||||||
skins.preview = {}
|
|
||||||
|
|
||||||
local skins_dir_list = minetest.get_dir_list(skins.modpath.."/textures")
|
local skins_dir_list = minetest.get_dir_list(skins.modpath.."/textures")
|
||||||
local unsorted_skinslist = {}
|
local unsorted_skinslist = {}
|
||||||
@ -10,26 +7,25 @@ for _, fn in pairs(skins_dir_list) do
|
|||||||
nameparts = string.gsub(fn, "[.]", "_"):split("_")
|
nameparts = string.gsub(fn, "[.]", "_"):split("_")
|
||||||
local id = nameparts[2]
|
local id = nameparts[2]
|
||||||
local name = "character_"..id
|
local name = "character_"..id
|
||||||
|
local skin_obj = skins.get(name) or skins.new(new)
|
||||||
if nameparts[3] == "preview" then
|
if nameparts[3] == "preview" then
|
||||||
skins.preview[name] = fn
|
skin_obj:set_preview(fn)
|
||||||
else
|
else
|
||||||
local file = io.open(skins.modpath.."/meta/"..name..".txt", "r")
|
local file = io.open(skins.modpath.."/meta/"..name..".txt", "r")
|
||||||
if file then
|
if file then
|
||||||
local data = string.split(file:read("*all"), "\n", 3)
|
local data = string.split(file:read("*all"), "\n", 3)
|
||||||
file:close()
|
file:close()
|
||||||
table.insert(unsorted_skinslist, {id = tonumber(id) or id, name = name})
|
skin_obj:set_texture(fn)
|
||||||
skins.textures[name] = fn
|
skin_obj:set_meta("_sort_id", tonumber(id))
|
||||||
skins.meta[name] = {}
|
skin_obj:set_meta("name", data[1])
|
||||||
skins.meta[name].name = data[1]
|
skin_obj:set_meta("author", data[2])
|
||||||
skins.meta[name].author = data[2]
|
skin_obj:set_meta("license", data[3])
|
||||||
skins.meta[name].license = data[3]
|
|
||||||
skins.meta[name].description = "" --what's that??
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
table.sort(unsorted_skinslist, function(a,b) return a.id < b.id end)
|
table.sort(unsorted_skinslist, function(a,b) return a:get_meta("_sort_id") < b:get_meta("_sort_id") end)
|
||||||
for _,v in ipairs(unsorted_skinslist) do
|
for _,v in ipairs(unsorted_skinslist) do
|
||||||
table.insert(skins.list, v.name)
|
table.insert(skins.list, v)
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user