diff options
author | bell07 <web.alexander@web.de> | 2018-05-14 19:38:56 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-14 19:38:56 +0200 |
commit | e761999946c623db364d0681c9bcfae90d4d0d6a (patch) | |
tree | d6920747b7358451dfb8b674b30fd8d4b37ac9a7 | |
parent | b12aefbe4fe768106ee1d1dfac8567dbbcd8c273 (diff) | |
parent | e6516d298284b6a64af2bce7c6df5be2ba4eb964 (diff) |
Merge pull request #13 from bell07/master
Visual update fixes if skin change externally
-rw-r--r-- | API.md | 15 | ||||
-rw-r--r-- | api.lua | 15 | ||||
-rw-r--r-- | init.lua | 1 | ||||
-rw-r--r-- | skin_meta_api.lua | 5 |
4 files changed, 20 insertions, 16 deletions
@@ -1,20 +1,17 @@ # Skinsdb Interface ## skins.get_player_skin(player) -Return the skin object assigned to the player. Returns defaout if nothins assigned +Return the skin object assigned to the player. Returns default if nothing assigned ## skins.assign_player_skin(player, skin) -Select the skin for the player. The "skin" parameter could be the skin key or the skin object +Check if allowed and assign the skin for the player without visual updates. The "skin" parameter could be the skin key or the skin object Returns false if skin is not valid or applicable to player ## skins.update_player_skin(player) Update selected skin visuals on player ## skins.set_player_skin(player, skin) -``` -skins.assign_player_skin(player, skin) -skins.update_player_skin(player) -``` +Function for external usage on skin selection. This function assign the skin, call the skin:set_skin(player) hook to update dynamic skins, then update the visuals ## skins.get_skin_format(file) Returns the skin format version ("1.0" or "1.8"). File is an open file handle to the texture file @@ -67,11 +64,11 @@ Get the skin preview Could be redefined for dynamic preview texture generation ## skin:set_skin(player) -Apply the skin to the player and do some resets. -Is called if skin selection started, in skins.update_player_skin() for examlpe +Hook for dynamic skins updates on select. Is called in skins.set_player_skin() +In skinsdb the default implementation for this function is empty. skin:apply_skin_to_player(player) -Apply the skin to the player. Is called in set_skin() and other places the skin needs to be updated +Apply the skin to the player. Called in skins.update_player_skin() to update visuals ## skin:set_meta(key, value) Add a meta information to the skin object @@ -31,14 +31,23 @@ end -- update visuals function skins.update_player_skin(player) - local skin = skins.get_player_skin(player) - skin:set_skin(player) + if skins.armor_loaded then + -- all needed is wrapped and implemented in 3d_armor mod + armor:set_player_armor(player) + else + -- do updates manually without 3d_armor + skins.get_player_skin(player):apply_skin_to_player(player) + if minetest.global_exists("sfinv") and sfinv.enabled then + sfinv.set_player_inventory_formspec(player) + end + end end --- Assign and update +-- Assign and update - should be used on selection externally function skins.set_player_skin(player, skin) local success = skins.assign_player_skin(player, skin) if success then + skins.get_player_skin(player):set_skin(player) skins.update_player_skin(player) end return success @@ -32,6 +32,7 @@ end -- 3d_armor compatibility if minetest.global_exists("armor") then + skins.armor_loaded = true armor.get_player_skin = function(self, name) local skin = skins.get_player_skin(minetest.get_player_by_name(name)) return skin:get_texture() diff --git a/skin_meta_api.lua b/skin_meta_api.lua index f8a92e2..c08573f 100644 --- a/skin_meta_api.lua +++ b/skin_meta_api.lua @@ -59,8 +59,6 @@ function skin_class:get_preview() return self._preview or "player.png" end -local armor_loaded = minetest.global_exists("armor") - function skin_class:apply_skin_to_player(player) local ver = self:get_meta("format") or "1.0" default.player_set_model(player, "skinsdb_3d_armor_character.b3d") @@ -76,7 +74,7 @@ function skin_class:apply_skin_to_player(player) v10_texture = self:get_texture() end - if armor_loaded then + if skins.armor_loaded then local armor_textures = armor.textures[player:get_player_name()] if armor_textures then armor_texture = armor_textures.armor @@ -103,7 +101,6 @@ function skin_class:set_skin(player) -- The set_skin is used on skins selection -- This means the method could be redefined to start an furmslec -- See character_creator for example - self:apply_skin_to_player(player) end function skin_class:is_applicable_for_player(playername) |