Я только начинаю использовать pycairo и столкнулся со следующей интересной ошибкой. Программа, которую я пишу, создает простое окно gtk, рисует на нем прямоугольник, а затем имеет функцию обратного вызова для рисования случайной линии на любом виде ввода с клавиатуры. Однако, похоже, что при каждом вводе с клавиатуры мне приходится создавать новый контекст, или я получаю сообщение об ошибке в тот момент, когда программа получает первый ввод с клавиатуры (в частности, в строке .stroke ()). Ошибка заключается в следующем, если это имеет значение. 'BadDrawable (неверный параметр Pixmap или Window)'. (Подробности: серийный номер 230, код ошибки 9, код запроса 53, младший код 0)
#! /usr/bin/env python
import pygtk
pygtk.require('2.0')
import gtk, gobject, cairo, math, random
# Create a GTK+ widget on which we will draw using Cairo
class Screen(gtk.DrawingArea):
# Draw in response to an expose-event
__gsignals__ = { "expose-event": "override" }
# Handle the expose-event by drawing
def do_expose_event(self, event):
# Create the cairo context
self.cr = self.window.cairo_create()
# Restrict Cairo to the exposed area; avoid extra work
self.cr.rectangle(event.area.x, event.area.y, event.area.width, event.area.height)
self.cr.clip()
self.draw(*self.window.get_size())
def key_press_event(self, *args):
# print args
self.cr = self.window.cairo_create() # This is the line I have to add
# in order to make this function not throw the error. Note that cr is only
# given as attribute of self in order to stop it going out of scope when this line
# doesn't exist
self.cr.set_source_rgb(random.random(), random.random(), random.random())
self.cr.move_to(*[z/2.0 for z in self.window.get_size()])
self.cr.line_to(*[z*random.random() for z in self.window.get_size()])
self.cr.stroke()
def draw(self, width, height):
# Fill the background with gray
self.cr.set_source_rgb(.5,.5,.5)
self.cr.rectangle(0, 0, width,height)
self.cr.fill()
self.cr.set_source_rgb(1,0,0)
self.cr.arc(width/2.0, height/2.0, min(width,height)/2.0 - 20.0, 0.0, 2.0*math.pi)
self.cr.stroke()
#create a gtk window, attach to exit button, and whatever is passed as arg becomes the body of the window. AWESOME
def run(Widget):
window = gtk.Window()
widget = Widget()
window.connect("delete-event", gtk.main_quit)
window.connect('key-press-event',widget.key_press_event)
widget.show()
window.add(widget)
window.present()
gtk.main()
if __name__ == "__main__":
run(Screen)
Спасибо за вашу помощь!
(Обновление: я играл, и я понял следующее: когда я изменяю размер окна, все добавленные новые объекты удаляются (или, по крайней мере, больше не появляются?))