2

我正在学习如何使用 GTKmm,而且我很难弄清楚如何将图像放入树视图中。我使用 Glade 创建了一个包含 3 列的树库,其中之一是GdkPixbuf名为store_pixbuf. 我还在林间空地创建了一个树视图,其中有一列同时具有一个称为 pixbuf 单元格渲染器int_col_pict和一个 char 数组单元格渲染器。在我的代码中,我对树存储有通常的MyColumns定义,例如:

class MyModelColumns : public Gtk::TreeModel::ColumnRecord
{
   public:
   Gtk::TreeModelColumn<Glib::ustring> store_hostname;
   Gtk::TreeModelColumn<Glib::ustring> store_intname;
   Gtk::TreeModelColumn<Glib::RefPtr<Gdk::Pixbuf> > store_pict;

   MyModelColumns   () { add(store_hostname); add(store_intname); add(store_pict);}
};

并使用以下代码填充它。

//Get a pointer to the treestore
Glib::RefPtr<Gtk::TreeStore> treestore = Glib::RefPtr<Gtk::TreeStore>::cast_static(builder->get_object("routerTreeStore"));

//make sure the pointer isn't bad
if(treestore){
MyModelColumns columns;

    //populate the first column
    Gtk::TreeRow row= *(treestore->append());
    row[columns.store_hostname] = router->hostname;

    //populate all children
    for(int i=0; i<router->interfaces.size(); i++)
    {   
        //append child row
        Gtk::TreeRow child = *(treestore->append(row.children()));

        //insert data into the row
        child[columns.store_pict] = Gdk::Pixbuf::create_from_file("red_dot.png");
        child[columns.store_intname] = router->interfaces[i].interfaceName;
    }
}//if

我最初尝试使用股票图像,但我无法弄清楚我应该使用什么功能,所以我尝试使用Gdk::Pixbuf::create_from_file()(如您在上面看到的),但在运行时我收到以下错误:

Gtk-WARNING **: gtktreestore.c:765: Unable to convert from GdkPixbuf to gtkmm__GdkPixbuf

单击此处查看运行的样子。该图像应该与“FastEthernet ...”行在同一行

有谁知道我该如何解决这个问题?我完全错了吗?感谢您的关注,感谢您的每一点帮助!

4

3 回答 3

1

您的代码看起来正确。我刚刚编写了一个简单的示例,使用 gtkmm-2.4,为 Glib::RefPtr 创建列没有问题

我有几个问题:您使用的是什么版本的 gtkmm?您是否在 Pixbuf 的树视图中添加一列?

我不会发布我的完整示例,但相关位是:

在 example.h

  //Tree model columns:
  class ModelColumns : public Gtk::TreeModel::ColumnRecord
  {
  public:

    ModelColumns()
    { add(m_col_store_pict);}
    Gtk::TreeModelColumn<Glib::RefPtr<Gdk::Pixbuf> > m_col_store_pict;

  };

  ModelColumns m_Columns;

在 example.cpp

  //Create the Tree model:
  m_refTreeModel = Gtk::ListStore::create(m_Columns);
  m_TreeView.set_model(m_refTreeModel);

  //Fill the TreeView's model
  Gtk::TreeModel::Row row = *(m_refTreeModel->append());
  row[m_Columns.m_col_store_pict] = Gdk::Pixbuf::create_from_file("/usr/share/icons/gnome/22x22/apps/arts.png");

  row = *(m_refTreeModel->append());
  row[m_Columns.m_col_store_pict] = Gdk::Pixbuf::create_from_file("/usr/share/icons/gnome/22x22/apps/fonts.png");

  row = *(m_refTreeModel->append());
  row[m_Columns.m_col_store_pict] = Gdk::Pixbuf::create_from_file("/usr/share/icons/gnome/22x22/apps/access.png");

  //Add the TreeView's view columns:
  m_TreeView.append_column("Some Picture", m_Columns.m_col_store_pict);

这有什么帮助吗?

于 2011-05-05T14:18:09.350 回答
1

如果您想要的只是每行可能不同的股票图标,您可以通过设置 pixbuf 渲染器属性来实现。这个想法是该列包含一个字符串 stock-id,渲染器将其显示为一个图标。

// in your class declaration

struct columnsRecord : public Gtk::TreeModel::ColumnRecord {
    ...
    Gtk::TreeModelColumn<std::string>    stockID;   // stock id name
    ...
} treeColumns;

Gtk::CellRendererPixBuf     pixBufRenderer;
... 
// setting up columns
int numcols = treeView.append_column("Icon Column", pixBufRenderer);  // returns # cols after append
treeView.get_column(numcols-1)->add_attribute(pixBufRenderer,"stock-id",treeColumns.stockID)
...
// setting a row
std::string id = good_val ? Gtk::Stock::YES.id : Gtk::Stock::NO.id;
rowiter->set_value(columns.stockID,id);
于 2011-11-30T19:55:36.997 回答
0

看起来有必要为 pixbuf 单元显式设置 CellRenderer。此代码片段在每个数据行上显示 CANCEL 图标。

Gtk::CellRendererPixbuf *cross = Gtk::manage(new Gtk::CellRendererPixbuf());
cross->property_stock_id() = Gtk::StockID(Gtk::Stock::CANCEL).get_string();
cross->property_stock_size() = Gtk::ICON_SIZE_BUTTON;
[...]
int cols_count = m_TreeView.append_column("icons", *cross);

要显示自定义图像,您需要删除两行设置 stock_id 添加如下内容:

Gtk::TreeViewColumn* pColumn = m_TreeView.get_column(cols_count - 1);
if(pColumn) {
  pColumn->add_attribute(cell->property_value(), columns.store_pict);
}
于 2011-10-13T09:12:54.243 回答