[gtk/js-example] Add a simple Javascript example
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/js-example] Add a simple Javascript example
- Date: Mon, 5 Jul 2021 17:49:15 +0000 (UTC)
commit 873f6ccfea38bcda8e0d4e42854b6bd4f4dbb46b
Author: Matthias Clasen <mclasen redhat com>
Date: Mon Jul 5 13:44:17 2021 -0400
Add a simple Javascript example
This shows how to use a layout manager in a widget,
implemented in javascript. The example sets up the
environment for running from the toplevel dir, assuming
that the build dir is called 'build'.
examples/labels.js | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 50 insertions(+)
---
diff --git a/examples/labels.js b/examples/labels.js
new file mode 100755
index 0000000000..562153e587
--- /dev/null
+++ b/examples/labels.js
@@ -0,0 +1,50 @@
+#!/usr/bin/env -S GI_TYPELIB_PATH=${PWD}/build/gtk:${GI_TYPELIB_PATH}
LD_PRELOAD=${LD_PRELOAD}:${PWD}/build/gtk/libgtk-4.so gjs
+
+imports.gi.versions['Gtk'] = '4.0';
+
+const GObject = imports.gi.GObject;
+const Gtk = imports.gi.Gtk;
+
+const DemoWidget = GObject.registerClass({
+ GTypeName: 'DemoWidget',
+ }, class DemoWidget extends Gtk.Widget {
+
+ _init(params = {}) {
+ super._init(params);
+
+ let layout_manager = new Gtk.GridLayout ();
+ this.set_layout_manager (layout_manager);
+ this.label1 = new Gtk.Label({ label: "Red",
+ hexpand: true,
+ vexpand: true });
+ this.label1.set_parent (this);
+ let child1 = layout_manager.get_layout_child (this.label1);
+ child1.set_row (0);
+ child1.set_column (0);
+
+ this.label2 = new Gtk.Label({ label: "Green",
+ hexpand: true,
+ vexpand: true });
+ this.label2.set_parent (this);
+ let child2 = layout_manager.get_layout_child (this.label2);
+ child2.set_row (0);
+ child2.set_column (1);
+ }
+});
+
+// Create a new application
+let app = new Gtk.Application({ application_id: 'org.gtk.exampleapp' });
+
+// When the application is launched…
+app.connect('activate', () => {
+ // … create a new window …
+ let win = new Gtk.ApplicationWindow({ application: app });
+ // … with a button in it …
+ let widget = new DemoWidget();
+ win.set_child(widget);
+ win.present();
+});
+
+// Run the application
+app.run([]);
+
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]