如图所示,拉伸移动对话框,数字所示的控件位置都保持在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);
}