forked from Shirakumo/trial
-
Notifications
You must be signed in to change notification settings - Fork 0
/
fps.lisp
81 lines (71 loc) · 2.86 KB
/
fps.lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
(in-package #:org.shirakumo.fraf.trial)
;;;; Very fast FPS display. Focus is on reducing GPU load.
(define-asset (trial fps-counter) mesh
(with-mesh-construction (v finalize (location uv) NIL)
(loop for x from 0 by 16
repeat 6
do (v (+ x 16) 16 0 0.1 1)
(v (+ x 0) 16 0 0 1)
(v (+ x 0) 0 0 0 0)
(v (+ x 0) 0 0 0 0)
(v (+ x 16) 0 0 0.1 0)
(v (+ x 16) 16 0 0.1 1))
(finalize-data))
:data-usage :stream-draw)
(declaim (type (unsigned-byte 60) +frame-count+ +start-time+))
(define-global +frame-count+ 0)
(define-global +start-time+ 0)
(define-shader-entity fps-counter (renderable)
((name :initform 'fps-counter)))
(defmethod stage :after ((counter fps-counter) (area staging-area))
(stage (// 'trial 'fps-counter) area)
(stage (// 'trial 'ascii) area))
(defmethod render ((counter fps-counter) (program shader-program))
(declare (optimize speed (safety 1)))
(let* ((vao (// 'trial 'fps-counter))
(now (get-internal-real-time))
(dt (- now +start-time+)))
(incf +frame-count+)
(when (<= (/ internal-time-units-per-second 10) dt)
(let* ((fps (floor (/ +frame-count+ (/ dt internal-time-units-per-second))))
(buf (caadr (bindings vao)))
(dat (buffer-data buf)))
(declare (type (simple-array single-float) dat))
(declare (type (unsigned-byte 32) fps))
(setf +start-time+ now)
(setf +frame-count+ 0)
(flet ((set-rect (i d)
(let* ((glyphs #.(truncate (fourth (texture-source-src (load-image (input* (asset 'trial 'ascii)) T))) 9))
(b (* 5 (* 6 i)))
(d0 (* (+ d 16) (/ 1.0 glyphs)))
(d1 (+ d0 (/ 1.0 glyphs))))
(setf (aref dat (+ b 3)) d1)
(setf (aref dat (+ b 8)) d0)
(setf (aref dat (+ b 13)) d0)
(setf (aref dat (+ b 18)) d0)
(setf (aref dat (+ b 23)) d1)
(setf (aref dat (+ b 28)) d1))))
(loop for i downfrom 5 to 0
for div = 1 then (* 10 div)
do (set-rect i (mod (floor fps div) 10))))
(update-buffer-data buf T)))
(bind (// 'trial 'ascii) :texture0)
(with-depth-mask T
(render vao program))))
(define-class-shader (fps-counter :vertex-shader)
"
layout (location = TRIAL_V_LOCATION) in vec3 position;
layout (location = TRIAL_V_UV) in vec2 in_uv;
out vec2 uv;
void main(){
gl_Position = mat4(0.0015625, 0.0, 0.0, 0.0, 0.0, 0.0027777778, 0.0, 0.0, 0.0, 0.0, -0.02, 0.0, -1.0, -1.0, -1.0, 1.0)
* vec4(position, 1.0);
uv = in_uv;
}")
(define-class-shader (fps-counter :fragment-shader)
"uniform sampler2D texture_image;
in vec2 uv;
out vec4 color;
void main(){
color = texture(texture_image, uv);
}")