source of truth comes from inventory for which item is selected.

This commit is contained in:
Bryce Covert
2016-08-03 19:35:17 -07:00
parent 62c9ceb5f9
commit 197165b663
5 changed files with 35 additions and 57 deletions

View File

@@ -26,7 +26,7 @@
:profiles {
:dev {
:source-paths ["src" "src-common" "src-dev"]
:jvm-opts ["-Duse-repl=true" "-Dno-steam=true" "-Dclojure.compiler.direct-linking=true"]
:jvm-opts ["-Duse-repl=true" "-Dno-steam=true" #_"-Dclojure.compiler.direct-linking=true"]
:dependencies [[com.badlogicgames.gdx/gdx-tools "1.5.3"]
[org.clojure/tools.nrepl "0.2.7"]
[play-clj-nrepl "0.1.0" :exclusions [play-clj]]
@@ -53,6 +53,6 @@
:warn-on-reflection true}
}
:aot [advent.core.desktop-launcher advent.tryitout]
:aot [advent.core.desktop-launcher]
:main advent.core.desktop-launcher)

View File

@@ -472,10 +472,7 @@
(run-action entities
(begin [this screen entities]
(screen! dialogue/choice-screen :on-present-choices :choices dialogue-choices :callback #(reset! selected-index %))
(screen! @(resolve 'advent.screens.scene/scene) :on-deactivate)
(-> entities
(assoc-in [:cursor :override] nil)
(assoc-in [:cursor :current] :main)))
(assoc-in entities [:state :active?] false))
(continue [this screen entities] entities)
@@ -483,9 +480,7 @@
(not (nil? @selected-index)))
(terminate [this screen entities]
(-> entities
(assoc-in [:state :active?] true)
(assoc-in [:cursor :override] nil)))
(assoc-in entities [:state :active?] true))
(skip-type [this screen entities]
:none))
@@ -677,8 +672,7 @@
(assoc-in e [:tweens :fade-out] (tween/tween :fade-out screen [:fade :opacity] 0.0 1.0 time))
(if music-changed?
(assoc-in e [:tweens :fade-out-music] (tween/tween :fade-out-music screen [:volume :value] 1.0 0.0 time))
e)
(assoc-in e [:cursor :current] :main)))
e)))
(continue [this screen entities]
entities)

View File

