Qt 在布局好的界面上显示一个控件

如图所示,拉伸移动对话框,数字所示的控件位置都保持在PushButton的右上角。


控件类:

#ifndef MYWIDGET_H
#define MYWIDGET_H

#include <QWidget>

class QLabel;
class MyWidget : public QWidget
{
    Q_OBJECT
public:
    explicit MyWidget(QWidget *parent = 0);
    void showNumber(int num);
    
signals:
    
public slots:
    
private:
    QLabel *label_;
};

#endif // MYWIDGET_H

#include "mywidget.h"
#include <QtGui>

MyWidget::MyWidget(QWidget *parent) :
    QWidget(parent)
{
    label_ = new QLabel(this);
    QString image(":/images/bg.png");
    QPixmap pixmap(image);
    label_->setGeometry(0, 0, pixmap.width(), pixmap.height());
    label_->setStyleSheet(QString("background-color:rgb(0, 0, 0, 0);background-image:url(%1);color:rgb(255, 255, 255)").arg(image));
    this->setFixedSize(pixmap.size());
    label_->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
    label_->setFont(QFont(font().family(), 10, QFont::Bold));
}

void MyWidget::showNumber(int num)
{
    label_->setText(QString::number(num));
}

使用:

#ifndef DIALOG_H
#define DIALOG_H

#include <QDialog>

namespace Ui {
class Dialog;
}

class MyWidget;
class Dialog : public QDialog
{
    Q_OBJECT
    
public:
    explicit Dialog(QWidget *parent = 0);
    ~Dialog();
    
private slots:
    void on_pushButton_clicked();

protected:
    void resizeEvent(QResizeEvent *);

private:
    Ui::Dialog *ui;
    MyWidget *myWidget_;
};

#endif // DIALOG_H

#include "dialog.h"
#include "ui_dialog.h"
#include "mywidget.h"
#include <QtGui>

Dialog::Dialog(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::Dialog)
{
    ui->setupUi(this);

    myWidget_ = new MyWidget(this);
}

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

void Dialog::on_pushButton_clicked()
{
    static int i = 1;
    myWidget_->showNumber(i++);
}

void Dialog::resizeEvent(QResizeEvent *event)
{
    QPoint point(ui->pushButton->pos());
    QPoint newPoint = point;
    newPoint.setX(point.x() + ui->pushButton->width() - myWidget_->width());
    newPoint.setY(point.y());
    myWidget_->move(newPoint);

    QDialog::resizeEvent(event);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值