-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathscene.py
111 lines (91 loc) · 3.85 KB
/
scene.py
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
from pyrr import Matrix44
import moderngl as mgl
from util import *
from camera import Camera
class Scene:
def __init__(self, ctx):
self.ctx = ctx
self.camera = Camera()
self._init_shader()
self.load_grid()
self.load_point()
def _init_shader(self):
self._init_mesh_shader()
self._init_grid_shader()
self._init_point_shader()
def _init_mesh_shader(self):
vertex_shader = shader_from_path('basic_w_norm.vert')
fragment_shader = shader_from_path('basic_w_norm.frag')
self.prog = self.ctx.program(
vertex_shader=vertex_shader,
fragment_shader=fragment_shader,
)
self.mv = self.prog['mv']
self.mvp = self.prog['mvp']
self.const_color = self.prog['const_color']
def _init_grid_shader(self):
grid_vertex_shader = shader_from_path('basic.vert')
grid_fragment_shader = shader_from_path('basic.frag')
self.grid_prog = self.ctx.program(
vertex_shader=grid_vertex_shader,
fragment_shader=grid_fragment_shader,
)
self.grid_mvp = self.grid_prog['mvp']
self.grid_const_color = self.grid_prog['const_color']
def _init_point_shader(self):
point_vertex_shader = shader_from_path('point.vert')
point_fragment_shader = shader_from_path('point.frag')
self.point_prog = self.ctx.program(
vertex_shader=point_vertex_shader,
fragment_shader=point_fragment_shader,
)
self.point_mvp = self.point_prog['mvp']
self.point_const_color = self.point_prog['const_color']
def load_mesh(self, mesh):
self.release_mesh()
self.vbo = self.ctx.buffer(mesh['gldat'].astype('f4').tobytes())
self.ibo = self.ctx.buffer(mesh['glindex'].astype('i4').tobytes())
vao_content = [
(self.vbo, '3f 3f', 'in_vert', 'in_norm')
]
self.vao = self.ctx.vertex_array(self.prog, vao_content, self.ibo)
self.model = Matrix44.from_scale((0.1, 0.1, 0.1))
def release_mesh(self):
if hasattr(self, 'model'):
self.vbo.release()
self.ibo.release()
self.vao.release()
del self.model
def load_grid(self):
self.grid_vbo = self.ctx.buffer(grid(5, 10).astype('f4').tobytes())
self.grid_vao = self.ctx.simple_vertex_array(self.grid_prog, self.grid_vbo, 'in_vert')
self.grid_model = Matrix44.from_translation((0, 0, 0))
def load_point(self):
self.point_vbo = self.ctx.buffer(np.array([0.0, 0.0, 0.0]).astype('f4').tobytes())
self.point_vao = self.ctx.simple_vertex_array(self.point_prog, self.point_vbo, 'in_vert')
self.point_model = Matrix44.from_translation((0, 0, 0))
def clear(self, color=(0.23, 0.23, 0.23)):
self.ctx.clear(*color)
def draw_grid(self):
mvp = self.camera.view_proj() * self.grid_model
self.grid_mvp.write(mvp.astype('f4').tobytes())
self.grid_const_color.value = (0.3, 0.3, 0.3)
self.grid_vao.render(mgl.LINES)
def draw_point(self):
mvp = self.camera.view_proj() * self.point_model
self.point_mvp.write(mvp.astype('f4').tobytes())
self.point_const_color.value = (1.0, 0.0, 0.0)
self.point_vao.render(mgl.POINTS)
def draw_mesh(self):
if hasattr(self, 'model'):
mv = self.camera.view() * self.model
mvp = self.camera.proj() * mv
self.mv.write(mv.astype('f4').tobytes())
self.mvp.write(mvp.astype('f4').tobytes())
self.const_color.value = (0.8, 0.8, 0.8)
self.vao.render()
def draw(self):
self.clear()
self.draw_grid()
self.draw_point()
self.draw_mesh()