Expand description
§Rust GTK 3 bindings
This project is UNMAINTAINED. Please take a look at gtk4-rs instead!
Rust bindings and wrappers for GTK 3, part of gtk3-rs, a multi-platform GUI toolkit. It is a part of gtk-rs.
GTK 3.22.30 is the lowest supported version for the underlying library.
§Minimum supported Rust version
Currently, the minimum supported Rust version is 1.70.0.
§Building
gtk expects GTK, GLib and Cairo development files to be installed on your system. See the GTK installation page.
§Using
We recommend using crates from crates.io, as demonstrated here.
If you want to track the bleeding edge, use the git dependency instead:
[dependencies]
gtk = { git = "https://github.com/gtk-rs/gtk3-rs.git" }Avoid mixing versioned and git crates like this:
# This will not compile
[dependencies]
gtk = "0.13"
gtk = { git = "https://github.com/gtk-rs/gtk3-rs.git" }§“Hello, World!” example program
//!
GTK needs to be initialized before use by calling init. Creating an
Application will call init for you.
use gtk::prelude::*;
use gtk::{Application, ApplicationWindow};
fn main() {
    let app = Application::builder()
        .application_id("org.example.HelloWorld")
        .build();
    app.connect_activate(|app| {
        // We create the main window.
        let win = ApplicationWindow::builder()
            .application(app)
            .default_width(320)
            .default_height(200)
            .title("Hello, World!")
            .build();
        // Don't forget to make all widgets visible.
        win.show_all();
    });
    app.run();
}§The main loop
In a typical GTK application you set up the UI, assign signal handlers and run the main event loop.
use gtk::prelude::*;
use gtk::{Application, ApplicationWindow, Button};
fn main() {
    let application = Application::builder()
        .application_id("com.example.FirstGtkApp")
        .build();
    application.connect_activate(|app| {
        let window = ApplicationWindow::builder()
            .application(app)
            .title("First GTK Program")
            .default_width(350)
            .default_height(70)
            .build();
        let button = Button::with_label("Click me!");
        button.connect_clicked(|_| {
            eprintln!("Clicked!");
        });
        window.add(&button);
        window.show_all();
    });
    application.run();
}§Threads
GTK is not thread-safe. Accordingly, none of this crate’s structs implement
Send or Sync.
The thread where init was called is considered the main thread. OS X has
its own notion of the main thread and init must be called on that thread.
After successful initialization, calling any gtk or gdk functions
(including init) from other threads will panic.
Any thread can schedule a closure to be run by the main loop on the main
thread via glib::idle_add or glib::timeout_add. While
working with GTK you might need the glib::idle_add_local
or glib::timeout_add_local version without the
Send bound. Those may only be called from the main thread.
§Panics
The gtk and gdk crates have some run-time safety and contract checks.
- 
Any constructor or free function will panic if called before initor on a non-main thread.
- 
Any &stror&Pathparameter with an interior null (\0) character will cause a panic.
- 
Some functions will panic if supplied out-of-range integer parameters. All such cases will be documented individually but they are not yet. 
- 
A panic in a closure that handles signals or in any other closure passed to a gtkfunction will abort the process.
§Features
§Library versions
By default this crate provides only GTK 3.22.30 APIs. You can access additional
functionality by selecting one of the v3_24, etc. features.
Cargo.toml example:
[dependencies.gtk]
version = "0.x.y"
features = ["v3_24"]Take care when choosing the version to target: some of your users might not have easy access to the latest ones. The higher the version, the fewer users will have it installed.
§Documentation
Most of this documentation is generated from the C API.
Until all parts of the documentation have been reviewed there will be incongruities with the actual Rust API.
Generate the docs:
> RUSTFLAGS="--cfg docsrs" cargo doc(if the installed GTK+ version is lower than 3.16, adjust the feature name accordingly).
§Contribute
Contributor you’re welcome!
See the general bindings documentation.
Most of the bindings (src/auto) are generated by gir using this configuration file. After editing Gir.toml the sources can be regenerated with
> make girWhen opening a PR please put the changes to the src/auto directory in a separate commit.
You may also wish to run cargo clippy -- -D warnings and check that you’re clean because
otherwise you may be surprised when CI fails.
§See Also
But also:
§License
gtk is available under the MIT License, please refer to it.
Re-exports§
- pub use ffi;
- pub use atk;
- pub use cairo;
- pub use gdk;
- pub use gdk_pixbuf;
- pub use gio;
- pub use glib;
- pub use pango;
Modules§
- builders
- Builder pattern types.
- prelude
- Traits and essential types intended for blanket imports.
- subclass
- xlib
Structs§
- AboutDialog 
- AccelFlags 
- AccelGroup 
- AccelLabel 
- ActionBar 
- Actionable
- Adjustment
- Allocation
- AppChooser
- AppChooserButton 
- AppChooserDialog 
- AppChooserWidget 
- Application
- ApplicationInhibit Flags 
- ApplicationWindow 
- AspectFrame 
- Assistant
- Bin
- Border
- Box
- Buildable
- Builder
- Button
- ButtonBox 
- Calendar
- CalendarDisplay Options 
- CellArea 
- CellArea Box 
- CellArea Context 
- CellEditable 
- CellLayout 
- CellRenderer 
- CellRenderer Accel 
- CellRenderer Combo 
- CellRenderer Pixbuf 
- CellRenderer Progress 
- CellRenderer Spin 
- CellRenderer Spinner 
- CellRenderer State 
- CellRenderer Text 
- CellRenderer Toggle 
- CellView 
- CheckButton 
- CheckMenu Item 
- Clipboard
- ColorButton 
- ColorChooser 
- ColorChooser Dialog 
- ColorChooser Widget 
- ComboBox 
- ComboBoxText 
- Container
- CssProvider
- CssSection
- DestDefaults 
- Dialog
- DialogFlags 
- DrawingArea 
- Editable
- Entry
- EntryBuffer 
- EntryCompletion 
- EventBox 
- EventController 
- Expander
- FileChooser 
- FileChooser Button 
- FileChooser Dialog 
- FileChooser Native 
- FileChooser Widget 
- FileFilter 
- FileFilter Flags 
- FileFilter Info 
- Fixed
- FlowBox
- FlowBoxChild 
- FontButton 
- FontChooser 
- FontChooser Dialog 
- FontChooser Widget 
- Frame
- GLArea
- Gesture
- GestureDrag 
- GestureLong Press 
- GestureMulti Press 
- GesturePan 
- GestureRotate 
- GestureSingle 
- GestureSwipe 
- GestureZoom 
- Grid
- HeaderBar 
- IMContext
- IMContextSimple 
- IMMulticontext
- IconInfo 
- IconLookup Flags 
- IconTheme 
- IconView 
- Image
- InfoBar
- InputHints 
- Invisible
- JunctionSides 
- Label
- Layout
- LevelBar 
- LinkButton 
- ListBox
- ListBoxRow 
- ListStore 
- LockButton 
- Menu
- MenuBar
- MenuButton 
- MenuItem 
- MenuShell 
- MenuTool Button 
- MessageDialog 
- Misc
- ModelButton 
- MountOperation 
- NativeDialog 
- Notebook
- OffscreenWindow 
- Orientable
- Overlay
- PadActionEntry 
- PadController
- PageRange 
- PageSetup 
- Paned
- PaperSize 
- PlacesOpen Flags 
- PlacesSidebar 
- Pluggdk_backend="x11"
- Popover
- PopoverMenu 
- PrintContext 
- PrintOperation 
- PrintOperation Preview 
- PrintSettings 
- ProgressBar 
- RadioButton 
- RadioMenu Item 
- RadioTool Button 
- Range
- RecentChooser 
- RecentChooser Dialog 
- RecentChooser Menu 
- RecentChooser Widget 
- RecentData 
- RecentFilter 
- RecentFilter Flags 
- RecentInfo 
- RecentManager 
- Rectangle
- RegionFlags 
- Requisition
- Revealer
- Scale
- ScaleButton 
- Scrollable
- Scrollbar
- ScrolledWindow 
- SearchBar 
- SearchEntry 
- SelectionData 
- Separator
- SeparatorMenu Item 
- SeparatorTool Item 
- Settings
- ShortcutLabel 
- ShortcutsGroup 
- ShortcutsSection 
- ShortcutsShortcut 
- ShortcutsWindow 
- SizeGroup 
- Socketgdk_backend="x11"
- SpinButton 
- Spinner
- Stack
- StackSidebar 
- StackSwitcher 
- StateFlags 
- Statusbar
- StyleContext 
- StyleContext Print Flags 
- StyleProperties 
- StyleProvider 
- Switch
- TargetEntry 
- TargetFlags 
- TargetList 
- TextAttributes 
- TextBuffer 
- TextChild Anchor 
- TextIter 
- TextMark 
- TextSearch Flags 
- TextTag
- TextTagTable 
- TextView 
- TickCallback Id 
- ToggleButton 
- ToggleTool Button 
- ToolButton 
- ToolItem 
- ToolItem Group 
- ToolPalette 
- ToolPalette Drag Targets 
- ToolShell 
- Toolbar
- Tooltip
- TreeDrag Dest 
- TreeDrag Source 
- TreeIter 
- TreeModel 
- TreeModel Filter 
- TreeModel Flags 
- TreeModel Sort 
- TreePath 
- TreeRowReference 
- TreeSelection 
- TreeSortable 
- TreeStore 
- TreeView 
- TreeView Column 
- Viewport
- VolumeButton 
- Widget
- WidgetPath 
- Window
- WindowGroup 
Enums§
- Align
- ArrowType 
- AssistantPage Type 
- BaselinePosition 
- BorderStyle 
- BuilderError 
- ButtonBoxStyle 
- ButtonRole 
- ButtonsType 
- CellRenderer Accel Mode 
- CellRenderer Mode 
- CornerType 
- CssProviderError 
- CssSectionType 
- DeleteType 
- DirectionType 
- DragResult 
- EntryIcon Position 
- EventSequence State 
- FileChooser Action 
- FileChooser Confirmation 
- FileChooser Error 
- IconSize 
- IconTheme Error 
- IconView Drop Position 
- ImageType 
- InputPurpose 
- Justification
- LevelBarMode 
- License
- MenuDirection Type 
- MessageType 
- MovementStep 
- NotebookTab 
- NumberUpLayout 
- Orientation
- PackDirection 
- PackType 
- PadActionType 
- PageOrientation 
- PageSet
- PanDirection
- PolicyType 
- PopoverConstraint 
- PositionType 
- PrintDuplex 
- PrintError 
- PrintOperation Action 
- PrintOperation Result 
- PrintPages 
- PrintQuality 
- PrintStatus 
- PropagationPhase 
- RecentChooser Error 
- RecentManager Error 
- RecentSort Type 
- ReliefStyle 
- ResizeMode 
- ResponseType 
- RevealerTransition Type 
- ScrollStep 
- ScrollType 
- ScrollablePolicy 
- SelectionMode 
- SensitivityType 
- ShadowType 
- ShortcutType 
- SizeGroup Mode 
- SizeRequest Mode 
- SortColumn 
- SortType 
- SpinButton Update Policy 
- SpinType 
- StackTransition Type 
- TextDirection 
- TextExtend Selection 
- TextView Layer 
- TextWindow Type 
- ToolbarStyle 
- TreeView Column Sizing 
- TreeView Drop Position 
- TreeView Grid Lines 
- Unit
- WidgetHelp Type 
- WindowPosition 
- WindowType 
- WrapMode 
Constants§
- STYLE_PROVIDER_ PRIORITY_ APPLICATION 
- STYLE_PROVIDER_ PRIORITY_ FALLBACK 
- STYLE_PROVIDER_ PRIORITY_ SETTINGS 
- STYLE_PROVIDER_ PRIORITY_ THEME 
- STYLE_PROVIDER_ PRIORITY_ USER 
Statics§
- LEVEL_BAR_ OFFSET_ FULL 
- LEVEL_BAR_ OFFSET_ HIGH 
- LEVEL_BAR_ OFFSET_ LOW 
- PAPER_NAME_ A3 
- PAPER_NAME_ A4 
- PAPER_NAME_ A5 
- PAPER_NAME_ B5 
- PAPER_NAME_ EXECUTIVE 
- PAPER_NAME_ LEGAL 
- PAPER_NAME_ LETTER 
- PRINT_SETTINGS_ COLLATE 
- PRINT_SETTINGS_ DEFAULT_ SOURCE 
- PRINT_SETTINGS_ DITHER 
- PRINT_SETTINGS_ DUPLEX 
- PRINT_SETTINGS_ FINISHINGS 
- PRINT_SETTINGS_ MEDIA_ TYPE 
- PRINT_SETTINGS_ NUMBER_ UP 
- PRINT_SETTINGS_ NUMBER_ UP_ LAYOUT 
- PRINT_SETTINGS_ N_ COPIES 
- PRINT_SETTINGS_ ORIENTATION 
- PRINT_SETTINGS_ OUTPUT_ BASENAME 
- PRINT_SETTINGS_ OUTPUT_ BIN 
- PRINT_SETTINGS_ OUTPUT_ DIR 
- PRINT_SETTINGS_ OUTPUT_ FILE_ FORMAT 
- PRINT_SETTINGS_ OUTPUT_ URI 
- PRINT_SETTINGS_ PAGE_ RANGES 
- PRINT_SETTINGS_ PAGE_ SET 
- PRINT_SETTINGS_ PAPER_ FORMAT 
- PRINT_SETTINGS_ PAPER_ HEIGHT 
- PRINT_SETTINGS_ PAPER_ WIDTH 
- PRINT_SETTINGS_ PRINTER 
- PRINT_SETTINGS_ PRINTER_ LPI 
- PRINT_SETTINGS_ PRINT_ PAGES 
- PRINT_SETTINGS_ QUALITY 
- PRINT_SETTINGS_ RESOLUTION 
- PRINT_SETTINGS_ RESOLUTION_ X 
- PRINT_SETTINGS_ RESOLUTION_ Y 
- PRINT_SETTINGS_ REVERSE 
- PRINT_SETTINGS_ SCALE 
- PRINT_SETTINGS_ USE_ COLOR 
- PRINT_SETTINGS_ WIN32_ DRIVER_ EXTRA 
- PRINT_SETTINGS_ WIN32_ DRIVER_ VERSION 
- STYLE_CLASS_ ACCELERATOR 
- STYLE_CLASS_ ARROW 
- STYLE_CLASS_ BACKGROUND 
- STYLE_CLASS_ BOTTOM 
- STYLE_CLASS_ BUTTON 
- STYLE_CLASS_ CALENDAR 
- STYLE_CLASS_ CELL 
- STYLE_CLASS_ CHECK 
- STYLE_CLASS_ COMBOBOX_ ENTRY 
- STYLE_CLASS_ CONTEXT_ MENU 
- STYLE_CLASS_ CSD 
- STYLE_CLASS_ CURSOR_ HANDLE 
- STYLE_CLASS_ DEFAULT 
- STYLE_CLASS_ DESTRUCTIVE_ ACTION 
- STYLE_CLASS_ DIM_ LABEL 
- STYLE_CLASS_ DND 
- STYLE_CLASS_ DOCK 
- STYLE_CLASS_ ENTRY 
- STYLE_CLASS_ ERROR 
- STYLE_CLASS_ EXPANDER 
- STYLE_CLASS_ FLAT 
- STYLE_CLASS_ FRAME 
- STYLE_CLASS_ GRIP 
- STYLE_CLASS_ HEADER 
- STYLE_CLASS_ HIGHLIGHT 
- STYLE_CLASS_ HORIZONTAL 
- STYLE_CLASS_ IMAGE 
- STYLE_CLASS_ INFO 
- STYLE_CLASS_ INLINE_ TOOLBAR 
- STYLE_CLASS_ INSERTION_ CURSOR 
- STYLE_CLASS_ LABEL 
- STYLE_CLASS_ LEFT 
- STYLE_CLASS_ LEVEL_ BAR 
- STYLE_CLASS_ LINKED 
- STYLE_CLASS_ LIST 
- STYLE_CLASS_ LIST_ ROW 
- STYLE_CLASS_ MARK 
- STYLE_CLASS_ MENU 
- STYLE_CLASS_ MENUBAR 
- STYLE_CLASS_ MENUITEM 
- STYLE_CLASS_ MESSAGE_ DIALOG 
- STYLE_CLASS_ MONOSPACE 
- STYLE_CLASS_ NEEDS_ ATTENTION 
- STYLE_CLASS_ NOTEBOOK 
- STYLE_CLASS_ OSD 
- STYLE_CLASS_ OVERSHOOT 
- STYLE_CLASS_ PANE_ SEPARATOR 
- STYLE_CLASS_ PAPER 
- STYLE_CLASS_ POPOVER 
- STYLE_CLASS_ POPUP 
- STYLE_CLASS_ PRIMARY_ TOOLBAR 
- STYLE_CLASS_ PROGRESSBAR 
- STYLE_CLASS_ PULSE 
- STYLE_CLASS_ QUESTION 
- STYLE_CLASS_ RADIO 
- STYLE_CLASS_ RAISED 
- STYLE_CLASS_ READ_ ONLY 
- STYLE_CLASS_ RIGHT 
- STYLE_CLASS_ RUBBERBAND 
- STYLE_CLASS_ SCALE 
- STYLE_CLASS_ SCALE_ HAS_ MARKS_ ABOVE 
- STYLE_CLASS_ SCALE_ HAS_ MARKS_ BELOW 
- STYLE_CLASS_ SCROLLBAR 
- STYLE_CLASS_ SCROLLBARS_ JUNCTION 
- STYLE_CLASS_ SEPARATOR 
- STYLE_CLASS_ SIDEBAR 
- STYLE_CLASS_ SLIDER 
- STYLE_CLASS_ SPINBUTTON 
- STYLE_CLASS_ SPINNER 
- STYLE_CLASS_ STATUSBAR 
- STYLE_CLASS_ SUBTITLE 
- STYLE_CLASS_ SUGGESTED_ ACTION 
- STYLE_CLASS_ TITLE 
- STYLE_CLASS_ TITLEBAR 
- STYLE_CLASS_ TOOLBAR 
- STYLE_CLASS_ TOOLTIP 
- STYLE_CLASS_ TOP 
- STYLE_CLASS_ TOUCH_ SELECTION 
- STYLE_CLASS_ TROUGH 
- STYLE_CLASS_ UNDERSHOOT 
- STYLE_CLASS_ VERTICAL 
- STYLE_CLASS_ VIEW 
- STYLE_CLASS_ WARNING 
- STYLE_CLASS_ WIDE 
- STYLE_PROPERTY_ BACKGROUND_ COLOR 
- STYLE_PROPERTY_ BACKGROUND_ IMAGE 
- STYLE_PROPERTY_ BORDER_ COLOR 
- STYLE_PROPERTY_ BORDER_ RADIUS 
- STYLE_PROPERTY_ BORDER_ STYLE 
- STYLE_PROPERTY_ BORDER_ WIDTH 
- STYLE_PROPERTY_ COLOR 
- STYLE_PROPERTY_ FONT 
- STYLE_PROPERTY_ MARGIN 
- STYLE_PROPERTY_ PADDING 
Traits§
Functions§
- accel_groups_ activate 
- accel_groups_ from_ object 
- accelerator_get_ default_ mod_ mask 
- accelerator_get_ label 
- accelerator_get_ label_ with_ keycode 
- accelerator_name 
- accelerator_name_ with_ keycode 
- accelerator_parse 
- accelerator_parse_ with_ keycode 
- accelerator_set_ default_ mod_ mask 
- accelerator_valid 
- binary_age 
- bindings_activate 
- bindings_activate_ event 
- cairo_should_ draw_ window 
- cairo_transform_ to_ window 
- check_version 
- current_event 
- current_event_ device 
- current_event_ state 
- current_event_ time 
- debug_flags 
- default_language 
- device_grab_ add 
- device_grab_ remove 
- disable_setlocale 
- event_widget 
- events_pending 
- false_
- grab_get_ current 
- init
- Tries to initialize GTK+.
- interface_age 
- is_initialized 
- Returns trueif GTK has been initialized.
- is_initialized_ main_ thread 
- Returns trueif GTK has been initialized and this is the main thread.
- locale_direction 
- main
- main_do_ event 
- main_iteration 
- main_iteration_ do 
- main_level 
- main_quit 
- major_version 
- micro_version 
- minor_version 
- print_run_ page_ setup_ dialog 
- print_run_ page_ setup_ dialog_ async 
- propagate_event 
- render_activity 
- render_arrow 
- render_background 
- render_background_ get_ clip 
- render_check 
- render_expander 
- render_extension 
- render_focus 
- render_frame 
- render_frame_ gap 
- render_handle 
- render_icon 
- render_icon_ surface 
- render_insertion_ cursor 
- render_layout 
- render_line 
- render_option 
- render_slider 
- rgb_to_ hsv 
- selection_add_ target 
- selection_clear_ targets 
- selection_convert 
- selection_owner_ set 
- selection_owner_ set_ for_ display 
- selection_remove_ all 
- set_debug_ flags 
- set_initialized ⚠
- Informs this crate that GTK has been initialized and the current thread is the main one.
- show_uri_ on_ window 
- targets_include_ image 
- targets_include_ rich_ text 
- targets_include_ text 
- targets_include_ uri 
- test_find_ label 
- test_find_ sibling 
- test_find_ widget 
- test_register_ all_ types 
- test_widget_ send_ key 
- test_widget_ wait_ for_ draw 
- tree_get_ row_ drag_ data 
- tree_set_ row_ drag_ data 
- true_