First cut at updating mapedit
This commit is contained in:
parent
b9ec214b46
commit
939cfc6065
|
@ -3,7 +3,7 @@
|
||||||
(local tiledraw (require :editor.tiledraw))
|
(local tiledraw (require :editor.tiledraw))
|
||||||
(local util (require :lib.util))
|
(local util (require :lib.util))
|
||||||
(local files (require :game.files))
|
(local files (require :game.files))
|
||||||
(local {: attach-imstate : button : vert : horiz-wrapper} (util.require :editor.imgui))
|
(local {: attach-imstate : button : vert : horiz-wrapper : begin-group} (util.require :editor.imgui))
|
||||||
|
|
||||||
(local GraphicsEditView (View:extend))
|
(local GraphicsEditView (View:extend))
|
||||||
|
|
||||||
|
@ -42,16 +42,18 @@
|
||||||
|
|
||||||
(fn tile-selector [{: view &as form} selected-itile ?key]
|
(fn tile-selector [{: view &as form} selected-itile ?key]
|
||||||
(var selected-itile selected-itile)
|
(var selected-itile selected-itile)
|
||||||
(let [wrap (horiz-wrapper form)]
|
(let [g (begin-group)
|
||||||
|
wrap (horiz-wrapper form)]
|
||||||
(for [itile 1 (length view.tilecache.tiles)]
|
(for [itile 1 (length view.tilecache.tiles)]
|
||||||
(let [{: x : y} form
|
(let [{: x : y} form
|
||||||
(w h) (view:draw-sprite x y itile ?key)]
|
(w h) (view:draw-sprite x y itile ?key)]
|
||||||
(when (and w h)
|
(when (and w h)
|
||||||
(when (= itile selected-itile)
|
(when (= itile selected-itile)
|
||||||
(love.graphics.rectangle :line (- x 2) (- y 2) (+ w 4) (+ h 4)))
|
(love.graphics.rectangle :line (- x 2) (- y 2) (+ w 4) (+ h 4)))
|
||||||
(when (wrap button {:tag [:tile itile] : w : h})
|
(when (g wrap form button {:tag [:tile itile] : w : h})
|
||||||
(set selected-itile itile))))))
|
(set selected-itile itile)))))
|
||||||
selected-itile)
|
(g form)
|
||||||
|
selected-itile))
|
||||||
|
|
||||||
(fn GraphicsEditView.draw-tile-selector [self form ?key]
|
(fn GraphicsEditView.draw-tile-selector [self form ?key]
|
||||||
(match (vert form tile-selector {:scale self.sprite-scale :w form.w} (when (= self.tilekey ?key) self.itile) ?key)
|
(match (vert form tile-selector {:scale self.sprite-scale :w form.w} (when (= self.tilekey ?key) self.itile) ?key)
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
(fn view.form [self ?overrides]
|
(fn view.form [self ?overrides]
|
||||||
(lume.merge {:x (+ self.position.x style.padding.x (- self.scroll.x))
|
(lume.merge {:x (+ self.position.x style.padding.x (- self.scroll.x))
|
||||||
:y (+ self.position.y style.padding.y (- self.scroll.y))
|
:y (+ self.position.y style.padding.y (- self.scroll.y))
|
||||||
|
:w (- self.size.x (* style.padding.x 2))
|
||||||
:view self}
|
:view self}
|
||||||
(or ?overrides {})))
|
(or ?overrides {})))
|
||||||
(fn view.end-scroll [self {: y : h}]
|
(fn view.end-scroll [self {: y : h}]
|
||||||
|
@ -280,7 +281,8 @@
|
||||||
|
|
||||||
(fn dropdown [form selection options]
|
(fn dropdown [form selection options]
|
||||||
(let [{: x : y : w :h row-h : font : color : bg : xpad : ypad : view : tag}
|
(let [{: x : y : w :h row-h : font : color : bg : xpad : ypad : view : tag}
|
||||||
(with-style form :h #(+ ($1.font:get_height) $1.ypad)
|
(with-style form :w (* 150 SCALE)
|
||||||
|
:h #(+ ($1.font:get_height) $1.ypad)
|
||||||
:bg style.selection)]
|
:bg style.selection)]
|
||||||
(var new-selection nil)
|
(var new-selection nil)
|
||||||
|
|
||||||
|
@ -303,6 +305,18 @@
|
||||||
(focus form)
|
(focus form)
|
||||||
(or new-selection selection)))
|
(or new-selection selection)))
|
||||||
|
|
||||||
|
(fn labelled-dropdown [form label selection options]
|
||||||
|
(let [{: x : y : wlabel : wdropdown : font : color}
|
||||||
|
(with-style form :wlabel #(+ ($1.font:get_width label) $1.xpad)
|
||||||
|
:wdropdown (* 150 SCALE)
|
||||||
|
:w #(+ $1.wlabel $1.wdropdown)
|
||||||
|
:tag label)
|
||||||
|
form-dropdown (lume.merge form {:x (+ x wlabel) :w wdropdown})
|
||||||
|
_ (renderer.draw_text font label x y color)
|
||||||
|
selection (dropdown form-dropdown selection options)]
|
||||||
|
(set form.h form-dropdown.h)
|
||||||
|
selection))
|
||||||
|
|
||||||
(local form-preserved-keys (collect [_ key (ipairs [:view :x :y :font :color :xpad :ypad])] key true))
|
(local form-preserved-keys (collect [_ key (ipairs [:view :x :y :font :color :xpad :ypad])] key true))
|
||||||
(fn prepare-form [form overrides]
|
(fn prepare-form [form overrides]
|
||||||
(each [key (pairs form)]
|
(each [key (pairs form)]
|
||||||
|
@ -312,18 +326,18 @@
|
||||||
form)
|
form)
|
||||||
|
|
||||||
(fn vert [form viewfn overrides ...]
|
(fn vert [form viewfn overrides ...]
|
||||||
(let [result [(viewfn (prepare-form form overrides) ...)]]
|
(let [result (if viewfn [(viewfn (prepare-form form overrides) ...)] [])]
|
||||||
(set form.y (+ form.y (or form.h 0) (or form.ypad 0)))
|
(set form.y (+ form.y (or form.h 0) (or form.ypad 0)))
|
||||||
(table.unpack result)))
|
(table.unpack result)))
|
||||||
|
|
||||||
(fn horiz [form viewfn overrides ...]
|
(fn horiz [form viewfn overrides ...]
|
||||||
(let [result [(viewfn (prepare-form form overrides) ...)]]
|
(let [result (if viewfn [(viewfn (prepare-form form overrides) ...)] [])]
|
||||||
(set form.x (+ form.x (or form.w 0) (or form.xpad 0)))
|
(set form.x (+ form.x (or form.w 0) (or form.xpad 0)))
|
||||||
(table.unpack result)))
|
(table.unpack result)))
|
||||||
|
|
||||||
(fn horiz-wrapper [{: x : w &as form}]
|
(fn horiz-wrapper [{: x : w &as form}]
|
||||||
(set form.w nil)
|
(set form.w nil)
|
||||||
(fn [viewfn overrides ...]
|
(fn [form viewfn overrides ...]
|
||||||
(let [result [(viewfn (prepare-form form overrides) ...)]]
|
(let [result [(viewfn (prepare-form form overrides) ...)]]
|
||||||
(set form.x (+ form.x (or form.w 0) (or form.xpad 0)))
|
(set form.x (+ form.x (or form.w 0) (or form.xpad 0)))
|
||||||
(when (> (+ form.x (or form.w 0)) (+ x w))
|
(when (> (+ form.x (or form.w 0)) (+ x w))
|
||||||
|
@ -361,7 +375,7 @@
|
||||||
viewfn-or-form)))))
|
viewfn-or-form)))))
|
||||||
|
|
||||||
{: attach-imstate : cmd-predicate : postpone : mouse-inside : activate : active?
|
{: attach-imstate : cmd-predicate : postpone : mouse-inside : activate : active?
|
||||||
: button : checkbox : textbox : textfield : textbutton : dropdown
|
: button : checkbox : textbox : textfield : textbutton : dropdown : labelled-dropdown
|
||||||
: vert : horiz : horiz-wrapper : begin-group
|
: vert : horiz : horiz-wrapper : begin-group
|
||||||
: with-style : prepare-form : form-defaults}
|
: with-style : prepare-form : form-defaults}
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
(local GraphicsEditView (require :editor.gfxedit))
|
(local GraphicsEditView (require :editor.gfxedit2))
|
||||||
(local style (require :core.style))
|
(local style (require :core.style))
|
||||||
(local util (require :lib.util))
|
(local util (require :lib.util))
|
||||||
(local lume (require :lib.lume))
|
(local lume (require :lib.lume))
|
||||||
(local files (require :game.files))
|
(local files (require :game.files))
|
||||||
(local {: mouse-inside : activate : active? : checkbox : textfield : textbutton : textbox : dropdown} (util.require :editor.imstate))
|
(local {: mouse-inside : activate : active? : checkbox : textfield : textbutton : textbox : dropdown : labelled-dropdown : vert : horiz : begin-group} (util.require :editor.imgui))
|
||||||
(local {: tilestrip-to-sprite} (util.require :editor.tiledraw))
|
(local {: tilestrip-to-sprite} (util.require :editor.tiledraw))
|
||||||
(local {: encode-yx : encode-itile : decode-itile : dimensions} (util.require :game.tiles))
|
(local {: encode-yx : encode-itile : decode-itile : dimensions} (util.require :game.tiles))
|
||||||
(local actions (require :editor.actions))
|
(local actions (require :editor.actions))
|
||||||
|
@ -84,30 +84,24 @@
|
||||||
(set files.game.levels []))
|
(set files.game.levels []))
|
||||||
files.game.levels)
|
files.game.levels)
|
||||||
|
|
||||||
(fn MapEditView.draw-map-selector [self x y]
|
(fn MapEditView.draw-map-selector [self {: x : y &as form}]
|
||||||
(renderer.draw_text style.font "Map" x (+ y (/ style.padding.y 2)) style.text)
|
(let [level-count (length (self:levels))
|
||||||
(let [options {}
|
options (icollect [i (util.countiter (+ level-count 1))] (if (<= i level-count) i :New))
|
||||||
level-count (length (self:levels))
|
ilevel (vert form labelled-dropdown {:tag :map-selector :wdropdown (* 100 SCALE)} "Map" self.ilevel options)]
|
||||||
_ (do (for [i 1 level-count] (tset options i i))
|
|
||||||
(table.insert options :New))
|
|
||||||
(ilevel yNext) (dropdown self :map-selector self.ilevel options (+ x (* 50 SCALE)) y (* 100 SCALE))]
|
|
||||||
(when (not= ilevel self.ilevel)
|
(when (not= ilevel self.ilevel)
|
||||||
(set self.ilevel (if (= ilevel :New) (+ level-count 1) ilevel))
|
(set self.ilevel (if (= ilevel :New) (+ level-count 1) ilevel))
|
||||||
(self:load-level))
|
(self:load-level))))
|
||||||
(- yNext y)))
|
|
||||||
|
|
||||||
(fn MapEditView.set-ilayer [self ilayer]
|
(fn MapEditView.set-ilayer [self ilayer]
|
||||||
(set self.ilayer ilayer)
|
(set self.ilayer ilayer)
|
||||||
(self:set-style (self:layer-type)))
|
(self:set-style (self:layer-type)))
|
||||||
|
|
||||||
(fn MapEditView.draw-layer-selector [self x y]
|
(fn MapEditView.draw-layer-selector [self {: x : y &as form}]
|
||||||
(renderer.draw_text style.font "Layer" x (+ y (/ style.padding.y 2)) style.text)
|
|
||||||
(let [mkopt (fn [ilayer] {: ilayer :label (.. ilayer " (" (self:layer-type ilayer) ")")})
|
(let [mkopt (fn [ilayer] {: ilayer :label (.. ilayer " (" (self:layer-type ilayer) ")")})
|
||||||
options (icollect [ilayer (ipairs (platform :layers))] (mkopt ilayer))
|
options (icollect [ilayer (ipairs (platform :layers))] (mkopt ilayer))
|
||||||
(selection yNext) (dropdown self :layer-selector (mkopt self.ilayer) options (+ x (* 50 SCALE)) y (* 100 SCALE))]
|
selection (vert form labelled-dropdown {:wdropdown (* 100 SCALE) :tag :layer-selector} "Layer" (mkopt self.ilayer) options)]
|
||||||
(when (not= self.ilayer selection.ilayer)
|
(when (not= self.ilayer selection.ilayer)
|
||||||
(self:set-ilayer selection.ilayer))
|
(self:set-ilayer selection.ilayer))))
|
||||||
(- yNext y)))
|
|
||||||
|
|
||||||
(fn MapEditView.linking-obj [self] (. self.level.objects self.iobject-linking))
|
(fn MapEditView.linking-obj [self] (. self.level.objects self.iobject-linking))
|
||||||
(fn MapEditView.draw-link-line [self x y iobjectSrc color toMouse?]
|
(fn MapEditView.draw-link-line [self x y iobjectSrc color toMouse?]
|
||||||
|
@ -125,6 +119,14 @@
|
||||||
(love.graphics.circle :line xEnd yEnd (/ tilew 5))
|
(love.graphics.circle :line xEnd yEnd (/ tilew 5))
|
||||||
(love.graphics.setColor 1 1 1)))
|
(love.graphics.setColor 1 1 1)))
|
||||||
|
|
||||||
|
(fn MapEditView.draw-link-lines [self {: x : y} iobject-over]
|
||||||
|
(for [iobject 1 (length self.level.objects)]
|
||||||
|
(self:draw-link-line x y iobject [0 0 1 0.3]))
|
||||||
|
(when (not= iobject-over nil) (self:draw-link-line x y iobject-over [0 0.5 1] false))
|
||||||
|
(when (not= self.iobject-linking nil)
|
||||||
|
(if (= self.imstate.left :released) (set self.iobject-linking nil)
|
||||||
|
(self:draw-link-line x y self.iobject-linking [0 1 0] true))))
|
||||||
|
|
||||||
(fn MapEditView.draw-tilestrip [self x y my ?ilayer]
|
(fn MapEditView.draw-tilestrip [self x y my ?ilayer]
|
||||||
; stripcache leaks but honestly who cares
|
; stripcache leaks but honestly who cares
|
||||||
(local tilestrip [])
|
(local tilestrip [])
|
||||||
|
@ -145,13 +147,55 @@
|
||||||
intileh (or ystagger tileh)]
|
intileh (or ystagger tileh)]
|
||||||
[(+ (or xstagger 0) (* mapw tilew)) (+ tileh (* (- maph 1) intileh))]))
|
[(+ (or xstagger 0) (* mapw tilew)) (+ tileh (* (- maph 1) intileh))]))
|
||||||
|
|
||||||
(fn MapEditView.draw-map-editor [self x y ilayer]
|
(fn MapEditView.draw-player [self mx my x y]
|
||||||
|
(each [_ player (ipairs (or files.game.players [:player]))]
|
||||||
|
(match (. self.level player)
|
||||||
|
{:x mx :y my} (renderer.draw_text style.font player x y style.text)))
|
||||||
|
(love.graphics.setColor 1 1 1))
|
||||||
|
|
||||||
|
(fn MapEditView.draw-object-box [self iobject x y w h]
|
||||||
|
(when (not= iobject nil)
|
||||||
|
(love.graphics.setColor 1 0 (if (and (= self.itile nil) (= iobject self.iobject)) 1 0))
|
||||||
|
(love.graphics.setLineWidth 3)
|
||||||
|
(love.graphics.rectangle :line x y w h)
|
||||||
|
(love.graphics.setColor 1 1 1)))
|
||||||
|
|
||||||
|
(fn MapEditView.handle-mouseedits-object [self mx my x y w h]
|
||||||
|
(when (and (active? self :map) (mouse-inside x y w h))
|
||||||
|
(let [iobject (self:iobject-from-xy mx my)]
|
||||||
|
(match self.imstate.left
|
||||||
|
:pressed (set self.iobject-linking iobject)
|
||||||
|
:released
|
||||||
|
(if (and (not= iobject nil) (= self.iobject-linking iobject))
|
||||||
|
(set self.iobject iobject)
|
||||||
|
|
||||||
|
(not= self.iobject-linking nil)
|
||||||
|
(tset (self:linking-obj) :link iobject)
|
||||||
|
|
||||||
|
(not= self.playerpos nil)
|
||||||
|
(do (tset self.level self.playerpos {:x mx :y my})
|
||||||
|
(set self.playerpos nil))
|
||||||
|
|
||||||
|
(= iobject nil)
|
||||||
|
(let [tile (self.tilecache:tile (self:itile-from-xy mx my))]
|
||||||
|
(table.insert self.level.objects {:x mx :y my :func (or tile.word "")})
|
||||||
|
(set self.iobject (length self.level.objects))))))))
|
||||||
|
|
||||||
|
(fn MapEditView.handle-mouseedits-tile [self mx my x y w h]
|
||||||
|
(when (and (active? self :map) (mouse-inside x y w h) (not= (self:itile-from-xy mx my) self.itile))
|
||||||
|
(self:set-tile mx my self.itile)))
|
||||||
|
|
||||||
|
(fn MapEditView.draw-tile-xy-label [self mx my x y h ystagger]
|
||||||
|
(local labely (math.floor (+ y (- (or ystagger 0)) (/ (- (if ystagger (* ystagger 2) h) (style.font:get_height)) 2))))
|
||||||
|
(renderer.draw_text style.font (string.format "%x" (encode-yx {:x mx :y my})) (+ x 20) labely style.text)
|
||||||
|
(love.graphics.setColor 1 1 1))
|
||||||
|
|
||||||
|
(fn MapEditView.draw-map-editor [self {: x : y &as form} ilayer]
|
||||||
(love.graphics.setColor 1 1 1 1)
|
(love.graphics.setColor 1 1 1 1)
|
||||||
(local button-state self.imstate.left)
|
|
||||||
(local {: mapw : maph : tilew : tileh : xstagger : ystagger} (self:scaled-dimensions ilayer))
|
(local {: mapw : maph : tilew : tileh : xstagger : ystagger} (self:scaled-dimensions ilayer))
|
||||||
(local intileh (or ystagger tileh))
|
(local intileh (or ystagger tileh))
|
||||||
(local [mappw mapph] (self:mapsize ilayer))
|
(let [[w h] (self:mapsize ilayer)] (lume.extend form {: w : h :tag :map}))
|
||||||
(activate self :map x y mappw mapph)
|
(activate form)
|
||||||
(var iobject-over nil)
|
(var iobject-over nil)
|
||||||
(for [my 1 maph]
|
(for [my 1 maph]
|
||||||
(local tiley (+ y (* (- my 1) (or ystagger tileh))))
|
(local tiley (+ y (* (- my 1) (or ystagger tileh))))
|
||||||
|
@ -160,51 +204,18 @@
|
||||||
(self:draw-tilestrip (+ x xoff) tiley my ilayer)
|
(self:draw-tilestrip (+ x xoff) tiley my ilayer)
|
||||||
(for [mx 1 mapw]
|
(for [mx 1 mapw]
|
||||||
(local tilex (+ x (* (- mx 1) tilew) xoff))
|
(local tilex (+ x (* (- mx 1) tilew) xoff))
|
||||||
(local itile (self:itile-from-xy mx my))
|
|
||||||
(local iobject (self:iobject-from-xy mx my))
|
(local iobject (self:iobject-from-xy mx my))
|
||||||
(when (= self.itile nil)
|
(when (= self.itile nil)
|
||||||
(each [_ player (ipairs (or files.game.players [:player]))]
|
(self:draw-player mx my tilex intiley)
|
||||||
(match (. self.level player)
|
(self:draw-object-box iobject tilex intiley tilew intileh))
|
||||||
{:x mx :y my} (renderer.draw_text style.font player tilex intiley style.text)))
|
(if self.itile
|
||||||
(love.graphics.setColor 1 1 1))
|
(self:handle-mouseedits-tile mx my tilex intiley tilew intileh)
|
||||||
(when (and (not= iobject nil) (= self.itile nil))
|
(self:handle-mouseedits-object mx my tilex intiley tilew intileh))
|
||||||
(love.graphics.setColor 1 0 (if (and (= self.itile nil) (= iobject self.iobject)) 1 0))
|
|
||||||
(love.graphics.setLineWidth 3)
|
|
||||||
(love.graphics.rectangle :line tilex intiley tilew intileh)
|
|
||||||
(love.graphics.setColor 1 1 1))
|
|
||||||
(when (mouse-inside tilex intiley tilew intileh)
|
(when (mouse-inside tilex intiley tilew intileh)
|
||||||
(when (not= iobject nil) (set iobject-over iobject))
|
(when (not= iobject nil) (set iobject-over iobject))
|
||||||
(local labely (math.floor (+ intiley (- (or ystagger 0)) (/ (- (if ystagger (* ystagger 2) tileh) (style.font:get_height)) 2))))
|
(self:draw-tile-xy-label mx my tilex intiley tileh ystagger))))
|
||||||
(renderer.draw_text style.font (string.format "%x" (encode-yx {:x mx :y my})) (+ tilex 20) labely style.text)
|
(when (= self.itile nil) (self:draw-link-lines form iobject-over))
|
||||||
(love.graphics.setColor 1 1 1))
|
(vert form))
|
||||||
(when (and self.itile (active? self :map) (mouse-inside tilex intiley tilew intileh) (not= itile self.itile))
|
|
||||||
(self:set-tile mx my self.itile))
|
|
||||||
(when (and (= self.itile nil) (active? self :map) (mouse-inside tilex intiley tilew intileh))
|
|
||||||
(match button-state
|
|
||||||
:pressed (set self.iobject-linking iobject)
|
|
||||||
:released
|
|
||||||
(if (and (not= iobject nil) (= self.iobject-linking iobject))
|
|
||||||
(set self.iobject iobject)
|
|
||||||
|
|
||||||
(not= self.iobject-linking nil)
|
|
||||||
(tset (self:linking-obj) :link iobject)
|
|
||||||
|
|
||||||
(not= self.playerpos nil)
|
|
||||||
(do (tset self.level self.playerpos {:x mx :y my})
|
|
||||||
(set self.playerpos nil))
|
|
||||||
|
|
||||||
(= iobject nil)
|
|
||||||
(let [tile (self.tilecache:tile itile)]
|
|
||||||
(table.insert self.level.objects {:x mx :y my :func (or tile.word "")})
|
|
||||||
(set self.iobject (length self.level.objects))))))))
|
|
||||||
(when (= self.itile nil)
|
|
||||||
(for [iobject 1 (length self.level.objects)]
|
|
||||||
(self:draw-link-line x y iobject [0 0 1 0.3]))
|
|
||||||
(when (not= iobject-over nil) (self:draw-link-line x y iobject-over [0 0.5 1] false))
|
|
||||||
(when (not= self.iobject-linking nil)
|
|
||||||
(if (= self.imstate.left :released) (set self.iobject-linking nil)
|
|
||||||
(self:draw-link-line x y self.iobject-linking [0 1 0] true))))
|
|
||||||
mapph)
|
|
||||||
|
|
||||||
(fn condition-label [flag]
|
(fn condition-label [flag]
|
||||||
(if flag {:label flag : flag} {:label "<always>"}))
|
(if flag {:label flag : flag} {:label "<always>"}))
|
||||||
|
@ -215,23 +226,18 @@
|
||||||
(table.insert options (condition-label flag)))
|
(table.insert options (condition-label flag)))
|
||||||
options))
|
options))
|
||||||
|
|
||||||
(fn MapEditView.draw-object-code-editor [self object x y]
|
(fn MapEditView.draw-object-code-editor [self form object]
|
||||||
(var y y)
|
|
||||||
(var istep-to-delete nil)
|
(var istep-to-delete nil)
|
||||||
(when (not object.steps) (set object.steps []))
|
(when (not object.steps) (set object.steps []))
|
||||||
(each [istep step (ipairs object.steps)]
|
(each [istep step (ipairs object.steps)]
|
||||||
(when (textbutton self "X" (+ x (* 280 SCALE)) y)
|
(when (textbutton (lume.merge form {:x (+ form.x (* 280 SCALE))}) "X")
|
||||||
(set istep-to-delete istep))
|
(set istep-to-delete istep))
|
||||||
(set step.condition (. (dropdown self [:code-condition istep] (condition-label step.condition) (condition-options)
|
(set step.condition (. (dropdown (lume.merge form {:x (+ form.x (* 100 SCALE)) :w (* 100 SCALE) :tag [:code-condition istep]}) (condition-label step.condition) (condition-options)) :flag))
|
||||||
(+ x (* 100 SCALE) style.padding.x) y (* 100 SCALE))
|
(set step.action (vert form dropdown {:w (* 100 SCALE) :tag [:code-action istep]} (or step.action (. actions.actionlist 1)) actions.actionlist))
|
||||||
:flag))
|
(vert form actions.edit {:w (* 300 SCALE)} istep))
|
||||||
(set (step.action y) (dropdown self [:code-action istep] (or step.action (. actions.actionlist 1)) actions.actionlist x y (* 100 SCALE)))
|
|
||||||
(set y (actions.edit step self x y (* 300 SCALE) istep))
|
|
||||||
(set y (+ y style.padding.y)))
|
|
||||||
(when istep-to-delete (table.remove object.steps istep-to-delete))
|
(when istep-to-delete (table.remove object.steps istep-to-delete))
|
||||||
(let [(do-new y) (textbutton self "+ New Step" x (+ y style.padding.y))]
|
(when (vert form textbutton {} "+ New Step")
|
||||||
(when do-new (table.insert object.steps {}))
|
(table.insert object.steps {})))
|
||||||
y))
|
|
||||||
|
|
||||||
(fn advanced? [object]
|
(fn advanced? [object]
|
||||||
(or object.advanced
|
(or object.advanced
|
||||||
|
@ -239,36 +245,36 @@
|
||||||
(not= object.func "")
|
(not= object.func "")
|
||||||
(not= object.func nil))))
|
(not= object.func nil))))
|
||||||
|
|
||||||
(fn MapEditView.draw-object-advanced-editor [self object x y]
|
(fn MapEditView.draw-object-advanced-editor [self form object]
|
||||||
(let [(func y) (textfield self "Word" object.func x y (* 100 SCALE) (* 200 SCALE))
|
(let [fieldform {:wlabel (* 100 SCALE) :wtext (* 200 SCALE)}]
|
||||||
(name y) (textfield self "Name" object.name x (+ y style.padding.y) (* 100 SCALE) (* 200 SCALE))
|
(set object.func (vert form textfield fieldform "Word" object.func))
|
||||||
(linkword y) (textfield self "Link word" object.linkword x (+ y style.padding.y) (* 100 SCALE) (* 200 SCALE))
|
(set object.name (vert form textfield fieldform "Name" object.name))
|
||||||
(do-unlink y) (if object.link (textbutton self "Unlink" x (+ y style.padding.y)) (values false y))
|
(set object.linkword (vert form textfield fieldform "Link word" object.linkword))
|
||||||
(linkentity y) (if object.link (values object.linkentity y) (textfield self "Link entity" object.linkentity x (+ y style.padding.y) (* 100 SCALE) (* 200 SCALE)))]
|
(if object.link
|
||||||
(lume.extend object {: func : name : linkword : linkentity})
|
(when (vert form textbutton {} "Unlink")
|
||||||
(when do-unlink (set object.link nil))
|
(set object.link nil))
|
||||||
y))
|
(set object.linkentity (vert form textfield fieldform "Link entity" object.linkentity)))))
|
||||||
|
|
||||||
(fn MapEditView.draw-object-editor [self x y]
|
(fn MapEditView.draw-object-editor [self form]
|
||||||
(let [object (self:object)
|
(let [object (self:object)
|
||||||
y (if (advanced? object)
|
footer (begin-group)]
|
||||||
(self:draw-object-advanced-editor object x y)
|
(if (advanced? object)
|
||||||
(self:draw-object-code-editor object x y))
|
(self:draw-object-advanced-editor form object)
|
||||||
new-flag-name (textbox self :new-flag-name self.new-flag-name x (+ y style.padding.y) (* 200 SCALE))
|
(self:draw-object-code-editor form object))
|
||||||
(mk-new-flag y) (textbutton self "+ New Flag" (+ x (* 200 SCALE) style.padding.x) (+ y style.padding.y))
|
(set self.new-flag-name (footer horiz form textbox {:tag :new-flag-name :w (* 200 SCALE)} self.new-flag-name))
|
||||||
do-delete (textbutton self "Delete" x (+ y (* style.padding.y 2)))
|
(when (footer horiz form textbutton {} "+ New Flag")
|
||||||
(do-advanced y) (textbutton self (if (advanced? object) "Simple" "Advanced") (+ x (* 150 SCALE)) (+ y (* style.padding.y 2)))]
|
|
||||||
(set self.new-flag-name new-flag-name)
|
|
||||||
(when mk-new-flag
|
|
||||||
(when (= files.game.flags nil)
|
(when (= files.game.flags nil)
|
||||||
(set files.game.flags []))
|
(set files.game.flags []))
|
||||||
(table.insert files.game.flags new-flag-name)
|
(table.insert files.game.flags self.new-flag-name)
|
||||||
(set self.new-flag-name ""))
|
(set self.new-flag-name ""))
|
||||||
(when do-delete
|
(footer form)
|
||||||
|
(when (footer vert form textbutton {} "Delete")
|
||||||
(move-object self.level.objects (+ self.iobject 1) self.iobject)
|
(move-object self.level.objects (+ self.iobject 1) self.iobject)
|
||||||
(set self.iobject nil))
|
(set self.iobject nil))
|
||||||
(when do-advanced (set object.advanced (not (advanced? object))))
|
(when (footer textbutton (lume.merge form {:x (+ form.x (* 150 SCALE))}) (if (advanced? object) "Simple" "Advanced"))
|
||||||
y))
|
(set object.advanced (not (advanced? object))))
|
||||||
|
(footer form)
|
||||||
|
(vert form)))
|
||||||
|
|
||||||
(fn MapEditView.load-level [self]
|
(fn MapEditView.load-level [self]
|
||||||
(set self.stripcache {})
|
(set self.stripcache {})
|
||||||
|
@ -282,43 +288,36 @@
|
||||||
(self:load-level))
|
(self:load-level))
|
||||||
|
|
||||||
(fn MapEditView.draw [self]
|
(fn MapEditView.draw [self]
|
||||||
(var x (+ self.position.x style.padding.x (- self.scroll.x)))
|
|
||||||
(var y (+ self.position.y style.padding.y (- self.scroll.y)))
|
|
||||||
(self:draw_background style.background)
|
(self:draw_background style.background)
|
||||||
(self:draw_scrollbar)
|
(self:draw_scrollbar)
|
||||||
(local {: mapw : maph : tilew : tileh} (self:scaled-dimensions))
|
(let [form (self:form)
|
||||||
(local ytop y)
|
form-editor (self:form)
|
||||||
(local editor-on-side (> self.size.x (+ (* tilew mapw) (* 300 SCALE))))
|
header (begin-group)
|
||||||
(when (platform :layers) (self:draw-layer-selector (+ x (* 200 SCALE)) y))
|
_ (self:draw-map-selector form header)
|
||||||
(set y (+ y (self:draw-map-selector x y) style.padding.y))
|
_ (when (platform :layers) (self:draw-layer-selector form header))
|
||||||
(set y (+ y (self:draw-map-editor x y) style.padding.y))
|
_ (self:draw-map-editor form)
|
||||||
(set y (+ y (self:draw-tile-selector x y (if editor-on-side (* tilew mapw)
|
editor-on-side (> self.size.x (+ form.w (* 300 SCALE)))
|
||||||
(- self.size.x (* style.padding.x 2))))))
|
fieldform {:wlabel (* 100 SCALE) :wtext (* 200 SCALE)}]
|
||||||
|
(when editor-on-side
|
||||||
(set (self.level.tickword y) (textfield self "Tick word" self.level.tickword x (+ y style.padding.y) (* 100 SCALE) (* 200 SCALE)))
|
(set form-editor.x (+ form.x form.w style.padding.x))
|
||||||
(set (self.level.moveword y) (textfield self "Move word" self.level.moveword x (+ y style.padding.y) (* 100 SCALE) (* 200 SCALE)))
|
(set form-editor.w (- form-editor.w form.w style.padding.x)))
|
||||||
(set (self.level.loadword y) (textfield self "Load word" self.level.loadword x (+ y style.padding.y) (* 100 SCALE) (* 200 SCALE)))
|
(self:draw-tile-selector (lume.extend form {:w (if editor-on-side form.w (- self.size.x (* style.padding.x 2)))}))
|
||||||
(let [(checked y-new) (checkbox self "Edit objects" (= self.itile nil) x (+ y style.padding.y))
|
(set self.level.tickword (vert form textfield fieldform "Tick word" self.level.tickword))
|
||||||
_ (when checked
|
(set self.level.moveword (vert form textfield fieldform "Move word" self.level.moveword))
|
||||||
(set self.itile nil)
|
(set self.level.loadword (vert form textfield fieldform "Load word" self.level.loadword))
|
||||||
(set self.playerpos nil))]
|
(when (vert form checkbox {} "Edit objects" (= self.itile nil))
|
||||||
(set y y-new)
|
(set self.itile nil)
|
||||||
|
(set self.playerpos nil))
|
||||||
(each [_ player (ipairs (or files.game.players [:player]))]
|
(each [_ player (ipairs (or files.game.players [:player]))]
|
||||||
(let [(checked y-new) (checkbox self (.. "Position " player) (and (= self.itile nil) (= self.playerpos player)) x (+ y style.padding.y))]
|
(when (vert form checkbox {} (.. "Position " player) (and (= self.itile nil) (= self.playerpos player)))
|
||||||
(when checked
|
(set self.itile nil)
|
||||||
(set self.itile nil)
|
(set self.playerpos player)))
|
||||||
(set self.playerpos player))
|
(each [_ levelflag (ipairs (or files.game.levelflags []))]
|
||||||
(set y y-new))))
|
(when (vert form checkbox {} levelflag (. self.level levelflag))
|
||||||
(each [_ levelflag (ipairs (or files.game.levelflags []))]
|
(tset self.level levelflag (not (. self.level levelflag)))))
|
||||||
(let [(checked y-new) (checkbox self levelflag (. self.level levelflag) x (+ y style.padding.y))]
|
(when (not editor-on-side) (set form-editor.y (+ form.y form.h style.padding.y)))
|
||||||
(when checked (tset self.level levelflag (not (. self.level levelflag))))
|
(when self.iobject (self:draw-object-editor form-editor))
|
||||||
(set y y-new)))
|
(self:end-scroll (if (> (+ form.y form.h) (+ form-editor.y (or form-editor.h 0))) form form-editor))))
|
||||||
(when self.iobject
|
|
||||||
(set y (math.max y (if editor-on-side
|
|
||||||
(self:draw-object-editor (+ x (* tilew mapw) style.padding.x) ytop)
|
|
||||||
(self:draw-object-editor x (+ y style.padding.y))))))
|
|
||||||
|
|
||||||
(set self.scrollheight (+ y (- self.position.y) self.scroll.y style.padding.y)))
|
|
||||||
|
|
||||||
(fn MapEditView.get_name [self] (.. "Map " self.ilevel))
|
(fn MapEditView.get_name [self] (.. "Map " self.ilevel))
|
||||||
|
|
||||||
|
|
|
@ -102,7 +102,7 @@
|
||||||
(when (= icolor selected-color)
|
(when (= icolor selected-color)
|
||||||
(love.graphics.setColor 1 1 1 1)
|
(love.graphics.setColor 1 1 1 1)
|
||||||
(love.graphics.rectangle :line (- form.x 2) (- form.y 2) (+ pixel-size 4) (+ pixel-size 4)))
|
(love.graphics.rectangle :line (- form.x 2) (- form.y 2) (+ pixel-size 4) (+ pixel-size 4)))
|
||||||
(when (g wrap button {:tag [:pal icolor] :w pixel-size :h pixel-size})
|
(when (g wrap form button {:tag [:pal icolor] :w pixel-size :h pixel-size})
|
||||||
(set selected-color icolor)))
|
(set selected-color icolor)))
|
||||||
(g form)
|
(g form)
|
||||||
selected-color))
|
selected-color))
|
||||||
|
|
Loading…
Reference in a new issue