2012-10-07 17:31:32 +00:00
|
|
|
.. _graphics:
|
|
|
|
|
|
|
|
Graphics
|
|
|
|
========
|
|
|
|
|
|
|
|
Introduction to Canvas
|
|
|
|
----------------------
|
|
|
|
|
2012-11-27 00:42:13 +00:00
|
|
|
Widgets graphical representation is done using a canvas, which you can see both
|
|
|
|
as an unlimited drawing board, and as a set of drawing instructions, there are
|
|
|
|
numerous different instructions you can apply (add) to your canvas, but there
|
|
|
|
is two main kind of them:
|
|
|
|
|
2013-03-24 20:08:25 +00:00
|
|
|
- :mod:`context instructions <kivy.graphics.context_instructions>`
|
|
|
|
- :mod:`vertex instructions <kivy.graphics.vertex_instructions>`
|
2012-11-27 00:42:13 +00:00
|
|
|
|
|
|
|
Context instructions don't draw anything, but they change the results of the
|
2013-03-24 20:08:25 +00:00
|
|
|
vertex instructions.
|
2012-11-27 00:42:13 +00:00
|
|
|
|
2013-03-21 00:29:58 +00:00
|
|
|
Canvasses can contain two subsets of instructions. They are the
|
|
|
|
:mod:`canvas.before <kivy.graphics.Canvas.before>` and the :mod:`canvas.after
|
|
|
|
<kivy.graphics.Canvas.after>` instruction groups. The instructions in these
|
|
|
|
groups will be executed before and after the :mod:`~kivy.graphics.canvas` group
|
|
|
|
respectively. This means that they will appear under (be executed before) and
|
|
|
|
above (be executed after) them.
|
2014-10-20 21:03:16 +00:00
|
|
|
Those groups are not created until the user accesses them.
|
2013-03-21 00:29:58 +00:00
|
|
|
|
|
|
|
To add a canvas instruction to a widget, you use the canvas context:
|
2013-03-20 03:40:45 +00:00
|
|
|
|
|
|
|
.. code-block:: python
|
2012-11-27 00:42:13 +00:00
|
|
|
|
|
|
|
class MyWidget(Widget):
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
super(MyWidget, self).__init__(**kwargs)
|
|
|
|
with self.canvas:
|
|
|
|
# add your instruction for main canvas here
|
|
|
|
|
|
|
|
with self.canvas.before:
|
|
|
|
# you can use this to add instructions rendered before
|
|
|
|
|
|
|
|
with self.canvas.after:
|
|
|
|
# you can use this to add instructions rendered after
|
|
|
|
|
2012-10-07 17:31:32 +00:00
|
|
|
Context instructions
|
|
|
|
--------------------
|
|
|
|
|
2012-11-27 00:42:13 +00:00
|
|
|
Context instructions manipulate the opengl context, you can rotate, translate,
|
2012-11-28 11:44:35 +00:00
|
|
|
and scale your canvas, attach a texture or change the drawing color, this one
|
|
|
|
is the most commonly used, but others are really useful too::
|
2012-11-27 00:42:13 +00:00
|
|
|
|
|
|
|
with self.canvas.before:
|
|
|
|
Color(1, 0, .4, mode='rgb')
|
|
|
|
|
2012-10-07 17:31:32 +00:00
|
|
|
Drawing instructions
|
|
|
|
--------------------
|
|
|
|
|
2012-11-28 11:44:35 +00:00
|
|
|
Drawing instructions are ranging from very simple ones, to draw a line or a
|
|
|
|
polygon, to more complex ones, like meshes or bezier curves::
|
|
|
|
|
|
|
|
with self.canvas:
|
|
|
|
# draw a line using the default color
|
|
|
|
Line(points=(x1, y1, x2, y2, x3, y3))
|
|
|
|
|
|
|
|
# lets draw a semi-transparent red square
|
|
|
|
Color(1, 0, 0, .5, mode='rgba')
|
2014-08-23 11:45:04 +00:00
|
|
|
Rectangle(pos=self.pos, size=self.size)
|
2012-11-28 11:44:35 +00:00
|
|
|
|
2012-10-07 17:31:32 +00:00
|
|
|
Manipulating instructions
|
|
|
|
-------------------------
|
|
|
|
|
2012-11-29 23:32:04 +00:00
|
|
|
Sometime, you want to update or remove the instructions you added to a canvas,
|
2012-11-28 11:44:35 +00:00
|
|
|
this can be done in various ways depending on your needs:
|
|
|
|
|
2013-03-19 10:32:41 +00:00
|
|
|
You can keep a reference to your instructions and update them::
|
2012-11-28 11:44:35 +00:00
|
|
|
|
|
|
|
class MyWidget(Widget):
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
super(MyWidget, self).__init__(**kwargs)
|
|
|
|
with self.canvas:
|
|
|
|
self.rect = Rectangle(pos=self.pos, size=self.size)
|
|
|
|
|
|
|
|
self.bind(pos=self.update_rect)
|
|
|
|
self.bind(size=self.update_rect)
|
|
|
|
|
|
|
|
def update_rect(self, *args):
|
|
|
|
self.rect.pos = self.pos
|
|
|
|
self.rect.size = self.size
|
|
|
|
|
|
|
|
|
2012-11-28 11:47:57 +00:00
|
|
|
Or you can clean your canvas and start fresh::
|
2012-11-28 11:44:35 +00:00
|
|
|
|
|
|
|
class MyWidget(Widget):
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
super(MyWidget, self).__init__(**kwargs)
|
|
|
|
self.draw_my_stuff()
|
|
|
|
|
|
|
|
self.bind(pos=self.draw_my_stuff)
|
|
|
|
self.bind(size=self.draw_my_stuff)
|
|
|
|
|
|
|
|
def draw_my_stuff(self):
|
|
|
|
self.canvas.clear()
|
|
|
|
|
|
|
|
with self.canvas:
|
|
|
|
self.rect = Rectangle(pos=self.pos, size=self.size)
|
|
|
|
|
2014-08-25 16:40:21 +00:00
|
|
|
Note that updating the instructions is considered the best practise as it
|
2014-09-21 15:08:29 +00:00
|
|
|
involves less overhead and avoids creating new instructions.
|