Qt中隐藏滚动条重新实现鼠标滚轮事件wheelEvent

本文介绍如何在Qt中隐藏QListWidget的滚动条并利用鼠标滚轮事件移动控件。通过QListWidget实现横排布局,当窗口不足以显示所有控件时,使用滚轮滚动查看隐藏部分。同时探讨了滚轮事件的处理,以及滚轮转动与界面单位尺度的关系。
摘要由CSDN通过智能技术生成

我的需求是实现一系列控件横排排列,隐藏滚动条,然后通过鼠标的滚轮的移动控件的位置。当窗口大小足以容纳所有控件时不响应滚轮事件,窗口缩小时可以通过鼠标的滚轮来把隐藏的控件移到视线中来。如图所示:


最开始用的是QScrollarea,但是总不能实现出我想要的布局,没有能自适应窗口大小,所以采用了一个变通的方法:通过QListwidget控件来实现,感觉这样操作起来比较方便,而且可以方便的添加控件。 (下面更新了采用QScrollarea的方法)

首先是隐藏QListwidget的滚动条,并且让QLIstwidget中的控件横排排列:

    ui->listWidget->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff); //隐藏水平方向和垂直方向的滚动条
    ui->listWidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
    ui->listWidget->setFlow(QListWidget::LeftToRight); //横排排列
    ui->listWidget->setSpacing(10);

QListwidget设置控

Qt,如果你想要隐藏QScrollArea(包含滚动条的容器)的滚动条,并利用触摸屏幕实现滑动滚动,可以采取以下步骤: 1. **创建QScrollArea**:首先,创建一个`QScrollArea`实例并设置其内容布局。 ```cpp QScrollArea scrollArea; scrollArea.setWidget(widgetToScroll); // 将需要滚动的内容添加到scrollArea ``` 2. **启用垂直/水平滚动**:通过`setHorizontalScrollBarPolicy()`和`setVerticalScrollBarPolicy()`方法,设定滚动政策来控制是否显示滚动条。例如,如果希望禁用滚动条,你可以设置为`Q.ScrollBarAlwaysOff`。 ```cpp scrollArea.setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); scrollArea.setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff); ``` 3. **处理触摸事件**:对于触摸屏幕的滚动,你需要在窗口上注册一个鼠标或触控事件处理器,如`QGestureEventFilter`,并监听`QEvent::Gesture`类型的事件。当检测到适当的触摸手势(如平移)时,手动更新内容的滚动位置。 ```cpp QGestureEventFilter gestureFilter(this); gesturesFilter.acceptGesture = [this](const QTouchEvent &event) { if (event.type() == QEvent::Gesture && event.isAccepted()) { handleGesture(event); } }; // ... 在适当的地方添加手势处理函数 handleGesture() ``` 4. **滚动处理函数**:在`handleGesture()`函数,根据触摸的方向和范围调整内容区域的位置。 ```cpp void handleGesture(const QTouchEvent &event) { if (event.gesture().type() == QGesture::Pan) { const QPointF delta = event.posF() - event.prevPosF(); int scrollDelta = qRound(delta.x()); // 或者 delta.y(),取决于你是横向还是纵向滚动 // 更新内容的可视部分 QRect visibleRect = scrollArea.viewport()->rect(); scrollArea.scrollTo(visibleRect.topLeft() + QPoint(scrollDelta, 0)); } } ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值