summaryrefslogtreecommitdiff
path: root/builtin
diff options
context:
space:
mode:
authorsapier <Sapier at GMX dot net>2014-06-19 18:17:35 +0200
committersapier <Sapier at GMX dot net>2014-07-16 15:02:56 +0200
commit65b8b524c02df853163fc1284a00a684a046d67c (patch)
tree2d5262f153efcd5740096edd690472a2b4eaa4a3 /builtin
parent903d343b08df17c88eafdd698af5b9f73ef6e389 (diff)
downloadminetest-65b8b524c02df853163fc1284a00a684a046d67c.tar.gz
minetest-65b8b524c02df853163fc1284a00a684a046d67c.tar.bz2
minetest-65b8b524c02df853163fc1284a00a684a046d67c.zip
Add srollbar formspec element
Diffstat (limited to 'builtin')
-rw-r--r--builtin/common/misc_helpers.lua57
-rw-r--r--builtin/mainmenu/tab_settings.lua66
2 files changed, 76 insertions, 47 deletions
diff --git a/builtin/common/misc_helpers.lua b/builtin/common/misc_helpers.lua
index e53ca373f..f57efc138 100644
--- a/builtin/common/misc_helpers.lua
+++ b/builtin/common/misc_helpers.lua
@@ -140,58 +140,58 @@ end
--------------------------------------------------------------------------------
function get_last_folder(text,count)
local parts = text:split(DIR_DELIM)
-
+
if count == nil then
return parts[#parts]
end
-
+
local retval = ""
for i=1,count,1 do
retval = retval .. parts[#parts - (count-i)] .. DIR_DELIM
end
-
+
return retval
end
--------------------------------------------------------------------------------
function cleanup_path(temppath)
-
+
local parts = temppath:split("-")
- temppath = ""
+ temppath = ""
for i=1,#parts,1 do
if temppath ~= "" then
temppath = temppath .. "_"
end
temppath = temppath .. parts[i]
end
-
+
parts = temppath:split(".")
- temppath = ""
+ temppath = ""
for i=1,#parts,1 do
if temppath ~= "" then
temppath = temppath .. "_"
end
temppath = temppath .. parts[i]
end
-
+
parts = temppath:split("'")
- temppath = ""
+ temppath = ""
for i=1,#parts,1 do
if temppath ~= "" then
temppath = temppath .. ""
end
temppath = temppath .. parts[i]
end
-
+
parts = temppath:split(" ")
- temppath = ""
+ temppath = ""
for i=1,#parts,1 do
if temppath ~= "" then
temppath = temppath
end
temppath = temppath .. parts[i]
end
-
+
return temppath
end
@@ -211,7 +211,7 @@ function core.splittext(text,charlimit)
local retval = {}
local current_idx = 1
-
+
local start,stop = string.find(text," ",current_idx)
local nl_start,nl_stop = string.find(text,"\n",current_idx)
local gotnewline = false
@@ -226,30 +226,30 @@ function core.splittext(text,charlimit)
table.insert(retval,last_line)
last_line = ""
end
-
+
if last_line ~= "" then
last_line = last_line .. " "
end
-
+
last_line = last_line .. string.sub(text,current_idx,stop -1)
-
+
if gotnewline then
table.insert(retval,last_line)
last_line = ""
gotnewline = false
end
current_idx = stop+1
-
+
start,stop = string.find(text," ",current_idx)
nl_start,nl_stop = string.find(text,"\n",current_idx)
-
+
if nl_start ~= nil and (start == nil or nl_start < start) then
start = nl_start
stop = nl_stop
gotnewline = true
end
end
-
+
--add last part of text
if string.len(last_line) + (string.len(text) - current_idx) > charlimit then
table.insert(retval,last_line)
@@ -258,7 +258,7 @@ function core.splittext(text,charlimit)
last_line = last_line .. " " .. string.sub(text,current_idx)
table.insert(retval,last_line)
end
-
+
return retval
end
@@ -400,6 +400,17 @@ function core.explode_textlist_event(evt)
return {type="INV", index=0}
end
+--------------------------------------------------------------------------------
+function core.explode_scrollbar_event(evt)
+ local retval = core.explode_textlist_event(evt)
+
+ retval.value = retval.index
+ retval.index = nil
+
+ return retval
+end
+
+--------------------------------------------------------------------------------
function core.pos_to_string(pos)
return "(" .. pos.x .. "," .. pos.y .. "," .. pos.z .. ")"
end
@@ -410,14 +421,14 @@ end
if INIT == "mainmenu" then
function core.get_game(index)
local games = game.get_games()
-
+
if index > 0 and index <= #games then
return games[index]
end
-
+
return nil
end
-
+
function fgettext(text, ...)
text = core.gettext(text)
local arg = {n=select('#', ...), ...}
diff --git a/builtin/mainmenu/tab_settings.lua b/builtin/mainmenu/tab_settings.lua
index dec28a961..2311978e0 100644
--- a/builtin/mainmenu/tab_settings.lua
+++ b/builtin/mainmenu/tab_settings.lua
@@ -75,29 +75,38 @@ local function showconfirm_reset(tabview)
new_dlg:show()
end
-local function gui_scale_index()
+local function gui_scale_to_scrollbar()
local current_value = tonumber(core.setting_get("gui_scaling"))
- if (current_value == nil) then
+ if (current_value == nil) or current_value < 0.25 then
return 0
- elseif current_value <= 0.5 then
- return 1
- elseif current_value <= 0.625 then
- return 2
- elseif current_value <= 0.75 then
- return 3
- elseif current_value <= 0.875 then
- return 4
- elseif current_value <= 1.0 then
- return 5
- elseif current_value <= 1.25 then
- return 6
- elseif current_value <= 1.5 then
- return 7
- else
- return 8
end
+
+ if current_value <= 1.25 then
+ return ((current_value - 0.25)/ 1.0) * 700
+ end
+
+ if current_value <= 6 then
+ return ((current_value -1.25) * 100) + 700
+ end
+
+ return 1000
+end
+
+local function scrollbar_to_gui_scale(value)
+
+ value = tonumber(value)
+
+ if (value <= 700) then
+ return ((value / 700) * 1.0) + 0.25
+ end
+
+ if (value <=1000) then
+ return ((value - 700) / 100) + 1.25
+ end
+
+ return 1
end
local function formspec(tabview, name, tabdata)
@@ -138,8 +147,11 @@ local function formspec(tabview, name, tabdata)
tab_string = tab_string ..
"box[0.75,4.25;3.25,1.25;#999999]" ..
"label[1,4.25;" .. fgettext("GUI scale factor") .. "]" ..
- "dropdown[1,4.75;3.0;dd_gui_scaling;0.5,0.625,0.75,0.875,1.0,1.25,1.5,2.0;"
- .. gui_scale_index() .. "]"
+ "scrollbar[1,4.75;2.75,0.4;sb_gui_scaling;horizontal;" ..
+ gui_scale_to_scrollbar() .. "]" ..
+ "tooltip[sb_gui_scaling;" ..
+ fgettext("Scaling factor applied to menu elements: ") ..
+ dump(core.setting_get("gui_scaling")) .. "]"
if ANDROID then
tab_string = tab_string ..
@@ -257,6 +269,16 @@ local function handle_settings_buttons(this, fields, tabname, tabdata)
core.show_keys_menu()
return true
end
+
+ if fields["sb_gui_scaling"] then
+ local event = core.explode_scrollbar_event(fields["sb_gui_scaling"])
+
+ if event.type == "CHG" then
+ local tosave = string.format("%.2f",scrollbar_to_gui_scale(event.value))
+ core.setting_set("gui_scaling",tosave)
+ return true
+ end
+ end
if fields["cb_touchscreen_target"] then
core.setting_set("touchtarget", fields["cb_touchscreen_target"])
return true
@@ -272,10 +294,6 @@ local function handle_settings_buttons(this, fields, tabname, tabdata)
core.setting_set("touchscreen_threshold",fields["dd_touchthreshold"])
ddhandled = true
end
- if fields["dd_gui_scaling"] then
- core.setting_set("gui_scaling",fields["dd_gui_scaling"])
- ddhandled = true
- end
return ddhandled
end