NOTE: This project is still in early development and is lacking documentation. It will be developed over time as I finish up Just Another Sand Game v1.0
Tux Redux is an immediate-mode UI system for LOVE2D inspired by SUIT. It is a continuation of my original extension to SUIT called Tux.
If you'd like an example of Tux Redux in action, check out my weekend game jam project, Verify You're Human.
local tux = require ("tux")
local checkboxData = {checked = false}
local checkColor = {
on = {0, 1, 0, 1},
off = {1, 0, 0, 1},
}
local sliderData = {value = 0}
local singleInputData = {
text = "First data",
inFocus = false,
}
function love.update (dt)
tux.callbacks.update (dt)
tux.show.label ({colors = {1, 0, 0, 1},}, 100, 100, 250, 100)
tux.show.label ({
colors = {1, 0, 1, 1},
tooltip = {
text = "This is a test"
}
}, 150, 150, 250, 100)
if tux.show.button (nil, 400, 300, 100, 200) == "end" then
print ("end")
end
if tux.show.button (nil, 450, 350, 100, 200) == "start" then
print ("start")
end
tux.show.noPressZone (nil, 550, 100, 100, 100)
if tux.show.button (nil, 600, 150, 100, 200) == "held" then
print ("held")
end
if tux.show.button ({text="Debug mode"}, 25, 525, 50, 50) == "start" then
tux.utils.setDebugMode (not tux.utils.getDebugMode ())
end
tux.show.checkbox ({data = checkboxData, mark = "cross"}, 500, 25, 100, 50)
tux.show.toggle ({data = checkboxData, checkColor = checkColor, style = "round"}, 25, 350, 50, 50)
tux.show.slider ({data = sliderData}, 150, 300, 200, 50)
tux.show.label ({
text = math.floor (sliderData.value * 100) / 100,
colors = {1, 0, 1, 1},
}, 25, 25, 50, 25)
tux.show.singleInput ({data = singleInputData}, 150, 400, 200, 50)
end
function love.draw ()
tux.callbacks.draw ()
-- Prints the cursor coordinates
local mx, my = love.mouse.getPosition ()
love.graphics.setColor (1, 1, 1, 1)
love.graphics.print (mx .. ", " .. my, 700, 25)
-- Prints the current debug mode
love.graphics.print ("Debug: " .. tostring (tux.utils.getDebugMode ()), 700, 50)
end
function love.textinput (text)
tux.callbacks.textinput (text)
end
function love.keypressed (key, scancode, isrepeat)
tux.callbacks.keypressed (key, scancode, isrepeat)
end
The following is a list of goals that I intend to fulfill with this project in the future:
- A familiar and intuitive interface inspired by SUIT
- UI components can be be shown by simply executing a function
- The state of the UI component is returned as a string and can be easily integrated with your existing logic
- Better documentation and more examples
- More base components
- Multiline text fields
- Toggle switches
- Drop-downs
- New UI options
- Icon support
- Padding
- Nineslices
- Better text alignment
- Automatic font sizing
- Improved layout system
- High extensibility
- New components only require a couple functions and attributes to create
- Registering components is as easy as calling tux.utils.register
- Internal rendering behavior is easily accessible/replaceable and well-documented