我正在尝试'继承'一个GtkWidget。我可以继承任何其他小部件,如GtkWindow等,并在自己的文件中实现其方法。然后我将使用一个函数加载新的小部件,该函数返回小部件,就像return g_object_new(...
一样。
代码工作正常,但我在struct init函数中得到不兼容的指针类型警告。
class.h
#ifndef CLASS_H_INCLUDED
#define CLASS_H_INCLUDED
#include <gtk/gtk.h>
#define CLASS_NAME_TYPE (class_name_get_type())
G_DECLARE_FINAL_TYPE(ClassName, class_name, CLASS, NAME, GtkWidget)
ClassName *class_name_new();
#endif // CLASS_H_INCLUDED
class.c
#include "class.h"
struct _ClassName
{
GtkWidget parent;
};
G_DEFINE_TYPE(ClassName, class_name, GTK_TYPE_WIDGET);
static void class_name_init(ClassName *self)
{
gtk_widget_set_name(self, "Widget");
}
static void class_name_class_init(ClassNameClass *klass)
{
}
ClassName *class_name_new()
{
return g_object_new(CLASS_NAME_TYPE, /* "foo", bar ,*/ NULL);
}
在函数static void class_name_init(ClassName *self)
中,我想像这样使用指针self
gtk_widget_set_name(self, "Widget");
这是我有兼容的指针类型的地方。 gtk_widget_set_name()期望类型为GtkWidget作为输入,但init函数的类型为ClassName。
Gtk知道ClassName与GtkWidget是相同的类型,因此代码可以工作,但无论如何都要修复代码,以便编译器不认为它是一个错误
通常,您应该使用强制转换操作符来避免编译器警告,假设self是一个指针:
gtk_widget_set_name((GtkWidget*)self, "Widget");
定义对象也像GTK_WIDGET(obj)
一样工作
代替
gtk_widget_set_name(self, "Widget");
做
gtk_widget_set_name(GTK_WIDGET(self), "Widget");`
如果self是一个窗口GTK_WINDOW(self)
,你总是可以定义对象