Ir para o conteúdo

Python e GTK 3: PyGObject Gtk.HeaderBar()

Utilizando Gtk.HeaderBar() com a linguagem de programação Python (PyGObject).

Exemplo

Python PyGObject Gtk.HeaderBar()

  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
# -*- coding: utf-8 -*-
"""Python e GTK 3: PyGObject Gtk.HeaderBar()."""

import gi

gi.require_version(namespace='Gtk', version='3.0')
from gi.repository import Gio, Gtk


class MainWindow(Gtk.ApplicationWindow):

    def __init__(self, **kwargs):
        super().__init__(**kwargs)

        self.set_title(title='Gtk.HeaderBar')
        self.set_default_size(width=1366 / 2, height=768 / 2)
        self.set_position(position=Gtk.WindowPosition.CENTER)
        self.set_default_icon_from_file(filename='../../assets/icons/icon.png')
        self.set_border_width(border_width=12)

        headerbar = Gtk.HeaderBar.new()
        # Definindo o título que será exibido na barra.
        # O titulo definido aqui sobrescreve o titulo da janela principal.
        headerbar.set_title(title='Gtk.HeaderBar')
        # Definindo um sub titulo para o HeaderBar.
        headerbar.set_subtitle(subtitle='Gtk.HeaderBar')
        # Torna visível os botões de minimizar, maximizar e fechar.
        # Por padrão essa opção é False.
        headerbar.set_show_close_button(setting=True)
        # Adicionando o HeaderBar na janela principal.
        self.set_titlebar(titlebar=headerbar)

        button_mail = Gtk.Button.new_from_icon_name(
            icon_name='mail-send-receive-symbolic',
            size=Gtk.IconSize.BUTTON
        )
        button_mail.connect('clicked', self._send_mail)
        headerbar.pack_end(child=button_mail)

        # Criando um Box Layout horizontal para conter os botões com seta.
        # Utilizando um Box Layout os botões ficam melhore distribuidos.
        hbox = Gtk.Box.new(orientation=Gtk.Orientation.HORIZONTAL, spacing=0)

        # Adicionando o Box Layout no começo do HeaderBar.
        headerbar.pack_start(child=hbox)

        button_left_arrow = Gtk.Button.new_from_icon_name(
            icon_name='go-previous-symbolic',
            size=Gtk.IconSize.BUTTON
        )
        button_left_arrow.connect('clicked', self._left_arrow)
        hbox.add(widget=button_left_arrow)

        button_right_arrow = Gtk.Button.new_from_icon_name(
            icon_name='go-previous-symbolic-rtl',
            size=Gtk.IconSize.BUTTON
        )
        button_right_arrow.connect('clicked', self._right_arrow)
        hbox.add(widget=button_right_arrow)

        # Adicionando um widget do tipo TextView()
        # na janela principal (só para não ficar vazio).
        text_view = Gtk.TextView.new()
        self.add(widget=text_view)

        self.show_all()

    @staticmethod
    def _send_mail(widget):
        print('Você clicou no botão que tem o icone de enviar/receber email')

    @staticmethod
    def _left_arrow(widget):
        print('Você clicou no botão que tem uma seta para a esquerda')

    @staticmethod
    def _right_arrow(widget):
        print('Você clicou no botão que tem uma seta para a direita')


class Application(Gtk.Application):

    def __init__(self):
        super().__init__(application_id='br.natorsc.Exemplo',
                         flags=Gio.ApplicationFlags.FLAGS_NONE)

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

    def do_activate(self):
        win = self.props.active_window
        if not win:
            win = MainWindow(application=self)
        win.present()

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


if __name__ == '__main__':
    import sys

    app = Application()
    app.run(sys.argv)