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
|
# module 'block' imported by twoview demo.
from gl import n3f, bgnpolygon, varray, endpolygon, lmbind
from GL import MATERIAL
# Draw a single 2x2x2 block with its center at (0, 0, 0)
# Arguments are the material indices (0 = don't call lmbind)
#
def block(m_front, m_back, m_left, m_right, m_top, m_bottom):
#
# Distances defining the sides
#
x_left = -1.0
x_right = 1.0
y_top = 1.0
y_bottom = -1.0
z_front = 1.0
z_back = -1.0
#
# Top surface points: A, B, C, D
#
A = x_right, y_top, z_front
B = x_right, y_top, z_back
C = x_left, y_top, z_back
D = x_left, y_top, z_front
#
# Bottom surface points: E, F, G, H
#
E = x_right, y_bottom, z_front
F = x_right, y_bottom, z_back
G = x_left, y_bottom, z_back
H = x_left, y_bottom, z_front
#
# Draw front face
#
if m_front: lmbind(MATERIAL, m_front)
n3f(0.0, 0.0, 1.0)
face(H, E, A, D)
#
# Draw back face
#
if m_back: lmbind(MATERIAL, m_back)
n3f(0.0, 0.0, -1.0)
face(G, F, B, C)
#
# Draw left face
#
if m_left: lmbind(MATERIAL, m_left)
n3f(-1.0, 0.0, 0.0)
face(G, H, D, C)
#
# Draw right face
#
if m_right: lmbind(MATERIAL, m_right)
n3f(1.0, 0.0, 0.0)
face(F, E, A, B)
#
# Draw top face
#
if m_top: lmbind(MATERIAL, m_top)
n3f(0.0, 1.0, 0.0)
face(A, B, C, D)
#
# Draw bottom face
#
if m_bottom: lmbind(MATERIAL, m_bottom)
n3f(0.0, -1.0, 0.0)
face(E, F, G, H)
def face(points):
bgnpolygon()
varray(points)
endpolygon()
|