File: widget_drawing.py.page

package info (click to toggle)
gnome-devel-docs 40.3-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 79,188 kB
  • sloc: javascript: 2,514; xml: 2,407; ansic: 2,229; python: 1,854; makefile: 805; sh: 499; cpp: 131
file content (138 lines) | stat: -rw-r--r-- 4,724 bytes parent folder | download
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
<?xml version="1.0" encoding="utf-8"?>
<page xmlns="http://projectmallard.org/1.0/" xmlns:its="http://www.w3.org/2005/11/its" xmlns:xi="http://www.w3.org/2001/XInclude" type="guide" style="task" id="widget_drawing.py" xml:lang="sv">
  <info>
    <title type="text">Widget (Python)</title>
    <link type="guide" xref="beginner.py#misc"/>
    <revision version="0.1" date="2013-02-24" status="stub"/>

    <credit type="author copyright">
      <name>Marta Maria Casetti</name>
      <email its:translate="no">mmcasetti@gmail.com</email>
      <years>2013</years>
    </credit>

    <desc>En komponent som använder Cairo-biblioteket för utritning</desc>
  
    <mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
      <mal:name>Sebastian Rasmussen</mal:name>
      <mal:email>sebras@gmail.com</mal:email>
      <mal:years>2019</mal:years>
    </mal:credit>
  
    <mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
      <mal:name>Anders Jonsson</mal:name>
      <mal:email>anders.jonsson@norsjovallen.se</mal:email>
      <mal:years>2021</mal:years>
    </mal:credit>
  </info>

  <title>Widget</title>
  <media type="image" mime="image/png" src="media/widget_drawing.png"/>
  <p>Ange en vinkel, visualisera den.</p>

  <links type="section"/>

  <section id="code">
  <title>Kod som använts för att generera detta exempel</title>

  <code mime="text/x-python" style="numbered">from gi.repository import Gtk
from gi.repository import cairo
import sys
import math


class MyWindow(Gtk.ApplicationWindow):

    def __init__(self, app):
        Gtk.Window.__init__(self, title="Välj en vinkel", application=app)
        self.set_default_size(400, 400)
        self.set_border_width(10)

        # en standardvinkel
        self.angle = 360

        grid = Gtk.Grid()

        # en stegningsruta som använder ett värde som vinkel
        ad = Gtk.Adjustment(360, 0, 360, 1, 0, 0)
        self.spin = Gtk.SpinButton(adjustment=ad, climb_rate=1, digits=0)
        self.spin.connect("value-changed", self.get_angle)

        # en rityta för att rita vad vi vill
        self.darea = Gtk.DrawingArea()
        # som vi beskriver i metoden draw(), ansluten till signalen ”draw”
        self.darea.connect("draw", self.draw)
        # vi måste begära en minsta storlek för ritytan, annars försvinner den
        self.darea.set_size_request(300, 300)

        grid.attach(self.spin, 0, 0, 1, 1)
        grid.attach(self.darea, 0, 1, 1, 1)

        self.add(grid)

    # närhelst vi får en ny vinkel i stegningsrutan
    def get_angle(self, event):
        self.angle = self.spin.get_value_as_int()
        # rita om det som finns i ritytan
        self.darea.queue_draw()

    def draw(self, darea, cr):
        # en 10 bildpunkter bred linje
        cr.set_line_width(10)
        # röd
        cr.set_source_rgba(0.5, 0.0, 0.0, 1.0)

        # få bredden och höjden på ritytan
        w = self.darea.get_allocated_width()
        h = self.darea.get_allocated_height()

        # gå till mitten på ritytan
        # (translatera från övre vänstra hörnet till w/2, h/2)
        cr.translate(w / 2, h / 2)
        # rita en linje till (55, 0)
        cr.line_to(55, 0)
        # och gå tillbaka till (0, 0)
        cr.line_to(0, 0)
        # rita en båge centrerad i origo, 50 bildpunkter bred, från vinkel 0
        # (i radianer) till vinkeln angiven av stegningsrutan (i grader)
        cr.arc(0, 0, 50, 0, self.angle * (math.pi / 180))
        # rita en linje tillbaka till origo
        cr.line_to(0, 0)
        # ritar banan, och behåller banan för framtida användning
        cr.stroke_preserve()

        # ställ in en färg
        cr.set_source_rgba(0.0, 0.5, 0.5, 1.0)
        # och använd den för att fylla banan (som vi hade behållit)
        cr.fill()


class MyApplication(Gtk.Application):

    def __init__(self):
        Gtk.Application.__init__(self)

    def do_activate(self):
        win = MyWindow(self)
        win.show_all()

    def do_startup(self):
        Gtk.Application.do_startup(self)

app = MyApplication()
exit_status = app.run(sys.argv)
sys.exit(exit_status)
</code>

  </section>
  
  <section id="references">
  <title>API-referenser</title>
  <p>I detta exempel använde vi följande:</p>
  <list>
    <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkWidget.html">GtkWidget</link></p></item>
    <item><p><link href="http://developer.gnome.org/gtk3/unstable/GtkDrawingArea.html">GtkDrawingArea</link></p></item>
    <item><p><link href="http://www.tortall.net/mu/wiki/CairoTutorial">Cairo-handledningen för Python-programmerare</link></p></item>
  </list>
  </section>
</page>