我将QWidget子类化如下:
class myClass : public QWidget
{
public:
explicit myClass(QWidget *parent);
protected:
void paintEvent(QPaintEvent *event);
}
myWidget::myWidget(QWidget* parent) : QWidget(parent)
{
setGeometry(10,10,100,100);
}
void myWidget::paintEvent(QPaintEvent *event)
{
QPainter qp(this);
QBrush bBlue(QColor::blue);
qp.fillRect(geometry(), bBlue);
}
我想要的是创建一个蓝色背景QWidget放置在QWidget父级的10,10,大小为100,100。
我得到的是myWidget的默认大小,例如100,50在0,0,黑色背景(或透明)和蓝色矩形,从myWidget中的10,10开始,并由myWidget剪辑。
就像setGeometry在myWidget中移动了一个矩形,而不是myWidget本身。
对Qt来说相当新,并且会喜欢上面的解释和修复......
提前谢谢。
加里。
...这是实际代码:
这是myWidget
class piTemplateWidget : public QWidget
{
public:
explicit piTemplateWidget(QWidget* parent);
static QColor* white;
static QColor* black;
static QColor* lightGrey;
static QColor* lightGreen;
piTemplate* tplt;
protected:
void paintEvent(QPaintEvent *event);
};
QColor* piTemplateWidget::white = new QColor(15,15,15);
QColor* piTemplateWidget::black = new QColor(250,250,250);
QColor* piTemplateWidget::lightGrey = new QColor(100,100,100);
QColor* piTemplateWidget::lightGreen = new QColor(250,15,250);
piTemplateWidget::piTemplateWidget(QWidget* parent) : QWidget(parent)
{
tplt = NULL;
move(100,100);
resize(300,240);
}
void piTemplateWidget::paintEvent(QPaintEvent *event)
{
QPainter qp(this);
QBrush bWhite(*white);
qp.fillRect(this->geometry(), bWhite);
// if (tplt==NULL)
// return;
// tplt->render(&qp);
}
...这是实例化我的小部件的父窗口小部件构造函数
piTemplateEdit::piTemplateEdit(QWidget *parent) :
QWidget(parent),
ui(new Ui::piTemplateEdit)
{
ui->setupUi(this);
currentTemplate = NULL;
if (piTemplate::templates->count()>0)
{
currentTemplate = (piTemplate*)piTemplate::templates->atIndex(0);
}
templateWidget = new piTemplateWidget(this);
templateWidget->tplt = currentTemplate;
}
......我希望这有帮助。
谢谢。
答案 0 :(得分:0)
在构造函数期间设置geometry
可能会被父窗口小部件调用的show
事件覆盖。
常见的主要功能如下所示:
#include <QtGui/QApplication>
#include "mainwindow.h"
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
w.show();
// w.showMaxmized(); // This line would trump the "setGeometry() call
// in the constructor
return a.exec();
}
这里描述了存储在QWidget中的几何rect:
http://qt-project.org/doc/qt-4.8/application-windows.html
http://qt-project.org/doc/qt-4.8/qwidget.html#pos-prop
我不会使用此内部QWidget
设置来填充您的小部件。如果您确实要存储某些设置,请创建一个QRect
成员变量并使用该变量。
如果你想用一种颜色填充QWidget的整个盒子,你应该尝试这样的事情:
void myWidget::paintEvent(QPaintEvent *event)
{
QPainter qp(this);
QBrush bBlue(QColor::blue);
qp.fillRect(QRect(0,0, this->width(), this->height()), bBlue);
}
内部涂料功能,它们与您所在的可涂漆区域有关。
http://qt-project.org/doc/qt-4.8/qwidget.html#mapTo
就像@LaszloPapp所说,你需要使用resize()
和move()
。在其中任何一个之后投出update()
电话都没有坏处。
另请务必查看show()
方法及其所有“另请参阅”项目。
http://qt-project.org/doc/qt-4.8/qwidget.html#show
http://qt-project.org/doc/qt-4.8/qshowevent.html
如果您#include <QShowEvent>
,并在展会活动发生时致电resize()
,您可能会很高兴。如果您将此窗口小部件嵌套在另一个窗口小部件中,则应使用大小提示和setFixedSize
或正确使用布局来查看。
http://qt-project.org/doc/qt-4.8/layout.html
希望有所帮助。