Zeichnung in PyGobject (Python ist3)

Ich versuche, schreiben Sie einfachen Grafik-editor mit PyGObject und python 3.
Ich brauche zum zeichnen von Linien mit unterschiedlicher Farbe und Breite mit der Maus. Ich fand viele Beispiele dafür, wie diese aber nichts mehr Komplex.

Wie Speichere ich Bild gezeichnet zwischen "draw" - Veranstaltungen? Gibt es inkrementelle Art zu zeichnen, oder muss ich den neu zu zeichnenden Bereich auf jeder "draw" - event? Ich fand heraus, dass ich sparen kann, Weg aber wie kann ich das speichern, Breite und Farben der gezeichneten Linien? Gibt es Weg erstellen Sie Bild außen 'ziehen' callback und gelten nur für die (draw) es innerhalb Rückruf?

Hier ist, was ich für jetzt.

#!/usr/bin/env python
# -*- coding: utf-8 -*-

from gi.repository import Gtk, Gdk
import os

class App(object):

    main_ui = os.path.join(os.path.dirname(__file__), 'gui.glade')

    def __init__(self):
        self.builder = Gtk.Builder()
        self.builder.add_from_file(self.main_ui)

        self.main_window.connect('destroy', self.quit)
        self.mw_quit_button.connect('clicked', self.quit)

        self.mw_graph_editor_button.connect('clicked', self.show_window, self.graph_editor_window)
        self.graph_editor_window.connect('delete-event', self.hide_window_delete)

        self.ge_menubar_file_quit.connect('activate', self.hide_window, self.graph_editor_window)
        self.ge_toolbar_quit.connect('clicked', self.hide_window, self.graph_editor_window)

        self.ge_drawingarea.connect('motion-notify-event', self.pointer_motion)
        self.ge_drawingarea.connect('motion-notify-event', self.show_coordinates)
        self.ge_drawingarea.connect('draw', self.draw_callback)

        self.path = None
        self.coord = (0, 0)
        self.rgb = (0, 0, 0)

    def __getattr__(self, name):
        obj = self.builder.get_object(name)
        if not obj:
            raise AttributeError("Object {0} has no attribute {1}".format(self, name))
        setattr(self, name, obj)
        return obj

    def draw_callback(self, drawingarea, cr):
        if self.path:
            cr.append_path(self.path)
        cr.line_to(self.coord[0], self.coord[1])
        cr.set_source_rgba(*self.rgb)
        self.path = cr.copy_path_flat()
        cr.stroke()

    def show_coordinates(self, window, event):
        self.ge_mouse_coordinates.set_label('X: {0:.0f} Y: {1:.0f}'.format(event.x, event.y))

    def pointer_motion(self, widget, event):
        if event.state & Gdk.ModifierType.BUTTON1_MASK:
            self.draw(widget, event.x, event.y)
        elif event.state & Gdk.ModifierType.BUTTON3_MASK:
            self.draw(widget, event.x, event.y, True)

    def draw(self, widget, x, y, erase=False):
        self.coord = (x,y)
        if erase:
            self.rgb = (256, 256, 256)
        else:
            self.rgb = (0, 0, 0)
        widget.queue_draw()

    def show_window(self, widget, data):
        data.show_all()

    def hide_window_delete(self, widget, event):
        widget.hide()
        return True

    def hide_window(self, widget, window):
        window.hide()

    def run(self):
        self.main_window.show_all()
        Gtk.main()

    def quit(self, widget=None, data=None):
        self.main_window.destroy()
        Gtk.main_quit()


if __name__ == "__main__":
    app = App()
    app.run()

Sorry für mein Deutsch, es ist nicht meine Muttersprache.

  • Sie könnte prüfen, kritzeln B. in Qt, um die Logik. Ich würde das gleiche tun. Zeichnen Sie in einem inneren Besitz cairo_surface, und dann an jeder Ziehung-Signale, kopieren Sie den Puffer, um den widget Rahmen, und fertig,
InformationsquelleAutor zaquest | 2012-04-22
Schreibe einen Kommentar