123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- (in-package :flora-search-aurora.intermission)
- (defun intermission-state-update (title subtitle side-text progress return)
- "The input-taking/logic-handling component of the inventory state-function.
- Part of INVENTORY-STATE."
- (if (and (⌨:pressed-enter-p) (> progress 60))
- return
- (list :parameters
- (list :title title
- :subtitle subtitle
- :side-text side-text
- :return return
- :progress (…:at-most 107 (+ progress .5))))))
- (defun render-centered-line (matrix string &key (y 0))
- "Given a STRING and a Y-position, render it to the MATRIX centered horizontally."
- (✎:render-line
- matrix
- string
- (list :y y
- :x (floor (/ (- (second (array-dimensions matrix))
- (length string))
- 2)))))
- (defun intermission-state-draw (matrix title subtitle side-text progress)
- "The drawing component of the inventory state-function.
- Part of INVENTORY-STATE."
- (let* ((title (…:getf-lang title))
- (title-border (subseq (make-string (length title) :initial-element #\=)
- 0 (…:at-least 0 (…:at-most (length title)
- (floor (- progress 35)))))))
-
-
- (when (> progress 35)
-
- (render-centered-line matrix title :y 1)
-
- (render-centered-line matrix title-border :y 0)
- (render-centered-line matrix title-border :y 2)
-
- (render-centered-line matrix (…:getf-lang subtitle) :y 4)
-
- (✎:render-string matrix (…:getf-lang side-text) '(:x 15 :y 10) :width 47)
-
- (✎:render-line
- matrix
- (subseq (make-string (second (array-dimensions matrix))
- :initial-element #\~)
- 0 (…:at-least 0 (floor (- progress 35))))
- '(:x 0 :y 9)))))
- (defun intermission-state (matrix &key title subtitle side-text progress return)
- "A state-function for use with STATE-LOOP."
- (sleep .02)
- (intermission-state-draw matrix title subtitle side-text progress)
- (intermission-state-update title subtitle side-text progress return))
- (defun make-intermission-function (title subtitle side-text return)
- "Return a state-function for intermission, for use with STATE-LOOP."
- (lambda (matrix &key (title title) (subtitle subtitle) (side-text side-text) (return return) (progress 0))
- (funcall #'intermission-state
- matrix :title title :subtitle subtitle :side-text side-text :progress progress :return return)))
- (defun make-intermission-state (title subtitle side-text return)
- "Return a state-plist for intermission, for use with STATE-LOOP."
- (list :parameters nil
- :function
- (make-intermission-function title subtitle side-text return)))
|