Используя библиотеку Gtk+, Drawing Area Widget и cairo.Context объект рисуем в окне программы прямоугольник и применяем градиентную заливку. Создаём программу на Python помощью конструктора Glade и IDE IDLE.
В IDE Glade создайте новый проект.
Создайте Окно класса GtkWindow, на вкладке Основные свойства присвойте ему идентификатор ID: window. Там же, на вкладке Основные свойства присвойте окну Заголовок GtkDrawingArea и проставьте размер и галочки Ширина по умолчанию 800 и Высота по умолчанию 600. На вкладке Сигналы в разделе GtkWidget событию destroy задайте обработчик on_destroy.
Поверх окна window разместите Display GtkDrawingArea. На вкладке Основные свойства задайте ему имя colorDraw.
В IDE Glade сохраните проект под именем, например, examle. В результате вы получите файл example.glade:
<?xml version="1.0" encoding="UTF-8"?>
<!-- Generated with glade 3.22.1 -->
<interface>
<requires lib="gtk+" version="3.20"/>
<object class="GtkWindow" id="window">
<property name="can_focus">False</property>
<property name="hexpand">True</property>
<property name="vexpand">True</property>
<property name="title" translatable="yes">GtkDrawingArea</property>
<property name="default_width">800</property>
<property name="default_height">600</property>
<signal name="destroy" handler="on_destroy" swapped="no"/>
<child>
<placeholder/>
</child>
<child>
<object class="GtkDrawingArea" id="colorDraw">
<property name="visible">True</property>
<property name="can_focus">False</property>
</object>
</child>
</object>
</interface>
В текстовом редакторе или, например, в IDE IDLE напишите программу example.py следующего содержания:
#!/usr/bin/python3
# -*- Mode: Python; coding: utf-8; indent-tabs-mode: t; c-basic-offset: 4; tab-width:$
import gi
gi.require_version('Gtk', '3.0')
from gi.repository import Gtk
import random, math, cairo
XML_FILE = "example.glade"
def do_draw(self, cr):
width = self.get_allocated_width()
height = self.get_allocated_height()
x0, y0 = 20, 20
x1, y1 = 20, height
lg = cairo.LinearGradient(x0, y0, x1, y1)
lg.add_color_stop_rgba(0.0, 1, 0, 0, 1)
lg.add_color_stop_rgba(0.5, 0, 1, 0, 1)
lg.add_color_stop_rgba(1.0, 0, 0, 1, 1)
cr.rectangle(20, 20, width - 40, height - 40)
cr.set_source(lg)
cr.fill()
class Handler:
def on_destroy(self, *args):
Gtk.main_quit()
builder = Gtk.Builder()
builder.add_from_file(XML_FILE)
builder.connect_signals(Handler())
win = builder.get_object("window")
colordr = builder.get_object("colorDraw")
colordr.connect('draw', do_draw)
win.show_all()
Gtk.main()
Наш проект состоит их 2-х файлов example.py иexample.glade. Теперь можно запускать нашу программу через терминал в папке проекта или через IDE IDLE:
dior@U18pro:~/Python/Example/Gtk Drawin Area$ ./example.py
Работает: