首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >signal_response of gtkmm4 FileChooserNative与该函数连接的构建错误

signal_response of gtkmm4 FileChooserNative与该函数连接的构建错误
EN

Stack Overflow用户
提问于 2021-08-08 13:49:38
回答 1查看 55关注 0票数 0

我需要将signal_response of FileChooserNative连接到函数,但是当我尝试使用来自用gtkmm 4书编程的示例代码时出错了。

当我试图编译它时(g++,XCLT,macOS Big ):

代码语言:javascript
复制
void MyWindow::on_button_browse_clicked(){
auto dialog = Gtk::FileChooserNative::create("Please choose a folder", *this,
Gtk::FileChooser::Action::SELECT_FOLDER, "Choose", "Cancel");
dialog->set_transient_for(*this);
dialog->set_modal(true);
dialog->signal_response().connect(sigc::bind(sigc::mem_fun(*this,
&MyWindow::on_folder_dialog_response), dialog)); // <- error
dialog->show();}

再现问题的最小.cpp是这里 (pastebin)。

我得到了in instantiation of function template specialization...错误。完整的构建日志是这里 (pastebin)。

我的目标是从文件选择对话框发送响应到on_folder_dialog_response函数,然后显示到终端文件夹的路径。

将响应从文件选择对话框连接到函数的正确代码是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-08 15:15:09

您有一个构建错误,因为您提供的额外参数的类型不是Gtk::FileChooserNative*,而是Glib::RefPtr<Gtk::FileChooserNative> (这就是隐藏在auto后面的内容)。所以你应该:

代码语言:javascript
复制
void MyWindow::on_folder_dialog_response(int response_id, Glib::RefPtr<Gtk::FileChooserNative>& dialog)

而不是。但是,请注意,dialog实例将在MyWindow::on_button_browse_clicked结束时死亡,并且将留下一个空引用。

使用Gtkmm 3.24 (您可能需要修改一下Gtkmm 4),我为您编写了一个小示例:

代码语言:javascript
复制
#include <iostream>

#include <gtkmm.h>

class MainWindow : public Gtk::Window
{

public:

    MainWindow();

private:

    // Handler for when the user clicks the "Open file chooser dialog..." button
    // on the main window. This:
    //
    //  1. Creates the file chooser.
    //  2. Connects the response signal handler, to know about what the user
    //     will have done with the chooser.
    //  3. Shows the file chooser.
    //
    // So when this is done the user is presented the file chooser.
    void OnButtonBrowseClicked()
    {
        m_fileChooser = Gtk::FileChooserNative::create("Please choose a folder",  
                                                       *this,    
                                                       Gtk::FileChooserAction::FILE_CHOOSER_ACTION_SELECT_FOLDER,
                                                       "Choose",
                                                       "Cancel");

        m_fileChooser->signal_response().connect(
            [this](int p_responseID)
            {
                OnBrowseButtonClicked(p_responseID);
            }
        );

        m_fileChooser->show();

    } // m_fileChooser will not be destroyed here because it is a member.

    // User response handler for the file chooser.
    void OnBrowseButtonClicked(int p_responseID)
    {
        switch(p_responseID)
        {
            case Gtk::ResponseType::RESPONSE_ACCEPT:
            {
                std::cout << m_fileChooser->get_file()->get_path() << std::endl;
                break;
            }
            case Gtk::ResponseType::RESPONSE_CANCEL:
            {
                std::cout << "Cancel clicked : " << p_responseID  << std::endl;
                break;
            } 
            default:
            {
                std::cout << "Unexpected button clicked: " << p_responseID << std::endl;
                break;
            }
        }
    }

    // Keeping a reference on the picker. This allows me to use it whenever I need. I can
    // also reset it if I don't need it anymore.
    Glib::RefPtr<Gtk::FileChooserNative> m_fileChooser;

    Gtk::Button m_browseBtn;

};

MainWindow::MainWindow()
: m_browseBtn{"Open file chooser dialog..."}
{
    add(m_browseBtn);

    m_browseBtn.signal_clicked().connect(
        [this]()
        {
            OnButtonBrowseClicked();
        }
    );
}

int main(int argc, char *argv[])
{
    auto app = Gtk::Application::create(argc, argv, "org.gtkmm.examples.base");
  
    MainWindow window;
    window.show_all();
  
    return app->run(window);
}

这基本上允许用户选择一个文件,并将其父目录的路径打印到控制台。

备注:

  1. 我使用了对文件选择器的引用,而不是参数(就像您尝试过的那样)。这使我可以访问它,而不必更改回调的预期原型。它还避免了空引用问题。
  2. 我已经避免了旧式的sigc::bind/sigc::mem_fun,而倾向于lambda的表达。我觉得它不那么晦涩。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68701398

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档