我正在关注这个tutorial 。我目前在Building applications部分。有件事让我感到困惑,那就是应用程序窗口是如何创建的。让我解释一下。
程序是这样启动的:
#include <gtk/gtk.h>
#include "exampleapp.h"
int
main (int argc, char *argv[])
{
return g_application_run (G_APPLICATION (example_app_new ()), argc, argv);
}
这很容易。该应用程序使用 g_application_run
函数启动。该函数采用三个参数:应用程序、参数计数和参数 vector 。让我们看看这个应用程序是如何创建的。
#include <gtk/gtk.h>
#include "exampleapp.h"
#include "exampleappwin.h"
struct _ExampleApp
{
GtkApplication parent;
};
G_DEFINE_TYPE(ExampleApp, example_app, GTK_TYPE_APPLICATION);
static void
example_app_init (ExampleApp *app)
{
}
static void
example_app_activate (GApplication *app)
{
ExampleAppWindow *win;
win = example_app_window_new (EXAMPLE_APP (app));
gtk_window_present (GTK_WINDOW (win));
}
static void
example_app_open (GApplication *app,
GFile **files,
gint n_files,
const gchar *hint)
{
GList *windows;
ExampleAppWindow *win;
int i;
windows = gtk_application_get_windows (GTK_APPLICATION (app));
if (windows)
win = EXAMPLE_APP_WINDOW (windows->data);
else
win = example_app_window_new (EXAMPLE_APP (app));
for (i = 0; i < n_files; i++)
example_app_window_open (win, files[i]);
gtk_window_present (GTK_WINDOW (win));
}
static void
example_app_class_init (ExampleAppClass *class)
{
G_APPLICATION_CLASS (class)->activate = example_app_activate;
G_APPLICATION_CLASS (class)->open = example_app_open;
}
ExampleApp *
example_app_new (void)
{
return g_object_new (EXAMPLE_APP_TYPE,
"application-id", "org.gtk.exampleapp",
"flags", G_APPLICATION_HANDLES_OPEN,
NULL);
}
行 G_DEFINE_TYPE(ExampleApp, example_app, GTK_TYPE_APPLICATION);
将 ExampleApp
别名为 GtkApplication
(但以一种聪明的方式,这样类型,与 GtkApplication
关联的变量等现在与 ExampleApp
关联)。
现在让我们看一下 ExampleApp *example_app_new(void)
函数。该函数实际上返回 GtkApplication *
,因为我们将 ExampleApp
与 GtkApplication
相关联。接下来,该函数通过调用 g_object_new 函数来调用并返回一个新对象。该函数采用以下参数:
EXAMPLE_APP_TYPE
,即GTK_TYPE_APPLICATION
"application-id"
,它告诉下一个参数是应用程序的 ID“org.gtk.exampleapp”
,ID"flags"
,告诉下一个参数是一个标志“G_APPLICATION_HANDLES_OPEN”
,一个标志NULL
,终止符
g_object_new
,这样调用,返回 GtkApplication
,其 ID 为 "org.gtk.exampleapp"
并带有标志 “G_APPLICATION_HANDLES_OPEN”
。程序返回到 example_app_new
后,它会退出并返回一个 ExampleApp *
类型的新对象。 GtkApplication *
到 main
。新应用使用 G_APPLICATION
宏在 g_application_run
中转换为 GApplication
。
这个问题顶部链接的教程说这会创建一个空窗口。在本教程的前面部分(例如 this one ),我们使用 g_signal_connect
在应用运行时调用函数。例如,
g_signal_connect (app, "activate", G_CALLBACK (activate), NULL);
当使用 g_application_run
运行应用 app
时,调用函数 activate
。函数 activate
通常会创建一个窗口并通过自身或调用其他函数来填充它。这就是令我困惑的地方:我们的示例应用程序程序中没有这样的东西。那么如何创建一个窗口呢?
最佳答案
问题在于重写 activate
和 open
函数。它说here :
为了处理这两种情况,我们重写 activate() vfunc(在没有命令行参数的情况下启动应用程序时调用该函数)和 open() vfunc(在使用命令行参数启动应用程序时调用该函数) .
因此,函数
static void
example_app_activate (GApplication *app)
{
ExampleAppWindow *win;
win = example_app_window_new (EXAMPLE_APP (app));
gtk_window_present (GTK_WINDOW (win));
}
在不带参数运行应用程序时调用。
static void
example_app_open (GApplication *app,
GFile **files,
gint n_files,
const gchar *hint)
{
GList *windows;
ExampleAppWindow *win;
int i;
windows = gtk_application_get_windows (GTK_APPLICATION (app));
if (windows)
win = EXAMPLE_APP_WINDOW (windows->data);
else
win = example_app_window_new (EXAMPLE_APP (app));
for (i = 0; i < n_files; i++)
example_app_window_open (win, files[i]);
gtk_window_present (GTK_WINDOW (win));
}
当有给定参数时调用。
关于c - 在此 GTK 应用程序中如何创建窗口?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52136240/