Disable game bar and header on Android (#7940)

This commit is contained in:
rubenwardy 2018-12-06 23:32:15 +00:00 committed by Paramat
parent 08884d258b
commit 0c6933bdf7

View File

@ -15,73 +15,82 @@
--with this program; if not, write to the Free Software Foundation, Inc., --with this program; if not, write to the Free Software Foundation, Inc.,
--51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. --51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
local function current_game()
local last_game_id = core.settings:get("menu_last_game")
local game, index = pkgmgr.find_by_gameid(last_game_id)
return game local enable_gamebar = PLATFORM ~= "Android"
end local current_game, singleplayer_refresh_gamebar
if enable_gamebar then
function current_game()
local last_game_id = core.settings:get("menu_last_game")
local game, index = pkgmgr.find_by_gameid(last_game_id)
local function singleplayer_refresh_gamebar() return game
local old_bar = ui.find_by_name("game_button_bar")
if old_bar ~= nil then
old_bar:delete()
end end
local function game_buttonbar_button_handler(fields) function singleplayer_refresh_gamebar()
for key,value in pairs(fields) do
for j=1,#pkgmgr.games,1 do local old_bar = ui.find_by_name("game_button_bar")
if ("game_btnbar_" .. pkgmgr.games[j].id == key) then
mm_texture.update("singleplayer", pkgmgr.games[j]) if old_bar ~= nil then
core.set_topleft_text(pkgmgr.games[j].name) old_bar:delete()
core.settings:set("menu_last_game",pkgmgr.games[j].id) end
menudata.worldlist:set_filtercriteria(pkgmgr.games[j].id)
local index = filterlist.get_current_index(menudata.worldlist, local function game_buttonbar_button_handler(fields)
tonumber(core.settings:get("mainmenu_last_selected_world"))) for key,value in pairs(fields) do
if not index or index < 1 then for j=1,#pkgmgr.games,1 do
local selected = core.get_textlist_index("sp_worlds") if ("game_btnbar_" .. pkgmgr.games[j].id == key) then
if selected ~= nil and selected < #menudata.worldlist:get_list() then mm_texture.update("singleplayer", pkgmgr.games[j])
index = selected core.set_topleft_text(pkgmgr.games[j].name)
else core.settings:set("menu_last_game",pkgmgr.games[j].id)
index = #menudata.worldlist:get_list() menudata.worldlist:set_filtercriteria(pkgmgr.games[j].id)
local index = filterlist.get_current_index(menudata.worldlist,
tonumber(core.settings:get("mainmenu_last_selected_world")))
if not index or index < 1 then
local selected = core.get_textlist_index("sp_worlds")
if selected ~= nil and selected < #menudata.worldlist:get_list() then
index = selected
else
index = #menudata.worldlist:get_list()
end
end end
menu_worldmt_legacy(index)
return true
end end
menu_worldmt_legacy(index)
return true
end end
end end
end end
end
local btnbar = buttonbar_create("game_button_bar", local btnbar = buttonbar_create("game_button_bar",
game_buttonbar_button_handler, game_buttonbar_button_handler,
{x=-0.3,y=5.9}, "horizontal", {x=12.4,y=1.15}) {x=-0.3,y=5.9}, "horizontal", {x=12.4,y=1.15})
for i=1,#pkgmgr.games,1 do for i=1,#pkgmgr.games,1 do
local btn_name = "game_btnbar_" .. pkgmgr.games[i].id local btn_name = "game_btnbar_" .. pkgmgr.games[i].id
local image = nil local image = nil
local text = nil local text = nil
local tooltip = core.formspec_escape(pkgmgr.games[i].name) local tooltip = core.formspec_escape(pkgmgr.games[i].name)
if pkgmgr.games[i].menuicon_path ~= nil and if pkgmgr.games[i].menuicon_path ~= nil and
pkgmgr.games[i].menuicon_path ~= "" then pkgmgr.games[i].menuicon_path ~= "" then
image = core.formspec_escape(pkgmgr.games[i].menuicon_path) image = core.formspec_escape(pkgmgr.games[i].menuicon_path)
else else
local part1 = pkgmgr.games[i].id:sub(1,5) local part1 = pkgmgr.games[i].id:sub(1,5)
local part2 = pkgmgr.games[i].id:sub(6,10) local part2 = pkgmgr.games[i].id:sub(6,10)
local part3 = pkgmgr.games[i].id:sub(11) local part3 = pkgmgr.games[i].id:sub(11)
text = part1 .. "\n" .. part2 text = part1 .. "\n" .. part2
if part3 ~= nil and if part3 ~= nil and
part3 ~= "" then part3 ~= "" then
text = text .. "\n" .. part3 text = text .. "\n" .. part3
end
end end
btnbar:add_button(btn_name, text, image, tooltip)
end end
btnbar:add_button(btn_name, text, image, tooltip) end
else
function current_game()
return nil
end end
end end
@ -200,10 +209,10 @@ local function main_button_handler(this, fields, name, tabdata)
if core.settings:get_bool("enable_server") then if core.settings:get_bool("enable_server") then
if selected ~= nil and gamedata.selected_world ~= 0 then if selected ~= nil and gamedata.selected_world ~= 0 then
gamedata.playername = fields["te_playername"] gamedata.playername = fields["te_playername"]
gamedata.password = fields["te_passwd"] gamedata.password = fields["te_passwd"]
gamedata.port = fields["te_serverport"] gamedata.port = fields["te_serverport"]
gamedata.address = "" gamedata.address = ""
core.settings:set("port",gamedata.port) core.settings:set("port",gamedata.port)
if fields["te_serveraddr"] ~= nil then if fields["te_serveraddr"] ~= nil then
@ -239,7 +248,7 @@ local function main_button_handler(this, fields, name, tabdata)
create_world_dlg:set_parent(this) create_world_dlg:set_parent(this)
this:hide() this:hide()
create_world_dlg:show() create_world_dlg:show()
mm_texture.update("singleplayer",current_game()) mm_texture.update("singleplayer", current_game())
return true return true
end end
@ -282,28 +291,31 @@ local function main_button_handler(this, fields, name, tabdata)
end end
end end
local function on_change(type, old_tab, new_tab) local on_change
local buttonbar = ui.find_by_name("game_button_bar") if enable_gamebar then
function on_change(type, old_tab, new_tab)
local buttonbar = ui.find_by_name("game_button_bar")
if ( buttonbar == nil ) then if ( buttonbar == nil ) then
singleplayer_refresh_gamebar() singleplayer_refresh_gamebar()
buttonbar = ui.find_by_name("game_button_bar") buttonbar = ui.find_by_name("game_button_bar")
end end
if (type == "ENTER") then if (type == "ENTER") then
local game = current_game() local game = current_game()
if game then if game then
menudata.worldlist:set_filtercriteria(game.id) menudata.worldlist:set_filtercriteria(game.id)
core.set_topleft_text(game.name) core.set_topleft_text(game.name)
mm_texture.update("singleplayer",game) mm_texture.update("singleplayer",game)
end
buttonbar:show()
else
menudata.worldlist:set_filtercriteria(nil)
buttonbar:hide()
core.set_topleft_text("")
mm_texture.update(new_tab,nil)
end end
buttonbar:show()
else
menudata.worldlist:set_filtercriteria(nil)
buttonbar:hide()
core.set_topleft_text("")
mm_texture.update(new_tab,nil)
end end
end end