Compare commits
No commits in common. "0205ea58e38fabd300a7c00692974120902cbfad" and "e8b796f978c13e2d32612b5ce6965bbbee85e078" have entirely different histories.
0205ea58e3
...
e8b796f978
13 changed files with 111 additions and 108 deletions
|
@ -1,4 +1,4 @@
|
||||||
local Rect = require "birb.classes.2D.rect"
|
local Rect = require "birb.objects.2D.rect"
|
||||||
|
|
||||||
local GuiElement = Rect:extend()
|
local GuiElement = Rect:extend()
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local Rect = require "birb.classes.2D.rect"
|
local Rect = require "birb.objects.2D.rect"
|
||||||
|
|
||||||
local BaseActor = require("birb.modules.world.actors.mixins.base")
|
local BaseActor = require("birb.modules.world.actors.mixins.base")
|
||||||
local SpritedActor = require("birb.modules.world.actors.mixins.sprites")
|
local SpritedActor = require("birb.modules.world.actors.mixins.sprites")
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local BasicBox = require "birb.classes.3D.box"
|
local BasicBox = require "birb.objects.3D.box"
|
||||||
|
|
||||||
local BaseActor = require("birb.modules.world.actors.mixins.base")
|
local BaseActor = require("birb.modules.world.actors.mixins.base")
|
||||||
local SpritedActor = require("birb.modules.world.actors.mixins.sprites")
|
local SpritedActor = require("birb.modules.world.actors.mixins.sprites")
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local Rect = require "birb.classes.2D.rect"
|
local Rect = require "birb.objects.2D.rect"
|
||||||
local IndexedRect = Rect:extend()
|
local IndexedRect = Rect:extend()
|
||||||
|
|
||||||
function IndexedRect:new(origin, ox, oy, w, h)
|
function IndexedRect:new(origin, ox, oy, w, h)
|
|
@ -21,7 +21,7 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local Point = require "birb.classes.2D.point"
|
local Point = require "birb.objects.2D.point"
|
||||||
local Rect = Point:extend()
|
local Rect = Point:extend()
|
||||||
|
|
||||||
function Rect:new(x, y, w, h)
|
function Rect:new(x, y, w, h)
|
|
@ -21,7 +21,7 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local Point = require "birb.classes.3D.point3D"
|
local Point = require "birb.objects.3D.point3D"
|
||||||
local Box = Point:extend()
|
local Box = Point:extend()
|
||||||
|
|
||||||
function Box:new(x, y, z, w, h, d)
|
function Box:new(x, y, z, w, h, d)
|
|
@ -23,7 +23,7 @@
|
||||||
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
]]
|
]]
|
||||||
|
|
||||||
local Rect = require "birb.classes.2D.rect"
|
local Rect = require "birb.objects.2D.rect"
|
||||||
local IndexedRect = Rect:extend()
|
local IndexedRect = Rect:extend()
|
||||||
|
|
||||||
function IndexedRect:new(origin, ox, oy, oz, w, h, d)
|
function IndexedRect:new(origin, ox, oy, oz, w, h, d)
|
|
@ -1,8 +0,0 @@
|
||||||
local consts = {}
|
|
||||||
|
|
||||||
consts.OPTION_MENU = "optionMenu"
|
|
||||||
consts.BORDERS_W = 96
|
|
||||||
consts.BORDERS_H = 24
|
|
||||||
consts.NBR_ELEMS = 8
|
|
||||||
|
|
||||||
return consts
|
|
|
@ -24,12 +24,10 @@
|
||||||
local Scene = require "birb.modules.scenes"
|
local Scene = require "birb.modules.scenes"
|
||||||
local OptionsMenu = Scene:extend()
|
local OptionsMenu = Scene:extend()
|
||||||
|
|
||||||
|
local ListBox = require "birb.modules.menusystem.menus.listbox"
|
||||||
local Widgets = require "scenes.menus.options.widgets"
|
local Widgets = require "scenes.menus.options.widgets"
|
||||||
local Menu = require "scenes.menus.options.menu"
|
|
||||||
|
|
||||||
local consts = require "scenes.menus.options.consts"
|
function OptionsMenu:new()
|
||||||
|
|
||||||
function OptionsMenu:start()
|
|
||||||
OptionsMenu.super.new(self)
|
OptionsMenu.super.new(self)
|
||||||
self.assets:addImageFont("medium", "assets/fonts/medium")
|
self.assets:addImageFont("medium", "assets/fonts/medium")
|
||||||
self.assets:setMusic("assets/music/options.ogg")
|
self.assets:setMusic("assets/music/options.ogg")
|
||||||
|
@ -40,31 +38,26 @@ function OptionsMenu:start()
|
||||||
|
|
||||||
self.assets:playMusic()
|
self.assets:playMusic()
|
||||||
|
|
||||||
self.menu = Menu("medium");
|
self:addMenu("main", true)
|
||||||
|
|
||||||
self:addSubMenu("video", "video")
|
self:addSubMenu("video", "video")
|
||||||
Widgets.Resolution(self, "video")
|
|
||||||
Widgets.Switch("fullscreen")
|
|
||||||
Widgets.Switch("borders")
|
|
||||||
Widgets.Switch("vsync")
|
|
||||||
|
|
||||||
self:addSubMenu("audio", "audio")
|
self:addSubMenu("audio", "audio")
|
||||||
Widgets.Audio("sfx")
|
|
||||||
Widgets.Audio("music")
|
|
||||||
|
|
||||||
self:addSubMenu("langs", "langs")
|
self:addSubMenu("langs", "langs")
|
||||||
|
|
||||||
self:setLanguageMenu()
|
|
||||||
|
|
||||||
self:addSubMenu("inputs", "inputs")
|
self:addSubMenu("inputs", "inputs")
|
||||||
|
|
||||||
|
Widgets.Resolution(self, "video")
|
||||||
|
Widgets.Switch(self, "video", "fullscreen")
|
||||||
|
Widgets.Switch(self, "video", "borders")
|
||||||
|
Widgets.Switch(self, "video", "vsync")
|
||||||
|
|
||||||
self:addPlayerMenus()
|
self:addPlayerMenus()
|
||||||
|
|
||||||
local menu = self.menusystem.menus[consts.OPTION_MENU]
|
self:setLanguageMenu()
|
||||||
menu:switch("main")
|
|
||||||
|
Widgets.Audio(self, "audio", "sfx")
|
||||||
|
Widgets.Audio(self, "audio", "music")
|
||||||
|
|
||||||
Widgets.Exit(self, "main")
|
Widgets.Exit(self, "main")
|
||||||
self.menusystem:switchMenu(consts.OPTION_MENU)
|
self.menusystem:switchMenu("main")
|
||||||
|
|
||||||
self.menusystem:setSoundFromSceneAssets("navigate")
|
self.menusystem:setSoundFromSceneAssets("navigate")
|
||||||
|
|
||||||
|
@ -76,19 +69,29 @@ end
|
||||||
-- Functions that serve the handling of menus
|
-- Functions that serve the handling of menus
|
||||||
|
|
||||||
function OptionsMenu:addMenu(name, nobackbutton)
|
function OptionsMenu:addMenu(name, nobackbutton)
|
||||||
Menu("medium")
|
local screenHeight, screenWidth = core.screen:getDimensions()
|
||||||
|
local w, h = 424/2, 240 - 48
|
||||||
|
local x, y = w / 2, 24
|
||||||
|
ListBox(self.menusystem, name, x, y, w, h, 8)
|
||||||
end
|
end
|
||||||
|
|
||||||
function OptionsMenu:addSubMenu(name, fullname)
|
function OptionsMenu:addSubMenu(name, fullname)
|
||||||
local menu = self.menusystem.menus[consts.OPTION_MENU]
|
self:addMenu(name)
|
||||||
menu:addSubmenu(name, core.lang:translate("options", fullname), "main")
|
Widgets.SubMenu(self, "main", name, fullname)
|
||||||
|
Widgets.SubMenu(self, name, "main", "back", 1, "<")
|
||||||
end
|
end
|
||||||
|
|
||||||
function OptionsMenu:addPlayerMenus()
|
function OptionsMenu:addPlayerMenus()
|
||||||
for key, _ in pairs(core.input.data[1].keys) do
|
for i,v in ipairs(core.input.data) do
|
||||||
-- FIXME: make sure that you can use the order you want for the keys list
|
local menu = "player" .. i
|
||||||
-- instead of a random one
|
self:addMenu(menu)
|
||||||
Widgets.Key(key)
|
Widgets.PlayerSubMenu(self, "inputs", i)
|
||||||
|
for k,w in pairs(v.keys) do
|
||||||
|
-- FIXME: make sure that you can use the order you want for the keys list
|
||||||
|
-- instead of a random one
|
||||||
|
Widgets.Key(self, i, k)
|
||||||
|
end
|
||||||
|
Widgets.SubMenu(self, menu, "inputs", "back", 1, "<")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -97,8 +100,8 @@ function OptionsMenu:addScene(submenu, scene, fullname)
|
||||||
end
|
end
|
||||||
|
|
||||||
function OptionsMenu:setLanguageMenu()
|
function OptionsMenu:setLanguageMenu()
|
||||||
for i,lang in ipairs(core.lang.data.available) do
|
for i,v in ipairs(core.lang.data.available) do
|
||||||
Widgets.Lang(lang)
|
Widgets.Lang(self, "langs", v)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -118,7 +121,6 @@ end
|
||||||
function OptionsMenu:draw()
|
function OptionsMenu:draw()
|
||||||
love.graphics.setColor(.3, .1, .4, 1)
|
love.graphics.setColor(.3, .1, .4, 1)
|
||||||
love.graphics.rectangle("fill", 0, 0, 424, 240)
|
love.graphics.rectangle("fill", 0, 0, 424, 240)
|
||||||
utils.graphics.resetColor()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
return OptionsMenu
|
return OptionsMenu
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
local TextMenu = require "birb.modules.menusystem.textmenu"
|
|
||||||
local OptionMenu = TextMenu:extend()
|
|
||||||
|
|
||||||
local consts = require "examples.scenes.menus.options.consts"
|
|
||||||
|
|
||||||
function OptionMenu:new(font)
|
|
||||||
local screenWidth, _ = core.screen:getDimensions()
|
|
||||||
local w = screenWidth - (consts.BORDERS_W*2)
|
|
||||||
local x = consts.BORDERS_W
|
|
||||||
local y = consts.BORDERS_H
|
|
||||||
OptionMenu.super.new(self, consts.OPTION_MENU, font, x, y, w, consts.NBR_ELEMS, 8)
|
|
||||||
end
|
|
||||||
|
|
||||||
return OptionMenu
|
|
|
@ -23,15 +23,15 @@
|
||||||
|
|
||||||
local widgets = {}
|
local widgets = {}
|
||||||
|
|
||||||
local Widget = require "birb.modules.menusystem.textmenu.widgets.basic"
|
local Widget = require "birb.modules.menusystem.menus.widgets"
|
||||||
local DoubleTextWidget = Widget:extend()
|
local DoubleTextWidget = Widget.Text:extend()
|
||||||
|
|
||||||
widgets.SubMenu = DoubleTextWidget:extend()
|
widgets.SubMenu = DoubleTextWidget:extend()
|
||||||
widgets.Dummy = Widget:extend()
|
widgets.Dummy = Widget.Text:extend()
|
||||||
widgets.Exit = Widget:extend()
|
widgets.Exit = Widget.Text:extend()
|
||||||
widgets.Switch = DoubleTextWidget:extend()
|
widgets.Switch = DoubleTextWidget:extend()
|
||||||
widgets.Resolution = DoubleTextWidget:extend()
|
widgets.Resolution = DoubleTextWidget:extend()
|
||||||
widgets.Lang = Widget:extend()
|
widgets.Lang = Widget.Text:extend()
|
||||||
widgets.PlayerSubMenu = DoubleTextWidget:extend()
|
widgets.PlayerSubMenu = DoubleTextWidget:extend()
|
||||||
widgets.Key = DoubleTextWidget:extend()
|
widgets.Key = DoubleTextWidget:extend()
|
||||||
widgets.Audio = DoubleTextWidget:extend()
|
widgets.Audio = DoubleTextWidget:extend()
|
||||||
|
@ -41,33 +41,44 @@ widgets.Audio = DoubleTextWidget:extend()
|
||||||
|
|
||||||
-- DoubleText widget : a two-side text widget
|
-- DoubleText widget : a two-side text widget
|
||||||
|
|
||||||
function DoubleTextWidget:new(label1, label2)
|
function DoubleTextWidget:new(menu, font, label1, label2)
|
||||||
DoubleTextWidget.super.new(self, "optionMenu", label1, "left")
|
DoubleTextWidget.super.new(self, menu, font, label1)
|
||||||
local label2 = label2 or ""
|
self.label2 = label2 or ""
|
||||||
self:addLabel(label2, "right")
|
end
|
||||||
|
|
||||||
|
function DoubleTextWidget:drawCanvas()
|
||||||
|
local w, h
|
||||||
|
w = math.floor(self.width)
|
||||||
|
h = math.floor(self.height / 2) - (self.font:getHeight() / 2)
|
||||||
|
self.font:draw(self.label, 4, h, -1, "left")
|
||||||
|
self.font:draw(self.label2, w-4, h, -1, "right")
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Submenu widget :: go to a submenu
|
-- Submenu widget :: go to a submenu
|
||||||
|
|
||||||
function widgets.SubMenu:new(scene, newmenu, fullname, order, label2)
|
function widgets.SubMenu:new(scene, menu, newmenu, fullname, order, label2)
|
||||||
self.scene = scene
|
self.scene = scene
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
local label = core.lang:translate("options", fullname)
|
local label = core.lang:translate("options", fullname)
|
||||||
local label2 = label2 or ">"
|
local label2 = label2 or ">"
|
||||||
self.newmenu = newmenu
|
self.newmenu = newmenu
|
||||||
widgets.SubMenu.super.new(self, label, label2)
|
widgets.SubMenu.super.new(self, widgetmenu, font, label, label2)
|
||||||
self.order = order or 0
|
self.order = order or 0
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.SubMenu:action()
|
function widgets.SubMenu:action()
|
||||||
self.scene.assets:playSFX("confirm")
|
self.scene.assets:playSFX("confirm")
|
||||||
self.menu:switch(self.newmenu)
|
self.scene.menusystem:switchMenu(self.newmenu)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Dummy widget :: An empty widget to serve as a base for others
|
-- Dummy widget :: An empty widget to serve as a base for others
|
||||||
|
|
||||||
function widgets.Dummy:new(scene, menu, fullname)
|
function widgets.Dummy:new(scene, menu, fullname)
|
||||||
self.scene = scene
|
self.scene = scene
|
||||||
widgets.Dummy.super.new(self, menu, fullname)
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
|
widgets.Dummy.super.new(self, widgetmenu, font, fullname)
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Dummy:action()
|
function widgets.Dummy:action()
|
||||||
|
@ -78,12 +89,14 @@ end
|
||||||
|
|
||||||
function widgets.Exit:new(scene, menu)
|
function widgets.Exit:new(scene, menu)
|
||||||
self.scene = scene
|
self.scene = scene
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
local label = core.lang:translate("commons", "exit")
|
local label = core.lang:translate("commons", "exit")
|
||||||
widgets.Exit.super.new(self, "optionMenu", label, "left")
|
widgets.Exit.super.new(self, widgetmenu, font, "Exit")
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Exit:action()
|
function widgets.Exit:action()
|
||||||
self.assets:playSFX("confirm")
|
self.scene.assets:playSFX("confirm")
|
||||||
core.scenemanager:setStoredScene("mainmenu")
|
core.scenemanager:setStoredScene("mainmenu")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -92,11 +105,14 @@ end
|
||||||
|
|
||||||
-- Switch widget (One widget to handle graphical switch)
|
-- Switch widget (One widget to handle graphical switch)
|
||||||
|
|
||||||
function widgets.Switch:new(keyname)
|
function widgets.Switch:new(scene, menu, keyname)
|
||||||
|
self.scene = scene
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
self.keyname = keyname
|
self.keyname = keyname
|
||||||
local label = core.lang:translate("options", keyname)
|
local label = core.lang:translate("options", keyname)
|
||||||
local label2 = self:getLabel()
|
local label2 = self:getLabel()
|
||||||
widgets.Switch.super.new(self, label, label2)
|
widgets.Switch.super.new(self, widgetmenu, font, label, label2)
|
||||||
self.order = 0
|
self.order = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -136,19 +152,21 @@ end
|
||||||
|
|
||||||
function widgets.Switch:action()
|
function widgets.Switch:action()
|
||||||
self:modifyKey()
|
self:modifyKey()
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("confirm")
|
||||||
scene.assets:playSFX("confirm")
|
self.label2 = self:getLabel()
|
||||||
self:replaceLabel(2, self:getLabel())
|
|
||||||
core.options:write()
|
core.options:write()
|
||||||
self:invalidateCanvas()
|
self:invalidateCanvas()
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Resolution Widget
|
-- Resolution Widget
|
||||||
|
|
||||||
function widgets.Resolution:new()
|
function widgets.Resolution:new(scene, menu)
|
||||||
|
self.scene = scene
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
local label = core.lang:translate("options", "resolution")
|
local label = core.lang:translate("options", "resolution")
|
||||||
local label2 = self:getLabel()
|
local label2 = self:getLabel()
|
||||||
widgets.Resolution.super.new(self, label, label2)
|
widgets.Resolution.super.new(self, widgetmenu, font, label, label2)
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Resolution:getLabel()
|
function widgets.Resolution:getLabel()
|
||||||
|
@ -161,10 +179,9 @@ function widgets.Resolution:action()
|
||||||
else
|
else
|
||||||
core.options.data.video.resolution = core.options.data.video.resolution + 1
|
core.options.data.video.resolution = core.options.data.video.resolution + 1
|
||||||
end
|
end
|
||||||
self:replaceLabel(2, self:getLabel())
|
self.label2 = self:getLabel()
|
||||||
core.screen:applySettings()
|
core.screen:applySettings()
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("confirm")
|
||||||
scene.assets:playSFX("confirm")
|
|
||||||
self:invalidateCanvas()
|
self:invalidateCanvas()
|
||||||
core.options:write()
|
core.options:write()
|
||||||
end
|
end
|
||||||
|
@ -172,15 +189,17 @@ end
|
||||||
-- LANGS WIDGET
|
-- LANGS WIDGET
|
||||||
-- Allow you to change the lang of the game
|
-- Allow you to change the lang of the game
|
||||||
|
|
||||||
function widgets.Lang:new(lang)
|
function widgets.Lang:new(scene, menu, lang)
|
||||||
|
self.scene = scene
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
local label = core.lang:getLangName(lang)
|
local label = core.lang:getLangName(lang)
|
||||||
self.lang = lang
|
self.lang = lang
|
||||||
widgets.Lang.super.new(self, "optionMenu", label, "left")
|
widgets.Lang.super.new(self, widgetmenu, font, label)
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Lang:action()
|
function widgets.Lang:action()
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("confirm")
|
||||||
scene.assets:playSFX("confirm")
|
|
||||||
core.options:setLanguage(self.lang)
|
core.options:setLanguage(self.lang)
|
||||||
--self.scene.menusystem:invalidateAllWidgets()
|
--self.scene.menusystem:invalidateAllWidgets()
|
||||||
end
|
end
|
||||||
|
@ -190,31 +209,35 @@ end
|
||||||
|
|
||||||
function widgets.PlayerSubMenu:new(scene, menu, sourceid)
|
function widgets.PlayerSubMenu:new(scene, menu, sourceid)
|
||||||
self.scene = scene
|
self.scene = scene
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
local label = core.lang:translate("options", "player") .. " " .. sourceid
|
local label = core.lang:translate("options", "player") .. " " .. sourceid
|
||||||
local label2 = ">"
|
local label2 = ">"
|
||||||
self.newmenu = "player" .. sourceid
|
self.newmenu = "player" .. sourceid
|
||||||
widgets.PlayerSubMenu.super.new(self, label, label2)
|
widgets.PlayerSubMenu.super.new(self, widgetmenu, font, label, label2)
|
||||||
self.order = 0
|
self.order = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.PlayerSubMenu:action()
|
function widgets.PlayerSubMenu:action()
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("confirm")
|
||||||
scene.assets:playSFX("confirm")
|
self.scene.menusystem:switchMenu(self.newmenu)
|
||||||
scene.menusystem:switchMenu(self.newmenu)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Key widgets
|
-- Key widgets
|
||||||
|
|
||||||
function widgets.Key:new(key)
|
function widgets.Key:new(scene, sourceid, key)
|
||||||
self.source = 1
|
self.scene = scene
|
||||||
|
self.source = sourceid
|
||||||
self.key = key
|
self.key = key
|
||||||
|
|
||||||
local menu = "player" .. self.source
|
local menu = "player" .. self.source
|
||||||
|
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
local label = self.key
|
local label = self.key
|
||||||
local label2 = self:getLabel()
|
local label2 = self:getLabel()
|
||||||
|
|
||||||
widgets.Key.super.new(self, label, label2)
|
widgets.Key.super.new(self, widgetmenu, font, label, label2)
|
||||||
self.order = 0
|
self.order = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -223,27 +246,28 @@ function widgets.Key:getLabel()
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Key:action()
|
function widgets.Key:action()
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("navigate")
|
||||||
scene.assets:playSFX("navigate")
|
self.scene:changeKey(self)
|
||||||
scene:changeKey(self)
|
self.scene.menusystem:deactivate()
|
||||||
scene.menusystem:deactivate()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Key:receiveKey( key )
|
function widgets.Key:receiveKey( key )
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("confirm")
|
||||||
scene.assets:playSFX("confirm")
|
|
||||||
core.options:setInputKey(self.source, self.key, key)
|
core.options:setInputKey(self.source, self.key, key)
|
||||||
self:replaceLabel(2, self:getLabel())
|
self.label2 = self:getLabel()
|
||||||
self:invalidateCanvas()
|
self:invalidateCanvas()
|
||||||
end
|
end
|
||||||
|
|
||||||
-- AUDIO FUNCTIONS
|
-- AUDIO FUNCTIONS
|
||||||
-- Sounds/Music functions
|
-- Sounds/Music functions
|
||||||
|
|
||||||
function widgets.Audio:new(audiotype)
|
function widgets.Audio:new(scene, menu, audiotype)
|
||||||
|
self.scene = scene
|
||||||
self.audiotype = audiotype
|
self.audiotype = audiotype
|
||||||
|
|
||||||
|
|
||||||
|
local widgetmenu = self.scene.menusystem.menus[menu]
|
||||||
|
local font = self.scene.assets.fonts["medium"]
|
||||||
self.audiotype = audiotype
|
self.audiotype = audiotype
|
||||||
local label = ""
|
local label = ""
|
||||||
if (self.audiotype == "sfx") then
|
if (self.audiotype == "sfx") then
|
||||||
|
@ -253,7 +277,7 @@ function widgets.Audio:new(audiotype)
|
||||||
end
|
end
|
||||||
local label2 = self:getLabel()
|
local label2 = self:getLabel()
|
||||||
|
|
||||||
widgets.Audio.super.new(self, label, label2)
|
widgets.Audio.super.new(self, widgetmenu, font, label, label2)
|
||||||
self.order = 0
|
self.order = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -282,16 +306,15 @@ function widgets.Audio:setVolume(vol)
|
||||||
core.options.data.audio.music = vol
|
core.options.data.audio.music = vol
|
||||||
end
|
end
|
||||||
|
|
||||||
self:replaceLabel(2, self:getLabel())
|
self.label2 = self:getLabel()
|
||||||
self:invalidateCanvas()
|
self:invalidateCanvas()
|
||||||
end
|
end
|
||||||
|
|
||||||
function widgets.Audio:action()
|
function widgets.Audio:action()
|
||||||
local value = self:getVolume()
|
local value = self:getVolume()
|
||||||
self:setVolume(value - 20)
|
self:setVolume(value - 20)
|
||||||
local scene = core.scenemanager.currentScene
|
self.scene.assets:playSFX("confirm")
|
||||||
scene.assets:playSFX("confirm")
|
self.scene.assets.music:setVolume(core.options.data.audio.music / 100)
|
||||||
core.music:applyVolume()
|
|
||||||
core.options:write()
|
core.options:write()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue