在看這篇之前,請先看過 GtkComboBox 與 GtkListStore,由於以Model-View的方式設計,您可以在不修改Model的情況下,為Model換上另一個顯示的外觀(View),例如為 GtkComboBox 與 GtkListStore 範例中建立的GtkListStore換上GtkTreeView的外觀。
具體來說,也就是該範例中的createModel()內容無需改變,將GtkComboBox的相對應程式碼,換成建立GtkTreeView的程式碼,例如:
GtkWidget *treeView = gtk_tree_view_new_with_model(createModel());
GtkCellRenderer *renderer = gtk_cell_renderer_pixbuf_new();
GtkTreeViewColumn *column = gtk_tree_view_column_new_with_attributes(
"Icon", renderer,
"pixbuf",
PIXBUF_COL,
NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW (treeView), column);
renderer = gtk_cell_renderer_text_new();
column = gtk_tree_view_column_new_with_attributes(
"Filename", renderer,
"text", TEXT_COL,
NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW (treeView), column);
GtkTreeViewColumn是GtkTreeView中的列代表,可用以設定該列的內容如何
繪製以及一些相關屬性,基本上以上程式片段中,gtk_tree_view_column_new_with_attributes()與
gtk_tree_view_append_column()函式可以用
gtk_tree_view_insert_column_with_attributes()函式來簡化,也就是可以簡化為:
GtkWidget *treeView = gtk_tree_view_new_with_model(createModel());
GtkCellRenderer *renderer = gtk_cell_renderer_pixbuf_new();
gtk_tree_view_insert_column_with_attributes(
GTK_TREE_VIEW(treeView), -1, "Icon", renderer,
"pixbuf", PIXBUF_COL,
NULL);
renderer = gtk_cell_renderer_text_new();
gtk_tree_view_insert_column_with_attributes(
GTK_TREE_VIEW(treeView), -1, "Filename", renderer,
"text", TEXT_COL,
NULL);
在GtkTreeView當中的選擇,是以為個GtkTreeSelection物件作代表,當選擇改變時,會發出"changed"的Signal,所以要連結Signal與Callback函式,可以如下進行:
GtkTreeSelection *selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeView));
g_signal_connect(G_OBJECT(selection), "changed",
G_CALLBACK(selection_changed), label);
至於Callback函式的部份大同小異,您要從傳遞的GtkTreeSelection中取得GtkTreeView,從GtkTreeView中取得
GtkTreeModel,再使用gtk_tree_selection_get_selected()將GtkTreeIter指向選中的列,以取得您
想取得的欄位資料:
gboolean selection_changed(GtkTreeSelection *selection, GtkLabel *label) {
GtkTreeView *treeView;
GtkTreeModel *model;
GtkTreeIter iter;
gchar *active;
treeView = gtk_tree_selection_get_tree_view(selection);
model = gtk_tree_view_get_model(treeView);
gtk_tree_selection_get_selected(selection, &model, &iter);
gtk_tree_model_get(model, &iter,
1, &active,
-1);
gtk_label_set_text(label, active);
}
下面的範例是以上說明的綜合示範:
#include <gtk/gtk.h>
enum {
PIXBUF_COL,
TEXT_COL
};
GtkTreeModel* createModel() {
const gchar *files[] = {"caterpillar.jpg", "momor.jpg",
"hamimi.jpg", "bush.jpg"};
GdkPixbuf *pixbuf;
GtkTreeIter iter;
GtkListStore *store;
gint i;
store = gtk_list_store_new(2, GDK_TYPE_PIXBUF, G_TYPE_STRING);
for(i = 0; i < 4; i++) {
pixbuf = gdk_pixbuf_new_from_file(files[i], NULL);
gtk_list_store_append(store, &iter);
gtk_list_store_set(store, &iter,
PIXBUF_COL, pixbuf,
TEXT_COL, files[i],
-1);
gdk_pixbuf_unref(pixbuf);
}
return GTK_TREE_MODEL(store);
}
gboolean selection_changed(GtkTreeSelection *selection, GtkLabel *label) {
GtkTreeView *treeView;
GtkTreeModel *model;
GtkTreeIter iter;
gchar *active;
treeView = gtk_tree_selection_get_tree_view(selection);
model = gtk_tree_view_get_model(treeView);
gtk_tree_selection_get_selected(selection, &model, &iter);
gtk_tree_model_get(model, &iter,
1, &active,
-1);
gtk_label_set_text(label, active);
}
int main(int argc, char *argv[]) {
GtkWidget *window;
GtkWidget *treeView;
GtkCellRenderer *renderer;
GtkTreeViewColumn *column;
GtkWidget *label;
GtkWidget *vbox;
GtkTreeSelection *selection;
gtk_init(&argc, &argv);
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_window_set_title(GTK_WINDOW(window), "GtkTreeView");
gtk_window_set_default_size(GTK_WINDOW(window), 200, 50);
treeView = gtk_tree_view_new_with_model(createModel());
renderer = gtk_cell_renderer_pixbuf_new();
column = gtk_tree_view_column_new_with_attributes(
"Icon", renderer,
"pixbuf", PIXBUF_COL,
NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW (treeView), column);
renderer = gtk_cell_renderer_text_new();
column = gtk_tree_view_column_new_with_attributes(
"Filename", renderer,
"text", TEXT_COL,
NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW (treeView), column);
label = gtk_label_new("caterpillar.jpg");
vbox = gtk_vbox_new(FALSE, 5);
gtk_box_pack_start(GTK_BOX(vbox), treeView, TRUE, TRUE, 5);
gtk_box_pack_start(GTK_BOX(vbox), label, TRUE, TRUE, 5);
gtk_container_add(GTK_CONTAINER(window), vbox);
selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeView));
g_signal_connect(G_OBJECT(selection), "changed",
G_CALLBACK(selection_changed), label);
g_signal_connect(GTK_OBJECT(window), "destroy",
G_CALLBACK(gtk_main_quit), NULL);
gtk_widget_show_all(window);
gtk_main();
return 0;
}
一個執行的結果畫面如下所示:
有了以上的基礎,要在GtkTreeView搭配GtkTreeStore就沒什麼好解釋的了,下面這個範例,只是將範例中的createModel()函式,換成 GtkComboBox 與 GtkTreeStore 中的createModel()函式,剩下的都沒有改變,也就是為 GtkComboBox 與 GtkTreeStore 中的Model換上GtkTreeView的外觀顯示:
- gtk_tree_view_with_tree_store.c
#include <gtk/gtk.h>
enum {
PIXBUF_COL,
TEXT_COL
};
GtkTreeModel* createModel() {
const gchar *files[] = {"caterpillar.jpg", "momor.jpg",
"hamimi.jpg", "bush.jpg"};
gchar *stocks[] = {
GTK_STOCK_DIALOG_WARNING,
GTK_STOCK_STOP,
GTK_STOCK_NEW,
GTK_STOCK_CLEAR,
GTK_STOCK_OPEN
};
gchar *stockNames[] = {
"WARNING",
"STOP",
"NEW",
"GTK_STOCK_CLEAR",
"GTK_STOCK_OPEN"
};
GtkWidget *cellView;
GdkPixbuf *pixbuf;
GtkTreeIter iter1, iter2;
GtkTreeStore *store;
gint i, j, s;
store = gtk_tree_store_new(2, GDK_TYPE_PIXBUF, G_TYPE_STRING);
cellView = gtk_cell_view_new();
for(i = 0; i < 4; i++) {
pixbuf = gdk_pixbuf_new_from_file(files[i], NULL);
gtk_tree_store_append(store, &iter1, NULL);
gtk_tree_store_set(store, &iter1,
PIXBUF_COL, pixbuf,
TEXT_COL, files[i],
-1);
gdk_pixbuf_unref(pixbuf);
for(j = 0; j < 3; j++) {
s = rand() % 5;
pixbuf = gtk_widget_render_icon(cellView, stocks[s],
GTK_ICON_SIZE_BUTTON, NULL);
gtk_tree_store_append(store, &iter2, &iter1);
gtk_tree_store_set(store, &iter2,
PIXBUF_COL, pixbuf,
TEXT_COL, stockNames[s],
-1);
gdk_pixbuf_unref(pixbuf);
}
}
return GTK_TREE_MODEL(store);
}
gboolean selection_changed(GtkTreeSelection *selection, GtkLabel *label) {
GtkTreeView *treeView;
GtkTreeModel *model;
GtkTreeIter iter;
gchar *active;
treeView = gtk_tree_selection_get_tree_view(selection);
model = gtk_tree_view_get_model(treeView);
gtk_tree_selection_get_selected(selection, &model, &iter);
gtk_tree_model_get(model, &iter,
1, &active,
-1);
gtk_label_set_text(label, active);
}
int main(int argc, char *argv[]) {
GtkWidget *window;
GtkWidget *treeView;
GtkCellRenderer *renderer;
GtkTreeViewColumn *column;
GtkWidget *label;
GtkWidget *vbox;
GtkTreeSelection *selection;
gtk_init(&argc, &argv);
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_window_set_title(GTK_WINDOW(window), "GtkTreeView");
gtk_window_set_default_size(GTK_WINDOW(window), 200, 50);
treeView = gtk_tree_view_new_with_model(createModel());
renderer = gtk_cell_renderer_pixbuf_new();
column = gtk_tree_view_column_new_with_attributes(
"Icon", renderer,
"pixbuf", PIXBUF_COL,
NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW (treeView), column);
renderer = gtk_cell_renderer_text_new();
column = gtk_tree_view_column_new_with_attributes(
"Filename", renderer,
"text", TEXT_COL,
NULL);
gtk_tree_view_append_column(GTK_TREE_VIEW (treeView), column);
label = gtk_label_new("caterpillar.jpg");
vbox = gtk_vbox_new(FALSE, 5);
gtk_box_pack_start(GTK_BOX(vbox), treeView, TRUE, TRUE, 5);
gtk_box_pack_start(GTK_BOX(vbox), label, TRUE, TRUE, 5);
gtk_container_add(GTK_CONTAINER(window), vbox);
selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeView));
g_signal_connect(G_OBJECT(selection), "changed",
G_CALLBACK(selection_changed), label);
g_signal_connect(GTK_OBJECT(window), "destroy",
G_CALLBACK(gtk_main_quit), NULL);
gtk_widget_show_all(window);
gtk_main();
return 0;
}
一個執行的結果如下所示:
分享到:
相关推荐
此文件为《GtkTreeView用法详解》配备的源代码。 这里面包含了几个文件: GtkTreeView.c Makefile GtkTreeView可执行程序 一副截图+一个pdf文档 更详细的资料请查看《GtkTreeView用法详解》 由于在 ShareJ...
GtkTreeView 构件是一个高级的构件,利用他你就可以制作出漂亮的普通列表或者是树状的列表。这个构件里可以包含一或者多行。他的构架呢?正是采用了大名鼎鼎的MVC (Model View Controller) 设计框架。也就是说数据和...
需要注意的是,`GtkTreeView`会自动管理模型的引用计数,这意味着当`GtkTreeView`不再需要模型时,它会自动释放对模型的引用。 **4.2 TreeView 的外观** 可以通过设置`GtkTreeView`的各种属性来改变其外观,例如...
#### 一、列表与树:GtkTreeView 控件 在 GTK+ 2.0 中,GtkTreeView 是一个用于显示数据的树状结构视图。它通常用于展示分层的数据集,如文件系统、组织结构等。 ##### 1.1 HelloWorld 示例 一个简单的 ...
重点在于,作者通过一个实例展示了如何使用GTK+中的GtkTreeView控件来显示和操作数据库(此处是MySQL数据库)中的数据。GtkTreeView是一种可用来展示列表或表格数据的控件,非常适合于数据库应用。通过C语言进行开发...
4. **GtkTreeView**: “GtkTreeView-1基础.doc”和“GtkTextView-3文本操作.doc”可能讲解了如何使用这个组件来展示表格和列表数据。GtkTreeView是一个强大的视图组件,可以显示多列数据,并支持排序、筛选和编辑。...
`GtkListView`(通常表现为`GtkTreeView`)则是一个视图,显示模型中的数据。你可以通过`GtkCellRenderer`自定义单元格的显示方式,比如文本、图像或者组合。 - **TreeView**:`GtkTreeView`是GTK+中的一个强大...
`GtkTreeView`是GTK+库中用于显示数据的树状或列表视图的组件。通过这个组件,开发者可以构建复杂的数据展示界面,适用于各种应用场景,如文件管理器、联系人列表等。 #### 1.1 HelloWorld 入门示例通常是最简单的...
- **clist.c**:这个例子展示了如何使用`GtkList`或`GtkTreeView`控件来显示和操作列表数据。这些控件允许用户浏览和选择多行数据,常用于数据表或目录列表。 - **text.c**:演示了`GtkTextBuffer`和`GtkTextView`...
如果需要自定义外观,则可以考虑使用 `GtkTreeView` 或 `GtkIconView`。 #### 五、编辑功能 WebKitGTK+ 提供了强大的编辑能力,只需一行代码即可启用: ```c webkit_web_view_set_editable(WEB_VIEW(view), TRUE)...
9. **高级控件**:除了基础控件外,GTK还有许多高级控件,如树视图(GtkTreeView)、列表视图(GtkListView)、进度条(GtkProgressBar)和日历(GtkCalendar)等,它们可以用来实现更复杂的用户界面功能。...
在这个应用中,开发者可能使用了GtkTreeModel来存储文件系统中的目录和文件信息,然后通过GtkTreeView来显示这些信息。通过设置列标题(如“名称”、“类型”、“大小”和“修改时间”),用户可以一目了然地查看...
除了基本控件,GTK+2.0还提供了一些高级组件,例如文件选择对话框(GtkFileChooser)、进度条(GtkProgressBar)和树视图(GtkTreeView)。这些组件使得开发者可以构建功能更强大的应用程序,比如支持文件操作或数据...
例如,使用GTK+,你需要学习GtkWidget、GtkWindow、GtkBox、GtkTreeView等类,以及信号和回调机制,以响应用户的点击、拖放等事件。 文件操作不仅限于读写,还包括复制、移动、重命名、删除等。这些功能需要调用...
此外,还会介绍高级小部件,如树视图(GtkTreeView)、笔记面板(GtkNotebook)和进度条(GtkProgressBar)。 7. **主题和国际化**:GTK支持主题引擎,允许用户改变应用程序的外观。教程会讲解如何使应用支持不同...
GTK+2.0提供了数据模型(GtkTreeModel)和视图(GtkTreeView)的接口,用于显示和操作表格或列表数据。 此外,文档还将涵盖对话框(Dialogs)、文件选择器、打印支持、拖放功能以及如何创建自定义小部件等内容。GTK...
4. **数据模型与视图**:GTK+支持模型-视图-控制器(MVC)设计模式,例如GtkTreeView用于显示列表或树状数据,通过绑定到各种数据模型(如GtkListStore或GtkTreeStore)来更新视图。 5. **国际化与本地化**:GTK+...
2. 查看:查看学生信息通常需要展示在表格或列表视图中,GTK提供了列表框(GtkListStore)和树视图(GtkTreeView)来实现这一功能。开发者会创建一个模型来存储所有学生数据,然后通过适配器(GtkTreeModel)将其...
例如,可以使用`GtkBox`或`GtkGrid`进行布局管理,使用`GtkButton`创建按钮,`GtkListStore`和`GtkTreeView`组合实现歌曲列表的显示与交互。 其次,Gstreamer是一个流水线式多媒体处理框架,它允许开发者灵活地组合...