blob: 06f081e75592acbe9434b7bd7615518e4d849e26 (
plain)
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
82
83
84
85
86
|
;;;; bitmap.lisp
(in-package #:wheelwork)
(defvar *bitmap-shader-program* nil
"Cached for later cleanup.")
(defvar *bitmap-vao* nil)
(defvar *bitmap-count* 0
"Used by finalizers to determin if the shader should be destroyed.")
(defun bitmap-finalizer ()
"executed after a bitmap has been reclaimed by gc. decrements bitmap
count and destroys shader-program if necessary."
(decf *bitmap-count*)
(when (zerop *bitmap-count*)
(when *bitmap-vao*
(gl:delete-vertex-arrays (list *bitmap-vao*))
(setf *bitmap-vao* nil))
(when *bitmap-shader-program*
(gl:delete-program *bitmap-shader-program*)
(setf *bitmap-shader-program* nil))))
(defclass/std bitmap (affine interactive)
((texture :ri :std (error "A bitmap requires a texture."))))
(defmethod initialize-instance :after ((bitmap bitmap) &key)
(incf *bitmap-count*)
(trivial-garbage:finalize bitmap #'bitmap-finalizer)
(with-slots (base-width base-height texture) bitmap
(setf base-height (texture-height texture)
base-width (texture-width texture))
(unless *bitmap-shader-program*
(setf *bitmap-shader-program*
(create-shader
'(:vertex
((vert :vec2))
((transform :mat4))
((values
(* transform (vari:vec4 vert 0.0 1.0))
vert))) ;color
'(:fragment
((tc :vec2))
((tex :sampler-2d))
((let ((frag (vari:texture tex tc)))
(if (< (aref frag 3) 0.01)
(vari:discard)
frag))))))
(gl:program-uniformi
*bitmap-shader-program*
(gl:get-uniform-location *bitmap-shader-program* "TEX")
0))
(unless *bitmap-vao*
(setf *bitmap-vao* (gl:gen-vertex-array))
(gl:bind-vertex-array *bitmap-vao*)
(let ((vbo (gl:gen-buffer)))
(with-gl-array (verts :float
0.0 1.0
1.0 0.0
0.0 0.0
0.0 1.0
1.0 1.0
1.0 0.0 )
(gl:bind-buffer :array-buffer vbo)
(gl:buffer-data :array-buffer :static-draw verts)))
(gl:enable-vertex-attrib-array 0)
(gl:vertex-attrib-pointer 0 2 :float 0 (* +float-size+ 2) 0)
(gl:bind-buffer :array-buffer 0)
(gl:bind-vertex-array 0))))
(defmethod cleanup ((bitmap bitmap))
(bitmap-finalizer))
(defmethod render ((bitmap bitmap))
(with-slots (texture) bitmap
(gl:active-texture 0)
(gl:bind-texture :texture-2d (texture-id texture))
(gl:use-program *bitmap-shader-program*)
(gl:program-uniform-matrix-4fv
*bitmap-shader-program*
(gl:get-uniform-location *bitmap-shader-program* "TRANSFORM")
(projected-matrix bitmap))
(gl:bind-vertex-array *bitmap-vao*)
(gl:draw-arrays :triangles 0 6)
(gl:bind-vertex-array 0)))
|