-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathParticleViewer.py
107 lines (80 loc) · 2.03 KB
/
ParticleViewer.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
import sys
from OpenGL.GL import *
from OpenGL.GLU import *
from OpenGL.GLUT import *
from particles.system import System
WIDTH = 640
HEIGHT = 480
class Global:
system = None
mvmat = []
pmat = []
def draw_background():
glMatrixMode(GL_PROJECTION)
glPushMatrix()
glLoadIdentity()
glMatrixMode(GL_MODELVIEW)
glPushMatrix()
glLoadIdentity()
glDepthMask(GL_FALSE)
glBegin(GL_QUADS)
glColor3f(0.6, 0.6, 0.6)
glVertex2f(-1.0, 1.0)
glVertex2f(1.0, 1.0)
glColor3f(0.2, 0.2, 0.2)
glVertex2f(1.0, -1.0)
glVertex2f(-1.0, -1.0)
glEnd()
glDepthMask(GL_TRUE)
glPopMatrix()
glMatrixMode(GL_PROJECTION)
glPopMatrix()
def draw_axis():
glBegin(GL_LINES)
glColor3f(1.0, 0.0, 0.0)
glVertex3f(0.0, 0.0, 0.0)
glVertex3f(1.0, 0.0, 0.0)
glEnd()
glBegin(GL_LINES)
glColor3f(0.0, 1.0, 0.0)
glVertex3f(0.0, 0.0, 0.0)
glVertex3f(0.0, 1.0, 0.0)
glEnd()
glBegin(GL_LINES)
glColor3f(0.0, 0.0, 1.0)
glVertex3f(0.0, 0.0, 0.0)
glVertex3f(0.0, 0.0, 1.0)
glEnd()
def display():
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)
draw_background()
draw_axis()
if Global.system:
Global.system.draw(Global.mvmat, Global.pmat)
glutSwapBuffers()
def reshape(w, h):
aspect = float(WIDTH)/float(HEIGHT)
glViewport(0, 0, WIDTH, HEIGHT)
glMatrixMode(GL_PROJECTION)
glLoadIdentity()
size = .3
glFrustum(-aspect * size, aspect * size, -size, size, 0.5, 20)
glMatrixMode(GL_MODELVIEW);
glLoadIdentity()
gluLookAt(7, -6, 7, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0)
Global.pmat = glGetFloatv(GL_PROJECTION_MATRIX)
Global.mvmat = glGetFloatv(GL_MODELVIEW_MATRIX)
if __name__ == '__main__':
glutInit()
glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE | GLUT_DEPTH)
glutInitWindowSize(WIDTH,HEIGHT)
glutCreateWindow(b"Particle Viewer")
if len(sys.argv) > 1:
filename = sys.argv[1]
Global.system = System.load(filename)
else:
print("No filename given")
glutReshapeFunc(reshape)
glutDisplayFunc(display)
glutIdleFunc(display)
glutMainLoop()