@@ -21,9 +21,10 @@
(and (:shown? entities) (= 1.0 (:opacity entities))))
(defn close [screen entities script-started? dragged-out?]
(defn close [screen {:keys [selected-item] :as entities} script-started? dragged-out?]
(log/info "closing inventory")
(screen! @(resolve 'advent.screens.scene/scene) :on-reactivate :script-started? script-started? :came-from-inventory? dragged-out?)
(screen! @(resolve 'advent.screens.scene/scene) :on-reactivate :came-from-inventory? dragged-out?)
(screen! @(resolve 'advent.screens.scene/hud) :on-reactivate :script-started? script-started? :item selected-item)
(-> entities
(assoc-in [:tweens :fade-out] (tween/tween :fade-out screen [:opacity] 1.0 0.0 0.2 :ease tween/ease-out-cubic
:finish #(assoc % :shown? false)))))
@@ -45,8 +46,7 @@
hovered-entity (first (filter #((:box %) x y) (vals (:items entities))))]
(cond
(and selected-item (mouse-outside-inventory? [x y]))
(do (screen! @(resolve 'advent.screens.scene/scene) :on-chose-item :item selected-item)
(close screen entities false true))
(close screen entities false true)
selected-item
(-> entities
@@ -67,8 +67,7 @@
(let [room-entities (-> @(resolve 'advent.screens.scene/scene)
:entities
deref
first)
current-cursor (get-in room-entities [:cursor :current])]
first)]
(log/info "chose inventory item" selected-item)
(println selected-item hovered-item dragged?)
@@ -94,9 +93,8 @@
:entities
deref
first)
current-cursor (get-in room-entities [:cursor :current])
ego (get-in room-entities [:room :entities :ego])]
(when (and selected-item (= :main current-cursor))
(when selected-item
(((:get-script ego) selected-item [0 0]) room-entities)
(close screen entities true false))))

View File

@@ -172,6 +172,9 @@ void main ()
")
;
(defn get-script-selector [entities]
(or (get-selected-inventory-item) :main))
(def default-interaction
{:get-script (fn [cursor [x y]] (if (= :main cursor)
(actions/get-script entities
@@ -206,14 +209,8 @@ void main ()
(assoc-in entities [:state :active?] false)))
(defn open-inventory [screen entities]
(when (not (get-in entities [:fg-actions :script-running?]))
(if (= (get-in entities [:cursor :current] ) :main)
(do
(screen! inventory-screen :show-screen :items (map (entities :all-items) (get-in entities [:state :inventory])))
(-> entities
(assoc-in [:state :active?] false)
(assoc-in [:cursor :override] nil)))
(assoc-in entities [:cursor :current] :main))))
(screen! inventory-screen :show-screen :items (map (entities :all-items) (get-in entities [:state :inventory])))
(assoc-in entities [:state :active?] false))
@@ -240,9 +237,7 @@ void main ()
current-action (get-in entities [:fg-actions :current])
;; TODO - hacky way of resetting queue
entities (if (and current-action
(= (get-in entities [:cursor :down-target])
(or (:id interacting-entity) (:id interaction) nil)))
entities (if current-action
(skip-action screen entities)
entities)]
@@ -253,15 +248,14 @@ void main ()
(get-in entities [:cursor :came-from-inventory?])))
((or (when (and interacting-entity (not (:cursor interaction)))
(do (screen! hud :on-start-script)
((:get-script interacting-entity) (doto (or (get-selected-inventory-item) (get-in entities [:cursor :current])) println) [x y])))
((:get-script interacting-entity) (get-script-selector entities) [x y])))
(when interaction
(do (screen! hud :on-start-script)
((:get-script interaction) (or (when (:cursor interaction) :main)
(get-selected-inventory-item)
(get-in entities [:cursor :current]))
(get-script-selector entities))
[x y])))
((:get-script default-interaction) (or (get-selected-inventory-item) (get-in entities [:cursor :current])) [x y])) entities))
((:get-script default-interaction) (get-script-selector entities) [x y])) entities))
(assoc-in entities [:cursor :down-target] nil)))
@@ -882,9 +876,9 @@ void main ()
entities)
entities))
(defn update-cursor [screen {{:keys [current override last active was-active]} :cursor :as entities}]
(defn update-cursor [screen {{:keys [override last active was-active]} :cursor :as entities}]
(if (= 0.0 (get-in entities [:fade :opacity]))
(let [new-current (or override (get-selected-inventory-item) current)]
(let [new-current (or override (get-selected-inventory-item) :main)]
(when-not (and (= new-current
last)
(= active was-active))
@@ -1185,7 +1179,6 @@ void main ()
:music-override {:object nil
:value nil}
:cursor {:id "cursor"
:current :main
:last nil
:override :hourglass
:last-pos [0 0]
@@ -1213,7 +1206,7 @@ void main ()
entities)))))
:on-resume (fn [screen [{{:keys [current override last active was-active]} :cursor :as entities}]]
(let [current (or override current)
(let [current (or override (get-selected-inventory-item) :main)
image-path (if active "cursor_light.png" "cursor.png")]
(graphics! :set-cursor (utils/cursor image-path (or (:cursor current) current))))
(doseq [[k [start time fn]] (get-in entities [:room :timers])]
@@ -1326,10 +1319,10 @@ void main ()
(filter identity))]
(utils/stop-music snd)))
#_#_:on-mouse-moved
:on-mouse-moved
mouse-moved
#_#_:on-touch-dragged
:on-touch-dragged
mouse-moved
:on-touch-down
@@ -1365,11 +1358,9 @@ void main ()
:on-deactivate (fn [screen [entities]]
(assoc-in entities [:state :active?] false))
:on-reactivate (fn [{:keys [script-started? came-from-inventory?] :as screen} [entities]]
(screen! hud :on-reactivate :cursor (get-in entities [:cursor :current]) :script-started? script-started?)
:on-reactivate (fn [{:keys [came-from-inventory?] :as screen} [entities]]
(-> entities
(assoc-in [:state :active?] true)
(assoc-in [:cursor :current] :main)
(assoc-in [:cursor :came-from-inventory?] came-from-inventory?)))
:on-end-safe (fn [screen [entities]]
@@ -1379,10 +1370,6 @@ void main ()
(assoc-in [:state :active?] true)
(assoc-in [:cursor :override] nil)))
:on-chose-item (fn [{:keys [item]} [entities]]
(screen! hud :on-chose-item :item item)
(assoc-in entities [:cursor :current] item))
:on-open-inventory (fn [screen [entities]]
(open-inventory screen entities))
@@ -1441,10 +1428,9 @@ void main ()
entities)))
(defn get-selected-inventory-item []
(doto
(let [[{{:keys [state state-data]} :inv-fsm}] (-> hud :entities deref)]
(and (= state :selected)
state-data))))
(let [[{{:keys [state state-data]} :inv-fsm}] (-> hud :entities deref)]
(and (= state :selected)
state-data)))
(defscreen demo
:on-show
@@ -1849,11 +1835,11 @@ void main ()
:on-reactivate
(fn [{:keys [cursor script-started?] :as screen} [entities]]
(let [selected-item? (and (:value cursor)
(:cursor cursor))]
(fn [{:keys [script-started? item] :as screen} [entities]]
(let [selected-item? (and (:value item)
(:cursor item))]
(if (and (not script-started?) selected-item?)
(transition-hud screen entities :selected cursor)
(transition-hud screen entities :selected item)
(transition-hud screen entities :none nil))))
:on-touch-down

View File

@@ -361,7 +361,7 @@
(let [current-action (get-in entities [:fg-actions :current])
is-script-running (get-in entities [:fg-actions :script-running?])]
(and is-script-running
(not= :end (get-in entities [:fg-actions :last-skip-type])))))
(not ( #{nil :end :none-but-arrow} (get-in entities [:fg-actions :last-skip-type]))))))
(defn update-override [{:keys [^FitViewport viewport] :as screen} entities]
(let [raw-pos (get-in entities [:cursor :last-pos])
@@ -393,7 +393,7 @@
(assoc-in [:cursor :override] nil)
(assoc-in [:cursor :active] false))
(and hovering-ego (not= :main current))
(and hovering-ego (not @(resolve 'advent.screens.scene/get-selected-inventory-item)))
(-> entities
(assoc-in [:cursor :override] (or (:cursor mouse-override) (when (#{:main :active-main} (get-in entities [:cursor :last])) :active-main)))
(assoc-in [:cursor :active] true))