可以使用布局来实现按钮随窗体大小自动缩放的效果。具体步骤如下:
- 在Qt Designer中将按钮添加到布局中(例如垂直布局)。
- 选择布局,设置其对齐方式为左上角,并将其内部填充设为0。
- 在代码中创建QWidget对象,并将其设置为窗体的centralWidget。
- 将布局添加到QWidget对象中。
- 设置窗体的resizeEvent事件,每次调整窗体大小时重新计算按钮的大小。
示例代码如下:
//在头文件中声明需要用到的类和变量
#include <QMainWindow>
#include <QVBoxLayout>
#include <QPushButton>
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
MainWindow(QWidget *parent = nullptr);
~MainWindow();
private:
QWidget *centralWidget;
QVBoxLayout *layout;
QPushButton *button;
protected:
void resizeEvent(QResizeEvent *event);
};
//在源文件中实现相应函数
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
{
//创建QWidget对象并设置为centralWidget
centralWidget = new QWidget(this);
setCentralWidget(centralWidget);
//创建垂直布局并添加到QWidget对象中
layout = new QVBoxLayout(centralWidget);
layout->setAlignment(Qt::AlignTop | Qt::AlignLeft);
layout->setContentsMargins(0, 0, 0, 0);
//创建按钮并添加到布局中
button = new QPushButton("Button", centralWidget);
layout->addWidget(button);
}
MainWindow::~MainWindow()
{
}
void MainWindow::resizeEvent(QResizeEvent *event)
{
//重新计算按钮的大小
QSize size = centralWidget->size();
button->setFixedSize(size.width() / 2, size.height() / 2);
QMainWindow::resizeEvent(event);
}