Fully pivot to pirates, some UI

This commit is contained in:
Dane Johnson 2023-11-06 11:49:58 -06:00
parent 7dbdaa6888
commit a270a2a806
4 changed files with 33 additions and 22 deletions

View File

@ -5,7 +5,7 @@
:url "https://www.eclipse.org/legal/epl-2.0/"} :url "https://www.eclipse.org/legal/epl-2.0/"}
:dependencies [[org.clojure/clojure "1.11.1"] :dependencies [[org.clojure/clojure "1.11.1"]
[seesaw "1.5.0"]] [seesaw "1.5.0"]]
:main ^:skip-aot space-sim.core :main ^:skip-aot age-of-sail.core
:target-path "target/%s" :target-path "target/%s"
:profiles {:uberjar {:aot :all :profiles {:uberjar {:aot :all
:jvm-opts ["-Dclojure.compiler.direct-linking=true"]}}) :jvm-opts ["-Dclojure.compiler.direct-linking=true"]}})

View File

@ -1,6 +1,7 @@
;; you should be in space-sim.core> ;; you should be in age-of-sail.core>
(def my-ship (ref {:position [0. 0.] (def my-ship (ref {:position [0. 0.]
:name "Virgina Woolfe"
:heading (normalize [1.0 1.0]) :heading (normalize [1.0 1.0])
:slots [{:type :downwind-sail :length 2 :furl 1.0}] :slots [{:type :downwind-sail :length 2 :furl 1.0}]
:velocity [1. 0.]})) :velocity [1. 0.]}))
@ -9,8 +10,7 @@
(start-program) (start-program)
@my-ship @my-ship
(dosync (alter my-ship assoc :heading (normalize [0. 1.])))
(stop-program) (stop-program)
(show-ui) (show-ui)
@tracked-ship

View File

@ -1,6 +1,7 @@
(ns space-sim.core (ns age-of-sail.core
(:require [space-sim.vec2 :refer :all] (:require [age-of-sail.vec2 :refer :all]
[seesaw.core :refer :all] [seesaw.core :refer :all]
[seesaw.bind :as b]
[clojure.math :as math])) [clojure.math :as math]))
(def tickrate 100) (def tickrate 100)
@ -8,6 +9,10 @@
(defonce ships (atom [])) (defonce ships (atom []))
(defonce program (atom nil)) (defonce program (atom nil))
(defn find-ship
[ships name]
(some #(when (= name (:name @%)) %) ships))
(defn downwind-force (defn downwind-force
"Calculates the force for a single square downwind sail "Calculates the force for a single square downwind sail
Force = furl × length² × dot(wind, heading)" Force = furl × length² × dot(wind, heading)"
@ -18,13 +23,11 @@
[ship wind] [ship wind]
(loop [slots (:slots ship) (loop [slots (:slots ship)
force (zero)] force (zero)]
(if (empty? slots) (if-let [slot (first slots)]
force
(let [slot (first slots)
tail (rest slots)]
(if (= :downwind-sail (:type slot)) (if (= :downwind-sail (:type slot))
(recur tail (add force (downwind-force slot wind (:heading ship)))) (recur (rest slots) (add force (downwind-force slot wind (:heading ship))))
(recur tail force)))))) (recur (rest slots) force))
force)))
(defn physics-step (defn physics-step
[ship wind] [ship wind]
@ -50,21 +53,29 @@
[] []
(stop-program) (stop-program)
(let [thread-continue (atom true)] (let [thread-continue (atom true)]
(.start (Thread. (fn [] (.start
(Thread.
(fn []
(while @thread-continue (while @thread-continue
(tick @ships) (tick @ships)
(Thread/sleep (quot 1000 tickrate)))))) (Thread/sleep (quot 1000 tickrate))))))
(reset! program thread-continue))) (reset! program thread-continue)))
;; UI ;; UI
(def tracked-ship (atom nil))
(defn ship-chooser (defn ship-chooser
[] []
(let [namebox (text)] (let [name (text :columns 20)]
(flow-panel :items ["Ship Name" namebox]) (b/bind (.getDocument name) (b/transform #(find-ship @ships %)) tracked-ship)
(listen namebox :key-typed #()))) (flow-panel :items ["Ship Name" name])))
(defn ship-info
[])
(defn show-ui (defn show-ui
[] []
(-> (frame :title "Space Sim") pack! show!)) (-> (frame :title "Space Sim" :content (ship-chooser)) pack! show!))
(defn -main (defn -main
[args] [args]

View File

@ -1,4 +1,4 @@
(ns space-sim.vec2 (ns age-of-sail.vec2
(:require [clojure.math :as math])) (:require [clojure.math :as math]))
(defn zero (defn zero