Creating A User Interface
Until now we have been creating GTK widgets with JavaScript code like this:
const button = new Button();
While this syntax is frequently used it is much easier and maintainable to build most of your application using a user interface file. A user interface file is an XML file containing all of your widgets' positioning and properties.
Your GNOME Builder project should contain a file named window.ui
. We can use Glade to edit this file.
Using Glade
data:image/s3,"s3://crabby-images/8f388/8f388b688efb8cb8f72ada97de5c39734733b6bf" alt=""
Open Glade
, make sure you have version 3.22.x+ and not an outdated version. The newest version of Glade
can be found on FlatHub here.
data:image/s3,"s3://crabby-images/b45dc/b45dc47f2819b3041b2f085aefe7848d9aff62ed" alt=""
Once in Glade, open the UI file from your new project.
data:image/s3,"s3://crabby-images/48570/4857009ca6d9877e139d36a0215b13337fdbea75" alt=""
There it is!
data:image/s3,"s3://crabby-images/490b7/490b7c84dfe9befa403f8e780596e1807565c01d" alt=""
Once opened, you'll see a basic Hello, World!
application. Right click on the GtkLabel
and click delete.
data:image/s3,"s3://crabby-images/bebf6/bebf66ccfdfc7e8ca461cf673160a952d751f08a" alt=""
You should now have a window that looks like this.
data:image/s3,"s3://crabby-images/9300d/9300d2f0019581ae0761e48e6ee7c0eb9aca4a45" alt=""
Select the header bar and rename the title to whatever your application is called (we chose 'Tags' randomly)
Adding a button to the header bar...
data:image/s3,"s3://crabby-images/89b8f/89b8ffb7e105afc47412d09183967f124fa856ca" alt=""
To add a button to the header bar locate Number of items
in the General
section of the header bar's properties.
data:image/s3,"s3://crabby-images/5501f/5501f3fadf04b98b7a6cecc9586c4766a8ba0ea3" alt=""
Increase the number to 1
.
data:image/s3,"s3://crabby-images/548f4/548f48bfcc0c456142a808e555e783194930201f" alt=""
Now let's find a button
.
data:image/s3,"s3://crabby-images/a7d93/a7d93659dccfa16729fcda7cd447b2df4207aa95" alt=""
There it is! Select GtkButton
.
data:image/s3,"s3://crabby-images/224af/224aff1cf4825c796460fe01ba3e812786912e6c" alt=""
Now anywhere we click a button will be placed.
data:image/s3,"s3://crabby-images/1ad64/1ad64f8389413f670696c3790cfe4ba56a886c97" alt=""
Place a button in the empty slot we've created in the header bar.
data:image/s3,"s3://crabby-images/9706b/9706ba71d185b6aa8582b5ab01d615d77fab8ff2" alt=""
Now let's name our button. We'll call it addFileButton
because we'll use it to open files for Tags.
data:image/s3,"s3://crabby-images/1bb6f/1bb6f522e73a15bd0f9a51329cb793687c45e226" alt=""
While we're at it, let's rename our header bar too because camelCasing is preferred in GJS.
data:image/s3,"s3://crabby-images/d7d5b/d7d5bbc83fe02b26e5e1214a31a84352c34e0c36" alt=""
We want to have a +
image inside our button to symbolize adding. To do this , select Add custom content
in General
in the button's properties section.
data:image/s3,"s3://crabby-images/2f34e/2f34e67132af3532c970292e1e35ecafbb6b6675" alt=""
Now let's grab a GtkImage
.
data:image/s3,"s3://crabby-images/9a99c/9a99c09331c3d6bb1f37fe69efc2166736651ec3" alt=""
Pop it into the button's empty slot.
data:image/s3,"s3://crabby-images/cf0e1/cf0e11bd2d1daa6bf374efcb76b8a3d198613fc7" alt=""
Now select the image.
data:image/s3,"s3://crabby-images/b93f8/b93f8712fcd6b3370b79a6fad04409de4fd19f4a" alt=""
Find Icon Name
in General
in the properties section of the GtkImage
. Click on Icon Name
.
data:image/s3,"s3://crabby-images/16a65/16a65ca898f04db3220e68625bf279a992d42d8e" alt=""
Select the appropriate semantic name for 'adding' which is list-add-symbolic
. Be certain you get list-add-symbolic
and not list-add
as symbolic icons are monochromatic and meant for menus and buttons.
data:image/s3,"s3://crabby-images/9449b/9449b4c35f11699a3dcdb604dd09da9f794f0d89" alt=""
You should now see the symbolic name list-add-symbolic
under Icon Name
.
data:image/s3,"s3://crabby-images/183b5/183b5376ec9af2f3549ff79537efa5ace570063b" alt=""
Select GtkBox
from the widget picker.
data:image/s3,"s3://crabby-images/16aa9/16aa9f07c78e9a06e9b333563b880e7362b620c8" alt=""
Now we will add a GtkBox
to store the window contents.
data:image/s3,"s3://crabby-images/c9edf/c9edf012b52c639587da396f98271ef663d6f416" alt=""
Pop it into the empty space in our window, TagsWindow
.
data:image/s3,"s3://crabby-images/2ab7a/2ab7a2ee779486343b41789f200511fa07ab5507" alt=""
data:image/s3,"s3://crabby-images/b92e2/b92e27247a50b618098f044e0894d0f9b3a02e20" alt=""
Now set Number of items
in General
in the widgets properties to 1
.
data:image/s3,"s3://crabby-images/2d3cc/2d3cc1e06fe279f04629a4ce29ee5cdda27fe4e3" alt=""
Now set the widget ID to mainBox
.
And we've built our UI!