如何在Qt上自定义可滚动图像小部件

时间:2016-12-21 15:05:59

标签: c++ qt

我的自定义图片Widget可滚动有问题。

这是我的自定义图片小部件。

imagewidget.h:

#ifndef IMAGEWIDGET_H
#define IMAGEWIDGET_H

#include <QWidget>
#include <QImage>
#include <QString>
#include <QPaintEvent>
#include <QAbstractScrollArea>

class ImageWidget: public QWidget
{
public:
    explicit ImageWidget(QWidget *parent = 0);
    QImage m_Image;
    void loadImage(const QString &fileName);
protected:
    void paintEvent(QPaintEvent *event);
};

#endif // IMAGEWIDGET_H

imagewidget.cpp:

#include "imagewidget.h"
#include <QPainter>
#include <QPoint>
#include <QDebug>
#include <QScrollBar>


ImageWidget::ImageWidget(QWidget *parent): QWidget(parent)
{
}

void ImageWidget::loadImage(const QString &fileName)
{
    if(!fileName.isNull()){
        m_Image.load(fileName);
        this->update();
        qDebug()<<"Load Image"<<endl;
    }
}

void ImageWidget::paintEvent(QPaintEvent *event)
{
    QPainter p(this);
    if(!m_Image.isNull()){
        p.drawImage(QPoint(0,0),m_Image);

    }
    qDebug()<<"Paint Event"<<endl;
}

这是mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"

#include <QScrollArea>
#include <QString>
#include <QFileDialog>
#include <QWidget>
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow),
    scrollArea(new QScrollArea())
{
    ui->setupUi(this);
    m_Image = new ImageWidget(this);
    scrollArea->setWidgetResizable(true);
    scrollArea->setWidget(m_Image);
    setCentralWidget(scrollArea);
}

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

void MainWindow::on_actionOpen_triggered()
{
   QString fileName = QFileDialog::getOpenFileName(this, tr("Open Image"), "/", tr("Image Files (*.png *.jpg *.bmp *.tif *.tiff)"));

   m_Image->loadImage(fileName);
   m_Image->adjustSize();
   this->update();

}

对于大图像,图像无法使用滚动条进行显示。 我的结果如下。谢谢你的阅读。 image viewer

1 个答案:

答案 0 :(得分:1)

您忘了设置ImageWidget minimumsize。

void ImageWidget::loadImage(const QString &fileName)
    {
    if(!fileName.isNull()){
        m_Image.load(fileName);
        setMinimumSize(m_Image.size());   //add this line
        this->update();
        qDebug()<<"Load Image"<<endl;
    }
}

ScrollArea显示滚动条的大小小于内容的小部件(在本例中为ImageWidget)。您只需加载图像并将其绘制在窗口小部件上,但不能更改窗口小部件的大小。

:)我在stackoverflow上的第一个答案。