访问宇宙 2023-03-06 21:28 采纳率: 80.4%
浏览 14
已结题

QT中如何实现CSharp中的InitializeComponent()初始化组件的方法

请问QT中如何实现CSharp中的InitializeComponent()初始化组件的方法?
代码如下,如何改写成QT或C++代码?
namespace TongDa.myPage
{
    /// 
    /// Page0.xaml 的交互逻辑
    /// 
    public partial class Page0 : Page
    {
        public Page0()
        {
            InitializeComponent();
        }

        private void dataGrid1_CellEditEnding(object sender, DataGridCellEditEndingEventArgs e)
        {
            MainWindow.partnum_combobox_update();
        }

        private void dataGrid1_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            MainWindow.partnum_combobox_update();
        }
    }
}
  • 写回答

1条回答 默认 最新

  • CodeBytes 2023-03-07 09:11
    关注

    该回答引用ChatGPT

    在Qt中,UI组件的初始化一般是在.ui文件中完成,通过Qt的UI设计器可以快速生成对应的C++代码。在C++代码中,使用类似于C#中的构造函数对UI进行初始化。

    例如,对于一个名为MyWidget的QWidget类,可以使用如下的方式进行UI初始化:

    
    #include "ui_mywidget.h"
    
    class MyWidget : public QWidget
    {
    public:
        MyWidget(QWidget *parent = nullptr)
            : QWidget(parent), ui(new Ui::MyWidget)
        {
            ui->setupUi(this);
        }
    
    private:
        Ui::MyWidget *ui;
    };
    
    

    在这个例子中,我们首先包含了一个名为“ui_mywidget.h”的头文件,该头文件是Qt UI设计器自动生成的,包含了UI组件的定义和初始化函数。然后在MyWidget的构造函数中,使用ui->setupUi(this)函数完成UI初始化。

    对于您提供的C#代码,可以考虑将Page0类对应的UI组件定义放到一个单独的.ui文件中,然后通过Qt的UI设计器生成对应的C++代码。然后在Page0的构造函数中,使用与上面类似的方式进行UI初始化。

    
    #include "ui_page0.h"
    #include "mainwindow.h"
    
    class Page0 : public QWidget
    {
    public:
        Page0(QWidget *parent = nullptr)
            : QWidget(parent), ui(new Ui::Page0)
        {
            ui->setupUi(this);
    
            connect(ui->dataGrid1, &QDataGrid::cellEditEnding,
                    this, &Page0::dataGrid1_CellEditEnding);
            connect(ui->dataGrid1, &QDataGrid::selectionChanged,
                    this, &Page0::dataGrid1_SelectionChanged);
        }
    
    private:
        Ui::Page0 *ui;
    
    private slots:
        void dataGrid1_CellEditEnding(QDataGridCellEditEndingEventArgs *e)
        {
            MainWindow::partnum_combobox_update();
        }
    
        void dataGrid1_SelectionChanged(QSelectionChangedEventArgs *e)
        {
            MainWindow::partnum_combobox_update();
        }
    };
    
    

    在这个例子中,我们首先包含了一个名为“ui_page0.h”的头文件,该头文件是Qt UI设计器自动生成的,包含了Page0类对应的UI组件的定义和初始化函数。然后在Page0的构造函数中,使用ui->setupUi(this)函数完成UI初始化,并通过connect函数将dataGrid1_CellEditEnding和dataGrid1_SelectionChanged函数与对应的UI组件的信号关联起来。在这两个函数中,我们调用了MainWindow::partnum_combobox_update()函数,与C#代码中的相应部分类似。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月15日
  • 已采纳回答 3月7日
  • 创建了问题 3月6日

悬赏问题

  • ¥15 CMAKE+VS2019+QT5.15.2组合进行二次编译
  • ¥15 nginx 配置静态html访问 ,后台登录时页面始终被重定向到登录页,无法访问到后台的静态html页
  • ¥20 自动登录的j2ee程序编译
  • ¥15 fluent模拟静态气体扩散
  • ¥15 java根据模板,生成word文档,需要带目录
  • ¥15 广告联盟的兜底广告是什么意思
  • ¥15 如何证明高斯噪声的包络公式
  • ¥150 寻找王者荣耀开发作者,合作或者解答
  • ¥15 关于cpci总线的几个问题,别用人工智能回答
  • ¥15 乳腺癌数据集 相关矩阵 特征选择