2018-10-20 22:42:49 +00:00
|
|
|
package doodle
|
|
|
|
|
|
|
|
import (
|
2019-07-05 22:02:22 +00:00
|
|
|
"fmt"
|
|
|
|
|
2019-04-10 00:35:44 +00:00
|
|
|
"git.kirsle.net/apps/doodle/lib/render"
|
|
|
|
"git.kirsle.net/apps/doodle/lib/ui"
|
|
|
|
"git.kirsle.net/apps/doodle/pkg/balance"
|
|
|
|
"git.kirsle.net/apps/doodle/pkg/log"
|
2018-10-20 22:42:49 +00:00
|
|
|
)
|
|
|
|
|
2019-06-26 00:43:23 +00:00
|
|
|
// SetupPalette sets up the palette panel.
|
|
|
|
func (u *EditorUI) SetupPalette(d *Doodle) *ui.Window {
|
|
|
|
window := ui.NewWindow("Palette")
|
|
|
|
window.ConfigureTitle(balance.TitleConfig)
|
|
|
|
window.TitleBar().Font = balance.TitleFont
|
|
|
|
window.Configure(ui.Config{
|
|
|
|
Background: balance.WindowBackground,
|
|
|
|
BorderColor: balance.WindowBorder,
|
|
|
|
})
|
|
|
|
|
|
|
|
// Doodad frame.
|
|
|
|
{
|
|
|
|
frame, err := u.setupDoodadFrame(d.Engine, window)
|
|
|
|
if err != nil {
|
|
|
|
d.Flash(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Even if there was an error (userdir.ListDoodads couldn't read the
|
|
|
|
// config folder on disk or whatever) the Frame is still valid but
|
|
|
|
// empty, which is still the intended behavior.
|
|
|
|
u.DoodadTab = frame
|
|
|
|
u.DoodadTab.Hide()
|
|
|
|
window.Pack(u.DoodadTab, ui.Pack{
|
|
|
|
Anchor: ui.N,
|
|
|
|
Fill: true,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Color Palette Frame.
|
|
|
|
u.PaletteTab = u.setupPaletteFrame(window)
|
|
|
|
window.Pack(u.PaletteTab, ui.Pack{
|
|
|
|
Anchor: ui.N,
|
|
|
|
Fill: true,
|
|
|
|
})
|
|
|
|
|
|
|
|
return window
|
|
|
|
}
|
|
|
|
|
2018-10-20 22:42:49 +00:00
|
|
|
// setupPaletteFrame configures the Color Palette tab for Edit Mode.
|
|
|
|
// This is a subroutine of editor_ui.go#SetupPalette()
|
|
|
|
func (u *EditorUI) setupPaletteFrame(window *ui.Window) *ui.Frame {
|
|
|
|
frame := ui.NewFrame("Palette Tab")
|
|
|
|
frame.SetBackground(balance.WindowBackground)
|
|
|
|
|
|
|
|
// Handler function for the radio buttons being clicked.
|
|
|
|
onClick := func(p render.Point) {
|
|
|
|
name := u.selectedSwatch
|
|
|
|
swatch, ok := u.Canvas.Palette.Get(name)
|
|
|
|
if !ok {
|
|
|
|
log.Error("Palette onClick: couldn't get swatch named '%s' from palette", name)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
log.Info("Set swatch: %s", swatch)
|
|
|
|
u.Canvas.SetSwatch(swatch)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Draw the radio buttons for the palette.
|
|
|
|
if u.Canvas != nil && u.Canvas.Palette != nil {
|
|
|
|
for _, swatch := range u.Canvas.Palette.Swatches {
|
2019-07-05 22:02:22 +00:00
|
|
|
swFrame := ui.NewFrame(fmt.Sprintf("Swatch(%s) Button Frame", swatch.Name))
|
|
|
|
|
|
|
|
colorFrame := ui.NewFrame(fmt.Sprintf("Swatch(%s) Color Box", swatch.Name))
|
|
|
|
colorFrame.Configure(ui.Config{
|
|
|
|
Width: 16,
|
|
|
|
Height: 16,
|
|
|
|
Background: swatch.Color,
|
|
|
|
BorderSize: 1,
|
|
|
|
BorderStyle: ui.BorderSunken,
|
|
|
|
})
|
|
|
|
swFrame.Pack(colorFrame, ui.Pack{
|
|
|
|
Anchor: ui.W,
|
|
|
|
})
|
|
|
|
|
2018-10-20 22:42:49 +00:00
|
|
|
label := ui.NewLabel(ui.Label{
|
|
|
|
Text: swatch.Name,
|
|
|
|
Font: balance.StatusFont,
|
|
|
|
})
|
2019-06-26 00:43:23 +00:00
|
|
|
label.Font.Color = swatch.Color.Darken(128)
|
2019-07-05 22:02:22 +00:00
|
|
|
swFrame.Pack(label, ui.Pack{
|
|
|
|
Anchor: ui.W,
|
|
|
|
})
|
2018-10-20 22:42:49 +00:00
|
|
|
|
2019-07-05 22:02:22 +00:00
|
|
|
btn := ui.NewRadioButton("palette", &u.selectedSwatch, swatch.Name, swFrame)
|
2018-10-20 22:42:49 +00:00
|
|
|
btn.Handle(ui.Click, onClick)
|
|
|
|
u.Supervisor.Add(btn)
|
|
|
|
|
2019-07-05 22:02:22 +00:00
|
|
|
btn.Compute(u.d.Engine)
|
|
|
|
swFrame.Configure(ui.Config{
|
|
|
|
Height: label.Size().H,
|
|
|
|
|
|
|
|
// TODO: magic number, trying to left-align
|
|
|
|
// the label by making the frame as wide as possible.
|
|
|
|
Width: paletteWidth - 16,
|
|
|
|
})
|
|
|
|
|
2018-10-20 22:42:49 +00:00
|
|
|
frame.Pack(btn, ui.Pack{
|
|
|
|
Anchor: ui.N,
|
|
|
|
Fill: true,
|
|
|
|
PadY: 4,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return frame
|
|
|
|
}
|