我试图通过添加一个按钮来修改fridge magnets example,该按钮将重新加载绘制可拖动标签的窗口小部件,以反映对其读取的文本文件所做的任何更改。我定义了另一个包含按钮和DragWidget对象的类,因此在main()中将有一个此类的实例,而不是DragWidget:
class wrapWidget: public QWidget
{
Q_OBJECT
public:
wrapWidget();
};
wrapWidget::wrapWidget()
{
QGridLayout *gridlayout = new QGridLayout();
DragWidget *w = new DragWidget();
QPushButton *b = new QPushButton("refresh");
gridlayout ->addWidget(w,0,0);
gridlayout ->addWidget(b,1,0);
setLayout(gridlayout );
connect(b,SIGNAL(clicked()),w,SLOT(draw()));
}
我要尝试进行连接的地方是连接呼叫。在原始的冰箱磁铁示例中,所有标签绘图代码都在DragWidget类的构造函数中。我将该代码移到了一个名为“ draw()”的公共方法中,并从构造函数中调用了该方法。这是DragWidget的定义和实现:
#include <QWidget>
QT_BEGIN_NAMESPACE
class QDragEnterEvent;
class QDropEvent;
QT_END_NAMESPACE
class DragWidget : public QWidget
{
public:
DragWidget(QWidget *parent = 0);
public slots:
void draw();
protected:
void dragEnterEvent(QDragEnterEvent *event);
void dragMoveEvent(QDragMoveEvent *event);
void dropEvent(QDropEvent *event);
void mousePressEvent(QMouseEvent *event);
void paintEvent(QPaintEvent *event);
};
DragWidget::DragWidget(QWidget *parent)
: QWidget(parent)
{
draw();
QPalette newPalette = palette();
newPalette.setColor(QPalette::Window, Qt::white);
setPalette(newPalette);
setMinimumSize(400, 100);//qMax(200, y));
setWindowTitle(tr("Fridge Magnets"));
setAcceptDrops(true);
}
void DragWidget::draw(){
QFile dictionaryFile(":/dictionary/words.txt");
dictionaryFile.open(QFile::ReadOnly);
QTextStream inputStream(&dictionaryFile);
int x = 5;
int y = 5;
while (!inputStream.atEnd()) {
QString word;
inputStream >> word;
if (!word.isEmpty()) {
DragLabel *wordLabel = new DragLabel(word, this);
wordLabel->move(x, y);
wordLabel->show();
wordLabel->setAttribute(Qt::WA_DeleteOnClose);
x += wordLabel->width() + 2;
if (x >= 245) {
x = 5;
y += wordLabel->height() + 2;
}
}
}
}
我认为也许将draw()作为插槽调用就足以重新加载标签,但是没有用。将draw()调用放在小部件的重写的paintEvent()而不是构造函数中的效果也不理想,该程序最终将陷入无限循环。
我所做的显然不是正确的方法,那么我应该怎么做呢?
最佳答案
我的快速猜测是,您尚未将Q_OBJECT宏添加到dragwidget.h标头中,未生成DragWidget类的moc文件,并且连接失败并显示“没有诸如draw()这样的插槽”错误。
将“ CONFIG + = console”添加到.pro文件可能也是一个好主意-您会看到所有警告消息(如关于连接错误的警告消息),因此跟踪此类错误会更容易。您可能还会检查connect的返回值。