annotate src/parpg/grease/renderer/vector.py @ 27:09b581087d68

Added base files for grease
author KarstenBock@gmx.net
date Tue, 12 Jul 2011 10:16:48 +0200
parents
children
rev   line source
27
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
1 #############################################################################
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
2 #
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
3 # Copyright (c) 2010 by Casey Duncan and contributors
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
4 # All Rights Reserved.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
5 #
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
6 # This software is subject to the provisions of the MIT License
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
7 # A copy of the license should accompany this distribution.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
8 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
9 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
10 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
11 #
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
12 #############################################################################
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
13
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
14 __version__ = '$Id$'
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
15
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
16 __all__ = ('Vector',)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
17
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
18 from grease.geometry import Vec2d
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
19 import ctypes
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
20 from math import sin, cos, radians
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
21 import pyglet
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
22
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
23
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
24 class Vector(object):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
25 """Renders shapes in a classic vector graphics style
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
26
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
27 :param scale: Scaling factor applied to shape vertices when rendered.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
28
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
29 :param line_width: The line width provided to ``glLineWidth`` before rendering.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
30 If not specified or None, ``glLineWidth`` is not called, and the line
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
31 width used is determined by the OpenGL state at the time of rendering.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
32
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
33 :param anti_alias: If ``True``, OpenGL blending and line smoothing is enabled.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
34 This allows for fractional line widths as well. If ``False``, the blending
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
35 and line smoothing modes are unchanged.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
36
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
37 :param corner_fill: If true (the default), the shape corners will be filled
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
38 with round points when the ``line_width`` exceeds 2.0. This improves
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
39 the visual quality of the rendering at larger line widths at some
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
40 cost to performance. Has no effect if ``line_width`` is not specified.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
41
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
42 :param position_component: Name of :class:`grease.component.Position`
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
43 component to use. Shapes rendered are offset by the entity positions.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
44
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
45 :param renderable_component: Name of :class:`grease.component.Renderable`
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
46 component to use. This component specifies the entities to be
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
47 rendered and their base color.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
48
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
49 :param shape_component: Name of :class:`grease.component.Shape`
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
50 component to use. Source of the shape vertices for each entity.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
51
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
52 The entities rendered are taken from the intersection of he position,
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
53 renderable and shape components each time :meth:`draw` is called.
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
54 """
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
55
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
56 CORNER_FILL_SCALE = 0.6
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
57 CORNER_FILL_THRESHOLD = 2.0
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
58
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
59 def __init__(self, scale=1.0, line_width=None, anti_alias=True, corner_fill=True,
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
60 position_component='position',
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
61 renderable_component='renderable',
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
62 shape_component='shape'):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
63 self.scale = float(scale)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
64 self.corner_fill = corner_fill
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
65 self.line_width = line_width
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
66 self.anti_alias = anti_alias
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
67 self._max_line_width = None
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
68 self.position_component = position_component
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
69 self.renderable_component = renderable_component
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
70 self.shape_component = shape_component
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
71
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
72 def set_world(self, world):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
73 self.world = world
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
74
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
75 def _generate_verts(self):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
76 """Generate vertex and index arrays for rendering"""
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
77 vert_count = sum(len(shape.verts) + 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
78 for shape, ignored, ignored in self.world.components.join(
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
79 self.shape_component, self.position_component, self.renderable_component))
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
80 v_array = (CVertColor * vert_count)()
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
81 if vert_count > 65536:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
82 i_array = (ctypes.c_uint * 2 * vert_count)()
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
83 i_size = pyglet.gl.GL_UNSIGNED_INT
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
84 else:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
85 i_array = (ctypes.c_ushort * (2 * vert_count))()
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
86 i_size = pyglet.gl.GL_UNSIGNED_SHORT
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
87 v_index = 0
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
88 i_index = 0
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
89 scale = self.scale
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
90 rot_vec = Vec2d(0, 0)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
91 for shape, position, renderable in self.world.components.join(
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
92 self.shape_component, self.position_component, self.renderable_component):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
93 shape_start = v_index
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
94 angle = radians(-position.angle)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
95 rot_vec.x = cos(angle)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
96 rot_vec.y = sin(angle)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
97 r = int(renderable.color.r * 255)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
98 g = int(renderable.color.g * 255)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
99 b = int(renderable.color.b * 255)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
100 a = int(renderable.color.a * 255)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
101 for vert in shape.verts:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
102 vert = vert.cpvrotate(rot_vec) * scale + position.position
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
103 v_array[v_index].vert.x = vert.x
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
104 v_array[v_index].vert.y = vert.y
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
105 v_array[v_index].color.r = r
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
106 v_array[v_index].color.g = g
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
107 v_array[v_index].color.b = b
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
108 v_array[v_index].color.a = a
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
109 if v_index > shape_start:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
110 i_array[i_index] = v_index - 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
111 i_index += 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
112 i_array[i_index] = v_index
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
113 i_index += 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
114 v_index += 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
115 if shape.closed and v_index - shape_start > 2:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
116 i_array[i_index] = v_index - 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
117 i_index += 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
118 i_array[i_index] = shape_start
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
119 i_index += 1
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
120 return v_array, i_size, i_array, i_index
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
121
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
122 def draw(self, gl=pyglet.gl):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
123 vertices, index_size, indices, index_count = self._generate_verts()
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
124 if index_count:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
125 if self.anti_alias:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
126 gl.glEnable(gl.GL_LINE_SMOOTH)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
127 gl.glHint(gl.GL_LINE_SMOOTH_HINT, gl.GL_NICEST)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
128 gl.glEnable(gl.GL_BLEND)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
129 gl.glBlendFunc(gl.GL_SRC_ALPHA, gl.GL_ONE_MINUS_SRC_ALPHA)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
130 gl.glPushClientAttrib(gl.GL_CLIENT_VERTEX_ARRAY_BIT)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
131 gl.glEnableClientState(gl.GL_VERTEX_ARRAY)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
132 gl.glEnableClientState(gl.GL_COLOR_ARRAY)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
133 gl.glVertexPointer(
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
134 2, gl.GL_FLOAT, ctypes.sizeof(CVertColor), ctypes.pointer(vertices))
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
135 gl.glColorPointer(
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
136 4, gl.GL_UNSIGNED_BYTE, ctypes.sizeof(CVertColor),
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
137 ctypes.pointer(vertices[0].color))
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
138 if self.line_width is not None:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
139 gl.glLineWidth(self.line_width)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
140 if self._max_line_width is None:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
141 range_out = (ctypes.c_float * 2)()
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
142 gl.glGetFloatv(gl.GL_ALIASED_LINE_WIDTH_RANGE, range_out)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
143 self._max_line_width = float(range_out[1]) * self.CORNER_FILL_SCALE
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
144 if self.corner_fill and self.line_width > self.CORNER_FILL_THRESHOLD:
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
145 gl.glEnable(gl.GL_POINT_SMOOTH)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
146 gl.glPointSize(
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
147 min(self.line_width * self.CORNER_FILL_SCALE, self._max_line_width))
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
148 gl.glDrawArrays(gl.GL_POINTS, 0, index_count)
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
149 gl.glDrawElements(gl.GL_LINES, index_count, index_size, ctypes.pointer(indices))
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
150 gl.glPopClientAttrib()
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
151
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
152
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
153 class CVert(ctypes.Structure):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
154 _fields_ = [("x", ctypes.c_float), ("y", ctypes.c_float)]
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
155
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
156 class CColor(ctypes.Structure):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
157 _fields_ = [
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
158 ("r", ctypes.c_ubyte),
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
159 ("g", ctypes.c_ubyte),
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
160 ("b", ctypes.c_ubyte),
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
161 ("a", ctypes.c_ubyte),
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
162 ]
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
163
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
164 class CVertColor(ctypes.Structure):
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
165 _fields_ = [("vert", CVert), ("color", CColor)]
09b581087d68 Added base files for grease
KarstenBock@gmx.net
parents:
diff changeset
166