2015-02-01 19:26:16 +00:00
|
|
|
'''
|
|
|
|
Lines Extended Demo
|
|
|
|
===================
|
|
|
|
|
|
|
|
This demonstrates how to use the extended line drawing routines such
|
2016-09-07 09:23:44 +00:00
|
|
|
as circles, ellipses, and rectangles. You should see a static image of
|
2015-02-01 19:26:16 +00:00
|
|
|
labelled shapes on the screen.
|
|
|
|
'''
|
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
from kivy.app import App
|
|
|
|
from kivy.uix.gridlayout import GridLayout
|
|
|
|
from kivy.uix.widget import Widget
|
|
|
|
from kivy.lang import Builder
|
|
|
|
|
|
|
|
Builder.load_string('''
|
|
|
|
<LineEllipse1>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: 1, .1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
|
|
|
ellipse: (self.x, self.y, self.width, self.height)
|
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Ellipse'
|
|
|
|
|
|
|
|
<LineEllipse2>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: 1, .1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
|
|
|
ellipse: (self.x, self.y, self.width, self.height, 90, 180)
|
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Ellipse from 90 to 180'
|
|
|
|
|
|
|
|
# fun result with low segments!
|
|
|
|
<LineEllipse3>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: 1, .1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
|
|
|
ellipse: (self.x, self.y, self.width, self.height, 90, 720, 10)
|
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Ellipse from 90 to 720\\n10 segments'
|
|
|
|
halign: 'center'
|
|
|
|
|
|
|
|
<LineCircle1>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: .1, 1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
2015-03-21 15:58:01 +00:00
|
|
|
circle:
|
|
|
|
(self.center_x, self.center_y, min(self.width, self.height)
|
|
|
|
/ 2)
|
2012-09-26 16:43:03 +00:00
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Circle'
|
|
|
|
|
|
|
|
<LineCircle2>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: .1, 1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
2015-03-21 15:58:01 +00:00
|
|
|
circle:
|
|
|
|
(self.center_x, self.center_y, min(self.width, self.height)
|
|
|
|
/ 2, 90, 180)
|
2012-09-26 16:43:03 +00:00
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Circle from 90 to 180'
|
|
|
|
|
|
|
|
<LineCircle3>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: .1, 1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
2015-03-21 15:58:01 +00:00
|
|
|
circle:
|
|
|
|
(self.center_x, self.center_y, min(self.width, self.height)
|
|
|
|
/ 2, 90, 180, 10)
|
2012-09-26 16:43:03 +00:00
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Circle from 90 to 180\\n10 segments'
|
|
|
|
halign: 'center'
|
|
|
|
|
2013-04-15 21:11:26 +00:00
|
|
|
<LineCircle4>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: .1, 1, .1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
2015-03-21 15:58:01 +00:00
|
|
|
circle:
|
|
|
|
(self.center_x, self.center_y, min(self.width, self.height)
|
|
|
|
/ 2, 0, 360)
|
2013-04-15 21:11:26 +00:00
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Circle from 0 to 360'
|
|
|
|
halign: 'center'
|
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
<LineRectangle>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: .1, .1, 1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
|
|
|
rectangle: (self.x, self.y, self.width, self.height)
|
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Rectangle'
|
2012-10-01 15:00:19 +00:00
|
|
|
|
|
|
|
<LineBezier>:
|
|
|
|
canvas:
|
|
|
|
Color:
|
|
|
|
rgba: .1, .1, 1, .9
|
|
|
|
Line:
|
|
|
|
width: 2.
|
2015-03-21 15:58:01 +00:00
|
|
|
bezier:
|
|
|
|
(self.x, self.y, self.center_x - 40, self.y + 100,
|
|
|
|
self.center_x + 40, self.y - 100, self.right, self.y)
|
2012-10-01 15:00:19 +00:00
|
|
|
Label:
|
|
|
|
center: root.center
|
|
|
|
text: 'Bezier'
|
2012-09-26 16:43:03 +00:00
|
|
|
''')
|
|
|
|
|
|
|
|
|
|
|
|
class LineEllipse1(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineEllipse2(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineEllipse3(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineCircle1(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineCircle2(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineCircle3(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2013-04-15 21:11:26 +00:00
|
|
|
class LineCircle4(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineRectangle(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-10-01 15:00:19 +00:00
|
|
|
class LineBezier(Widget):
|
|
|
|
pass
|
|
|
|
|
2015-02-02 01:09:20 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
class LineExtendedApp(App):
|
|
|
|
def build(self):
|
|
|
|
root = GridLayout(cols=2, padding=50, spacing=50)
|
|
|
|
root.add_widget(LineEllipse1())
|
|
|
|
root.add_widget(LineEllipse2())
|
|
|
|
root.add_widget(LineEllipse3())
|
|
|
|
root.add_widget(LineCircle1())
|
|
|
|
root.add_widget(LineCircle2())
|
|
|
|
root.add_widget(LineCircle3())
|
2013-04-15 21:11:26 +00:00
|
|
|
root.add_widget(LineCircle4())
|
2012-09-26 16:43:03 +00:00
|
|
|
root.add_widget(LineRectangle())
|
2012-10-01 15:00:19 +00:00
|
|
|
root.add_widget(LineBezier())
|
2012-09-26 16:43:03 +00:00
|
|
|
return root
|
|
|
|
|
2016-12-17 07:50:52 +00:00
|
|
|
|
2012-09-26 16:43:03 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
LineExtendedApp().run()
|