给QWidget添加QScrollBar滚动条

本文档介绍了一位开发者如何在Qt环境中,为避免QScrollArea的复杂性,选择自定义一个继承自QWidget的子类来实现滚动条功能。通过重载resizeEvent函数和添加信号槽,实现了QScrollBar的显示、隐藏及位置控制,以适应大图像显示需求。
摘要由CSDN通过智能技术生成

最近公司项目要用到滚动条,而且要性能非常好,因为图像可能非常大,widget的面积可能几万像素,看了QScrollArea、QAbstractScrollArea设计,太过复杂,

而QListView QTableView QTableWidget等直接或间接继承QAbstractScrollArea,其他很多控件类也直接或间接继承QAbstractScrollArea,

为了摆脱QScrollArea的viewport和其分离的设计,以使用Windows下GDI开发,我决定自己写一个继承自qwidget的子类带QScrollBar,在代码里面控制其位置和显示隐藏特性

自己的widget重载了resizeEvent函数,添加scrollbar的信号槽,上代码:

//CWidget.h
#include <QtWidgets/QMainWindow>
#include <QScrollBar>
#include <QAbstractSlider>
#include <QResizeEvent>

class CWidget : public QWidget
{
    Q_OBJECT

public:
    CWidget(QWidget* parent = 0);
    ~CWidget();

private:
    QScrollBar* vscrollbar;
    QScrollBar* hscrollbar;

private slots:
    void valueChangedScrollBar(int value);
protected:
    void resizeEvent(QResizeEvent* event);
};

 

//CWidget.cpp


CWidget::CWidget(QWidget* parent)
    : QWidget(parent)
{
        vscrollbar = new QScrollBar(Qt::Vertical, this);
        vscrollbar->setRange(0, 100);

        hscrollbar = new QScrollBar(Qt::Horizontal, this);
        hscrollbar->setRange(0, 100);

    connect(vscrollbar, SIGNAL(valueChanged(int)), this, SLOT(valueChangedScrollBar(int)));
}

void CWidget::valueChangedScrollBar(int value)
{
    //滚动位置value,通过控制显示图像内容
}

void CWidget::resizeEvent(QResizeEvent* e)
{
    QSize qsize = e->size();
    QSize qsize = e->size();
    //滚动条宽高都为20
    vscrollbar->setGeometry(qsize.width() - 20, 0, 20, qsize.height() - 20);
    hscrollbar->setGeometry(0, qsize.height() - 20, qsize.width() - 20, 20);
}

CWidget::~CWidget()
{

}


//看效果图

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值