Help language development. Donate to The Perl Foundation

Gnome::Gtk3 cpan:MARTIMM last updated on 2019-10-16



Gnome Gtk3 - Widget toolkit for graphical interfaces


Documentation at this site has the GNU Free Documentation License.


The purpose of this project is to create an interface to the GTK+ version 3 library.


There is already a bit of history for this package. It started off building the GTK::Glade package which soon became too big. So a part was separated into GTK::V3. After some working with the library I felt that the class names were a bit too long and that the words gtk and gdk were repeated too many times in the class path. E.g. there was GTK::V3::Gtk::GtkButton and GTK::V3::Gdk::GdkScreen to name a few. So, finally it was split into several other packages named, Gnome::N for the native linkup on behalf of any other Gnome module, Gnome::Glib, Gnome::GObject, Gnome::Gdk3 and Gnome::Gtk3 according to what is shown on the developers page here. The classes in these packages are now renamed into e.g. Gnome::Gtk3::Button, Gnome::Gdk3::Screen, Gnome::GObject::Object and Gnome::Glib::List. As a side effect the package GTK::Glade is also renamed into Gnome::Glade3 to show that it is from Gnome and that it is based on Gtk version 3.


This example does the same as the example from GTK::Simple to show you the differences between the implementations. What immediately is clear is that this example is somewhat longer. To sum up;



A screenshot of the example -this screenshot-. The code can be found at examples/01-hello-world.pl6.

use v6;

use Gnome::Gtk3::Main;
use Gnome::Gtk3::Window;
use Gnome::Gtk3::Grid;
use Gnome::Gtk3::Button;

# Instantiate main module for UI control
my Gnome::Gtk3::Main $m .= new;

# Class to handle signals
class AppSignalHandlers {

  # Handle 'Hello World' button click
  method first-button-click ( :widget($b1), :other-button($b2) ) {

  # Handle 'Goodbye' button click
  method second-button-click ( ) {

  # Handle window managers 'close app' button
  method exit-program ( ) {

# Create a top level window and set a title
my Gnome::Gtk3::Window $top-window .= new(:empty);
$top-window.set-title('Hello GTK!');

# Create a grid and add it to the window
my Gnome::Gtk3::Grid $grid .= new(:empty);

# Create buttons and disable the second one
my Gnome::Gtk3::Button $button .= new(:label('Hello World'));
my Gnome::Gtk3::Button $second .= new(:label('Goodbye'));

# Add buttons to the grid
$grid.gtk-grid-attach( $button, 0, 0, 1, 1);
$grid.gtk-grid-attach( $second, 0, 1, 1, 1);

# Instantiate the event handler class and register signals
my AppSignalHandlers $ash .= new;
  $ash, 'first-button-click', 'clicked',  :other-button($second)
$second.register-signal( $ash, 'second-button-click', 'clicked');

$top-window.register-signal( $ash, 'exit-program', 'destroy');

# Show everything and activate all



Pdf from pod Link to Gnome Developer
Gnome::Gtk3::AboutDialog GtkAboutDialog.html
Gnome::Gtk3::Bin GtkBin.html
Gnome::Gtk3::Builder GtkBuilder.html
Gnome::Gtk3::Button GtkButton.html
[Gnome::Gtk3::Box][Gnome::Gtk3::Box pdf] GtkBox.html
Gnome::Gtk3::CheckButton GtkCheckButton.html
Gnome::Gtk3::ComboBox GtkComboBox.html
Gnome::Gtk3::ComboBoxText GtkComboBoxText.html
Gnome::Gtk3::ColorButton GtkColorButton.html
[Gnome::Gtk3::ColorChooser][Gnome::Gtk3::ColorChooser pdf] GtkColorChooser.html
Gnome::Gtk3::ColorChooserDialog GtkColorChooserDialog.html
[Gnome::Gtk3::ColorChooserWidget][Gnome::Gtk3::ColorChooserWidget pdf] GtkColorChooserWidget.html
Gnome::Gtk3::Container GtkContainer.html
Gnome::Gtk3::CssProvider GtkCssProvider.html
Gnome::Gtk3::StyleContext GtkStyleContext.html
Gnome::Gtk3::Dialog GtkDialog.html
Gnome::Gtk3::Entry GtkEntry.html
Gnome::Gtk3::FileChooser GtkFileChooser.html
Gnome::Gtk3::FileChooserDialog GtkFileChooserDialog.html
Gnome::Gtk3::FileFilter GtkFileFilter.html
Gnome::Gtk3::Grid GtkGrid.html
Gnome::Gtk3::Image GtkImage.html
Gnome::Gtk3::Label GtkLabel.html
[ Gnome::Gtk3::LevelBar ][ Gnome::Gtk3::LevelBar pdf] GtkLevelBar.html
Gnome::Gtk3::ListBox GtkListBox.html
Gnome::Gtk3::Main GtkMain.html
Gnome::Gtk3::MenuItem GtkMenuItem.html
Gnome::Gtk3::Orientable GtkOrientable.html
Gnome::Gtk3::Paned GtkPaned.html
Gnome::Gtk3::RadioButton GtkRadioButton.html
Gnome::Gtk3::Range GtkRange.html
Gnome::Gtk3::Scale GtkScale.html
Gnome::Gtk3::StyleContext GtkStyleContext.html
Gnome::Gtk3::TextBuffer GtkTextBuffer.html
Gnome::Gtk3::TextTagTable GtkTextTagTable.html
Gnome::Gtk3::TextView GtkTextView.html
Gnome::Gtk3::ToggleButton GtkToggleButton.html
Gnome::Gtk3::Widget GtkWidget.html
Gnome::Gtk3::Window GtkWindow.html

Release notes



Versions of involved software


There are several crossing dependencies from one package to the other because it was one package in the past. To get all packages, just install the Gnome::Gtk3 package and the rest will be installed with it.

zef install Gnome::Gtk3


There are always some problems! If you find one, please help by filing an issue at my github project.



Name: Marcel Timmerman Github account name: MARTIMM