aboutsummaryrefslogtreecommitdiff
path: root/demo/sgi/gl_panel/twoview/block.py
blob: a40c8e9c12a8dde7f662651b90fcdb58cdd6a2cc (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
# 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()