如何将文件拖放到哪个 GTKMM 图像小部件


....
std::vector<Gtk::TargetEntry> listTargets;
listTargets.push_back( Gtk::TargetEntry("STRING") );
listTargets.push_back( Gtk::TargetEntry("text/plain") );
image1->drag_dest_set(listTargets);
image1->signal_drag_data_received().connect(sigc::mem_fun(*this,
              &mainWindow::drop_event) );
image2->drag_dest_set(listTargets);
image2->signal_drag_data_received().connect(sigc::mem_fun(*this,
                  &mainWindow::drop_event) );
....

和我的拖放事件处理程序函数:

void mainWindow::drop_event(
        const Glib::RefPtr<Gdk::DragContext>& context, int, int,
        const Gtk::SelectionData& selection_data, guint, guint time)
{
    std::cout << selection_data.get_data_as_string()  << std::endl;
}

我可以使用此代码获取"拖动到图像小部件"的文件位置。 输出如下所示:

file:////opt/google/chrome/google-chrome.desktop
file:////var/www/index.html
file:///opt/libreoffice4.1/LICENSE.html

没关系,我可以。但是,我怎么能得到:文件拖放到哪个图像(图像 1 或 image2 小部件(,如下所示:

dropped to **image1** : file:////opt/google/chrome/google-chrome.desktop
dropped to **image2** : file:////var/www/index.html
dropped to **image1** : file:///opt/libreoffice4.1/LICENSE.html

谢谢。。。

sigc 允许您将额外的参数绑定到处理程序。

汉德变成:

void mainWindow::drop_event(
        const Glib::RefPtr<Gdk::DragContext>& context, int, int,
        const Gtk::SelectionData& selection_data, guint, guint time, 
        Glib::ustring whichImage)
{
    std::cout << "dropped to" << whichImage << ":" << selection_data.get_data_as_string()  << std::endl;
}

那么connect是:

image1->signal_drag_data_received().connect(sigc::bind<Glib::ustring>(sigc::mem_fun(*this,
              &mainWindow::drop_event), "image1" ));
image2->signal_drag_data_received().connect( sigc::bind<Glib::ustring>(sigc::mem_fun(*this,
                  &mainWindow::drop_event), "image2"));

相关内容

  • 没有找到相关文章

最新更新