自学内容网 自学内容网

qt Qt设计师和自定义代码布局结合

        要将 Qt Designer 生成的 UI 布局与代码中自定义的布局结合起来,你可以使用一个占位符(如 QWidget或 QVBoxLayout),然后将 Designer 生成的布局插入到这个占位符中。假设你使用了 Ui::PolicykitAgentGUI 这个类来管理 Qt Designer 生成的 UI。

以下是如何处理这种情况的一个示例:

        1. 首先,在 Qt Designer 中设计你的界面,并确保你有一个占位符(例如 QWidget)来插入自定义的布局。

        2. 在代码中使用 setupUi() 方法初始化 Qt Designer 生成的 UI,然后将它嵌入到你的自定义布局中。
        下面是一个修改后的示例代码,展示如何将 Qt Designer 生成的 UI 布局插入到自定义的布局中:
 

#include "policykitagentgui.h"
#include "ui_policykitagentgui.h"

PolicykitAgentGUI::PolicykitAgentGUI(const QString &actionId,
                                     const QString &message,
                                     const QString &iconName,
                                     const PolkitQt1::Details &details,
                                     const PolkitQt1::Identity::List &identities)
   : QDialog(0, Qt::WindowStaysOnTopHint), ui(new Ui::PolicykitAgentGUI)
{
    // Setup the UI from Designer
    ui->setupUi(this);

    // Set the window flags for frameless window
    this->setWindowFlags(Qt::FramelessWindowHint);

    // Create a custom title bar and layout
    TitleBar *pTitle = new TitleBar();
    QVBoxLayout *pVLayout = new QVBoxLayout();
    pVLayout->addWidget(pTitle);

    // Add the rest of the UI from Designer into the custom layout
    pVLayout->addWidget(ui->centralWidget);  // Assuming centralWidget is the main widget in your Designer UI
    this->setLayout(pVLayout);

    // Set message and icon
    ui->messageLabel->setText(message);
    QIcon icon = QIcon::fromTheme(iconName);
    if (icon.isNull())
        icon = QIcon::fromTheme(QLatin1String("dialog-question"));
    ui->iconLabel->setPixmap(icon.pixmap(64, 64));

    // Get current user ID
    const uid_t current_uid = getuid();
    int current_user_index = -1;

    // Populate the identity combo box
    for (const PolkitQt1::Identity &identity : identities)
    {
        const int i = ui->identityComboBox->count(); // index of the added item
        ui->identityComboBox->addItem(identity.toString());
        const PolkitQt1::UnixUserIdentity *u_id = static_cast<const PolkitQt1::UnixUserIdentity *>(&identity);
        if (u_id != nullptr && u_id->uid() == current_uid)
            current_user_index = i;
    }

    // Set current user index if valid
    if (current_user_index != -1)
        ui->identityComboBox->setCurrentIndex(current_user_index);

    // Connect signals and slots
    connect(ui->identityComboBox, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), this, &PolicykitAgentGUI::onIdentityChanged);
    ui->passwordEdit->setFocus(Qt::OtherFocusReason);
}

PolicykitAgentGUI::~PolicykitAgentGUI()
{
    delete ui;
}

在这个示例中:

- 使用 ui->setupUi(this);初始化从 Qt Designer 生成的 UI。
- 使用 pVLayout->addWidget(ui->centralWidget); 将 Designer 生成的 UI 嵌入到自定义的布局中。确保 centralWidget 是你在 Designer 中主容器的对象名称。
- 通过 this->setLayout(pVLayout); 设置自定义布局。

        这样可以将 Qt Designer 生成的 UI 与自定义的布局结合起来。确保在 Qt Designer 中使用的对象名称(如 `centralWidget`)与代码中的名称一致。


原文地址:https://blog.csdn.net/qq_43287763/article/details/140543207

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!