The GitHub Pages site of this tutorial is available. Click here. It is more readable than this repository.
Now that GTK 4 is widely used, "GTK" usually means GTK 4. Therefore, this tutorial simply says "GTK" except where the version needs to be explicitly mentioned.
This tutorial illustrates how to write C programs with the GTK library. It is aimed at beginners, so the contents are limited to the basics. The table of contents is at the end of this README.md.
- Section 3 to 23 describe the basics, with the example of a simple editor
tfe(Text File Editor). - Section 24 to 27 describe GtkDrawingArea.
- Section 28 describes Drag and Drop.
- Section 29 to 33 describe the list model and the list view (GtkListView, GtkGridView, and GtkColumnView). It also describes GtkExpression.
The latest version of the tutorial is located at the GTK4-tutorial GitHub repository. You can read it directly without downloading.
There's a GitHub Page which is the HTML version of the tutorial.
Please refer to the GTK API Reference and the GNOME Developer Documentation Website for further information. These websites were opened in August 2021.
If you want to know about GObject and the type system, please refer to the GObject tutorial. GObject is the base of GTK, so it is important for developers to understand it as well as GTK.
This tutorial is still under development and unstable.
Even though the example codes have been tested on GTK (version 4.10.1), bugs may still exist.
If you find any bugs, errors, or mistakes in the tutorial and C examples, please let me know.
You can post them to GitHub issues.
You can also post updated files to pull request.
When submitting a pull request, please ensure that you only modify the files in the src directory.
Don't modify the files under gfm or html directories.
After modifying some source files, run bundle exec rake to create GFM (GitHub Flavoured Markdown) files and run bundle exec rake html to create HTML files.
Please refer to the Author Guide for further information.
If you have a question, feel free to post it to issue of this repository.
Your questions and feedback are welcome and invaluable for improving this tutorial.
If you want to get the tutorial in HTML or PDF format, build them with rake command, which is a ruby version of make.
Type bundle exec rake html for HTML.
Type bundle exec rake pdf for PDF.
The Author Guide describes how to write source files.
The license of this repository is written in Section1.
In short:
- GFDL1.3 for documents
- GPL3 for programs
- Prerequisite and License
- Preparation
- GtkApplication and GtkApplicationWindow
- Widgets (1)
- Widgets (2)
- Strings and Memory Management
- Widgets (3)
- Defining a Final Class
- GtkBuilder and UI Files
- Build System
- Instance Initialization and Destruction
- Signals
- TfeTextView Class
- Functions in GtkNotebook
- Tfe Main Program
- How to Build tfe (Text File Editor)
- Menus and Actions
- Stateful Action
- Ui File for Menu and Action Entries
- Composite Widgets and Alert Dialog
- GtkFontDialogButton and Gsettings
- TfeWindow
- Pango, CSS and Application
- GtkDrawingArea and Cairo
- Periodic Events
- Custom Drawing
- Tiny Turtle Graphics Interpreter
- Drag and Drop
- GtkListView
- GtkGridView and Activate Signal
- GtkExpression
- GtkColumnView
- GtkSignalListItemFactory