QT控件QDialog结合QDialogButtonBox实现确认弹窗

        项目需要二次确认开启,添加一个确认弹窗,采用QDialog并添加按钮控件。

        QDialogButtonBox控件用于添加按钮组,初始化时可以增加标准按键,但是不能自定义按钮文字。

        想要更改按键大小,但是没有提供设置组内按钮大小的函数和方法,实测使用样式表可以更改:

    //确认弹窗
    QDialog dialog;
    dialog.setWindowTitle("确认");
    dialog.resize(400, 200);
    QVBoxLayout *layout = new QVBoxLayout(&dialog);
    QLabel *label = new QLabel("确定要继续吗?", &dialog);
    QFont font("Arial", 15, QFont::Bold);
    label->setFont(font);
    label->setAlignment(Qt::AlignCenter);
    label->setGeometry(0, 0, 200, 50);
    layout->addWidget(label);

    //使用QDialogButtonBox简化按钮的创建和连接
    QDialogButtonBox *buttonBox = new QDialogButtonBox(&dialog);
    buttonBox->setMinimumSize(QSize(100, 100));
    buttonBox->setMaximumSize(QSize(400, 200));

    QPushButton *okButton = new QPushButton("确定");
    QPushButton *cancelButton = new QPushButton("取消");
    buttonBox->addButton(okButton, QDialogButtonBox::ActionRole);
    buttonBox->addButton(cancelButton, QDialogButtonBox::ActionRole);
    buttonBox->setStyleSheet("QPushButton { margin-right: 50px; width: 100px; height: 50px; }");

    connect(okButton, &QPushButton::clicked, &dialog, &QDialog::accept);
    connect(cancelButton, &QPushButton::clicked, &dialog, &QDialog::reject);

    layout->addWidget(buttonBox);

    int ret = dialog.exec();
    //根据选择进行响应
    if (ret == QDialog::Accepted) {

    } else {
        
    }

这里采用自定义按钮,然后添加至QDialogButtonBox的方式,修改样式表即可。

margin-right为按钮间距。

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

plmm烟酒僧

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值