Don't redraw unnecessarily
Only redraw the screen when it needs to be drawn. This prevents us from trying
to redraw a hundred billion fucking times when we only need to do it once.
author |
Steve Losh <steve@stevelosh.com> |
date |
Sun, 13 Dec 2015 13:23:53 +0000 (2015-12-13) |
parents |
f5172370bbdb
|
children |
1297582f0758
|
branches/tags |
(none) |
files |
src/silt/core.clj |
Changes
--- a/src/silt/core.clj Sun Dec 13 13:16:39 2015 +0000
+++ b/src/silt/core.clj Sun Dec 13 13:23:53 2015 +0000
@@ -7,13 +7,15 @@
; Data ------------------------------------------------------------------------
-(def fps 10)
+(def fps 50)
(def world-width 600)
(def world-height 400)
(def pond-count 100)
(def pond-size 3)
+(def dirty (atom true))
+
(def directions [[-1 -1] [ 0 -1] [ 1 -1]
[-1 0] [ 0 0] [ 1 0]
[-1 1] [ 0 1] [ 1 1]])
@@ -210,6 +212,9 @@
; Drawing ---------------------------------------------------------------------
+(defn mark-dirty! []
+ (reset! dirty true))
+
(defn calc-screen-coords [[wx wy]]
(let [[ox oy] @window-loc]
(normalize-world-coords [(- wx ox) (- wy oy)])))
@@ -242,17 +247,19 @@
(- (nth (s/get-size screen) 0) n))
(defn draw-screen! [screen]
- (letfn [(put-right [s y]
- (s/put-string screen (from-right screen (.length s)) y s))]
- (s/clear screen)
- (draw-terrain! screen)
- (draw-animals! screen)
- (draw-landmarks! screen)
- (put-right " SILT " 0)
- (put-right (str @world-temp "° ") 1)
- (put-right (str (count @animals) " ") 2)
- (s/move-cursor screen (from-right screen 1) 0)
- (s/redraw screen)))
+ (when @dirty
+ (reset! dirty false)
+ (letfn [(put-right [s y]
+ (s/put-string screen (from-right screen (.length s)) y s))]
+ (s/clear screen)
+ (draw-terrain! screen)
+ (draw-animals! screen)
+ (draw-landmarks! screen)
+ (put-right " SILT " 0)
+ (put-right (str @world-temp "° ") 1)
+ (put-right (str (count @animals) " ") 2)
+ (s/move-cursor screen (from-right screen 1) 0)
+ (s/redraw screen))))
; Input -----------------------------------------------------------------------
@@ -267,7 +274,8 @@
(:down \j) [x (+ y scale)]
(:left \h) [(- x scale) y]
(:right \l) [(+ x scale) y]))
- key))))
+ key))
+ (mark-dirty!)))
(defn update-animals! [key]
(dosync
@@ -283,15 +291,17 @@
\7 10000
\8 10000
\9 10000))))
- nil)
+ (mark-dirty!))
(defn update-temperature! [amt]
- (dosync (commute world-temp + amt)))
+ (dosync (commute world-temp + amt))
+ (mark-dirty!))
(defn reset-world! []
(reset-window!)
(reset-terrain!)
- (reset-animals!))
+ (reset-animals!)
+ (mark-dirty!))
(defn handle-input! [screen]
(while-let [key (s/get-key screen)]