Noah Petherbridge
0044b72943
Add the ability to drag and drop Doodads onto the level. The Doodad buttons on the palette now trigger a Drag/Drop behavior when clicked, and a "blueprint colored" version of the Doodad follows your cursor, centered on it. Actors are assigned a random UUID ID when they are placed into a level. The Canvas gained a MaskColor property that forces all pixels in the drawing to render as the same color. This is a visual-only effect, and is used when dragging Doodads in so they render as "blueprints" instead of their actual colors until they are dropped. Fix the chunk bitmap cache system so it saves in the $XDG_CACHE_FOLDER instead of /tmp and has better names. They go into `~/.config/doodle/chunks/` and have UUID file names -- but they disappear quickly! As soon as they are cached into SDL2 they are removed from disk. Other changes: - UI: Add Hovering() method that returns the widgets that are beneath a point (your cursor) and those that are not, for easy querying for event propagation. - UI: Add ability to return an ErrStopPropagation to tell the master Scene (outside the UI) not to continue sending events to other parts of the code, so that you don't draw pixels during a drag event.
38 lines
892 B
Go
38 lines
892 B
Go
package level
|
|
|
|
import (
|
|
"git.kirsle.net/apps/doodle/render"
|
|
uuid "github.com/satori/go.uuid"
|
|
)
|
|
|
|
// ActorMap holds the doodad information by their ID in the level data.
|
|
type ActorMap map[string]*Actor
|
|
|
|
// Inflate assigns each actor its ID from the hash map for their self reference.
|
|
func (m ActorMap) Inflate() {
|
|
for id, actor := range m {
|
|
actor.id = id
|
|
}
|
|
}
|
|
|
|
// Add a new Actor to the map. If it doesn't already have an ID it will be
|
|
// given a random UUIDv4 ID.
|
|
func (m ActorMap) Add(a *Actor) {
|
|
if a.id == "" {
|
|
a.id = uuid.Must(uuid.NewV4()).String()
|
|
}
|
|
m[a.id] = a
|
|
}
|
|
|
|
// Actor is an instance of a Doodad in the level.
|
|
type Actor struct {
|
|
id string // NOTE: read only, use ID() to access.
|
|
Filename string `json:"filename"` // like "exit.doodad"
|
|
Point render.Point `json:"point"`
|
|
}
|
|
|
|
// ID returns the actor's ID.
|
|
func (a *Actor) ID() string {
|
|
return a.id
|
|
}
|