在GTK +中,是否可以访问GtkFileChooser
中文件名的GtkWidget - 文本条目?我想使用gtk_entry_set_editable
禁用文本条目的可编辑属性。
答案 0 :(得分:1)
据我所知,没有。
你最终想要达到什么目的?也许还有另一种方法。
答案 1 :(得分:0)
如果有正当理由获得指向GtkEntry的指针,则从GtkFileChooserDialog派生,这可能会变异为GtkFileChooserDefault。 GObject会在检查类型实例时抱怨非法转换,即使它正常工作并且可以无错误地访问派生对象的数据,使用GTK_FILE_CHOOSER而不是MY_FILE_CHOOSER来避免警告消息和入口指针的本地静态。在构造期间无法访问条目小部件。以下是相关代码:
static GtkEntry *chooser_entry;
static void my_file_chooser_finalize (GObject *object)
{
chooser_entry = NULL;
(G_OBJECT_CLASS (my_file_chooser_parent_class))->finalize (object);
}
static void my_file_chooser_init (MyFileChooser *self)
{
chooser_entry = NULL;
}
static void look_for_entry(GtkWidget *widget, void *self)
{
if (GTK_IS_ENTRY(widget)) {
chooser_entry = (GtkEntry*)widget;
}
else if (GTK_IS_CONTAINER(widget)) {
gtk_container_forall ( GTK_CONTAINER (widget), look_for_entry, self);
}
}
static void file_chooser_find_entry (GtkWidget *chooser)
{
GList *children, *iter;
/* Get all objects inside the dialog */
children = gtk_container_get_children (GTK_CONTAINER (chooser));
for (iter = children; iter; iter = iter->next) {
if (GTK_IS_CONTAINER(iter->data)) {
gtk_container_forall ( GTK_CONTAINER (iter->data), look_for_entry, chooser);
if (chooser_entry != NULL) {
break;
}
}
}
g_list_free (children);
}
GtkEntry *my_file_chooser_get_entry (GtkWidget *widget)
{
if (chooser_entry == NULL) {
file_chooser_find_entry (widget);
}
return chooser_entry;
}
char *my_file_chooser_get_entry_text(GtkWidget *widget)
{
char *text;
GtkEntry *entry;
text = NULL;
if (GTK_IS_FILE_CHOOSER(widget)) {
entry = my_file_chooser_get_entry(widget);
if (GTK_IS_ENTRY(entry)) {
if (gtk_entry_get_text_length (entry)) {
text = g_strdup (gtk_entry_get_text(entry));
}
}
}
return text;
}
也许不理想,但有效。