more cursor cleanup. right clicking removes inventory cursor.

This commit is contained in:
=
2014-09-15 22:16:34 -07:00
parent bcb80ae2db
commit e5b2f95699
3 changed files with 21 additions and 12 deletions

View File

@@ -135,7 +135,9 @@
(reify
IAction
(begin [this screen entities]
(update-in entities [target-id :inventory] #(conj % item)))
(-> entities
(update-in [target-id :inventory] #(conj % item))
(assoc-in [:cursor :current] item)))
(continue [this screen entities] entities)

View File

@@ -94,6 +94,11 @@
range (+ (* percent-complete (- maximum-size minimum-size)) minimum-size)]
range)))))
(defn update-cursor [screen {{:keys [current override last]} :cursor :as entities}]
(when-not (= (or override current)
last)
(input! :set-cursor-image (utils/cursor "cursor.png" (or override current)) 0 0))
(assoc-in entities [:cursor :last] (or override current)))
(defscreen scene
:on-show
@@ -115,7 +120,10 @@
:channel (chan)
:current nil
:started? false}
:cursor {:id "cursor" :current :main }
:cursor {:id "cursor"
:current :main
:last :main
:override nil}
:sheep (assoc (animation->texture screen sheep) :x 38 :y 160 :baseline 160 :anim sheep)
:background (assoc {}
:collision (advent.pathfind/map-from-resource "pathfind-test-big.png")
@@ -192,7 +200,8 @@
:on-render
(fn [screen [entities]]
(clear!)
(let [entities (update-from-script screen entities)
(let [entities (update-cursor screen entities)
entities (update-from-script screen entities)
_ (label! (:fps entities) :set-text (str (game :fps)))
@@ -212,13 +221,11 @@
(fn [screen [entities]]
(let [{:keys [x y]} (input->screen screen {:x (:input-x screen) :y (:input-y screen)})]
(if-let [mouse-override (first (filter #(mouse-in? % [x y]) (get-in entities [:background :mouse-overrides])))]
(when (not (get-in entities [:cursor :override]))
(do (input! :set-cursor-image (utils/cursor "cursor.png" (cursor-override mouse-override)) 0 0)
(assoc-in entities [:cursor :override] mouse-override)))
(when (get-in entities [:cursor :override])
(do (input! :set-cursor-image (utils/cursor "cursor.png" :main) 0 0)
(assoc-in entities [:cursor :override] nil))))))
(assoc-in entities [:cursor :override] (cursor-override mouse-override))
(assoc-in entities [:cursor :override] nil))))
:on-touch-down (fn [screen [entities]]
(left-click screen entities)))
(if (= (button-code :right)
(:button screen))
(assoc-in entities [:cursor :current] :main)
(left-click screen entities))))

View File

@@ -11,7 +11,7 @@
(let [{:keys [x y]} (input->screen screen {:x (:input-x screen) :y (:input-y screen)})]
(println (:input-x screen) (:input-y screen) "->" x y)))
(def +all-cursors+ [:main :touch :look :talk :right :down :left :up])
(def +all-cursors+ [:main :wool :look :talk :right :down :left :up])
(defn cursor [filename which]
(let [scale 2