Gtk4-tutorial/src/sec23.src.md

91 lines
2.6 KiB
Markdown
Raw Normal View History

2022-04-05 10:42:02 +02:00
# Periodic Events
2022-04-05 10:42:02 +02:00
This chapter was written by Paul Schulz <paul@mawsonlakes.org>.
2022-04-05 10:42:02 +02:00
## How do we create an animation?
2022-04-05 10:42:02 +02:00
In this section we will continue to build on our previous work. We will create
an analog clock application. By adding a function which periodically redraws
GtkDrawingArea, the clock will be able to continuously display the time.
2022-04-05 10:42:02 +02:00
The application uses a compiled in 'resource' file, so if the GTK4 libraries and
their dependencies are installed and available, the application will run from
anywhere.
2022-04-05 10:42:02 +02:00
The program also makes use of some standard mathematical and time handling
functions.
2022-04-05 10:42:02 +02:00
The clocks mechanics were taken from a Cairo drawing example, using gtkmm4, which can be found
[here](https://developer-old.gnome.org/gtkmm-tutorial/stable/sec-drawing-clock-example.html.en).
2022-04-05 10:42:02 +02:00
The complete code is at the end.
2022-04-05 10:42:02 +02:00
## Drawing the clock face, hour, minute and second hands
2022-04-05 10:42:02 +02:00
The `draw_clock()` function does all the work. See the in-file comments for an
explanation of how the Cairo drawing works.
2022-04-05 10:42:02 +02:00
For a detailed reference of what each of the Cairo functions does see the
[cairo_t reference](https://www.cairographics.org/manual/cairo-cairo-t.html).
@@@include
2022-04-05 10:42:02 +02:00
tfc/tfc.c draw_clock
@@@
2022-04-05 10:42:02 +02:00
In order for the clock to be drawn, the drawing function `draw_clock()` needs
to be registered with GTK4. This is done in the `app_activate()` function (on line 24).
Whenever the application needs to redraw the GtkDrawingArea, it will now call `draw_clock()`.
There is still a problem though. In order to animate the clock we need to also
tell the application that the clock needs to be redrawn every second. This
process starts by registering (on the next line, line 15) a timeout function
with `g_timeout_add()` that will wakeup and run another function `time_handler`,
every second (or 1000ms).
@@@include
2022-04-05 10:42:02 +02:00
tfc/tfc.c app_activate
@@@
2022-04-05 10:42:02 +02:00
Our `time_handler()` function is very simple, as it just calls
`gtk_widget_queue_draw()` which schedules a redraw of the widget.
@@@include
2022-04-05 10:42:02 +02:00
tfc/tfc.c time_handler
@@@
2022-04-05 10:42:02 +02:00
.. and that is all there is to it. If you compile and run the example you will
get a ticking analog clock.
If you get this working, you can try modifying some of the code in
2022-04-05 10:44:46 +02:00
`draw_clock()` to tweak the application (such as change the color or size and
2022-04-05 10:42:02 +02:00
length of the hands) or even add text, or create a digital clock.
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
## The Complete code
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
You can find the source files in the `tfc` directory. it can be compiled with `./comp tfc`.
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
`tfc.c`
2021-03-06 16:19:29 +01:00
@@@include
2022-04-05 10:42:02 +02:00
tfc/tfc.c
@@@
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
`tfc.ui`
2021-03-06 16:19:29 +01:00
@@@include
2022-04-05 10:42:02 +02:00
tfc/tfc.ui
@@@
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
`tfc.gresource.xml`
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
@@@include
tfc/tfc.gresource.xml
@@@
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
`comp`
2021-03-06 16:19:29 +01:00
2022-04-05 10:42:02 +02:00
@@@include
tfc/comp
@@@