QT开发中文网

鼠标移动画布时候 总感觉移动不平稳 有抖动, 如何解决

鼠标移动时的抖动通常与以下几个因素有关:

  1. 鼠标事件处理:确保在mouseMoveEvent中,只有在拖动状态下才更新滚动条。
  2. 双缓冲:在绘制过程中使用双缓冲技术,以避免闪烁。
  3. 平滑滚动:可以考虑引入定时器来平滑鼠标移动。

下面是改进后的代码示例,主要集中在使得滚动更加平稳和减少抖动感:

#include <QApplication>
#include <QMainWindow>
#include <QScrollArea>
#include <QFrame>
#include <QVBoxLayout>
#include <QPainter>
#include <QMouseEvent>

class CanvasFrame : public QFrame {
    Q_OBJECT

public:
    CanvasFrame(QWidget *parent = nullptr) : QFrame(parent) {
        setMinimumSize(500, 500);
        setMouseTracking(true); // 启用鼠标跟踪
        dragging = false; // 初始状态为未拖拽
    }

protected:
    void paintEvent(QPaintEvent *event) override {
        Q_UNUSED(event);
        
        QPainter painter(this);
        
        // 设置线条颜色和宽度
        painter.setPen(QPen(Qt::gray, 1));

        int gridSize = 100;
        
        // 绘制横向网格线
        for (int i = 0; i <= height(); i += gridSize) {
            painter.drawLine(0, i, width(), i);
        }
        
        // 绘制纵向网格线
        for (int j = 0; j <= width(); j += gridSize) {
            painter.drawLine(j, 0, j, height());
        }
    }

    void mousePressEvent(QMouseEvent *event) override {
        if (event->button() == Qt::LeftButton) {
            lastMousePos = event->pos();
            dragging = true;
            setCursor(Qt::ClosedHandCursor); // 更换光标为抓手形状
        }
    }

    void mouseMoveEvent(QMouseEvent *event) override {
        if (dragging && event->buttons() & Qt::LeftButton) { 
            int dx = event->pos().x() - lastMousePos.x();
            int dy = event->pos().y() - lastMousePos.y();
            
            horizontalScrollBar()->setValue(horizontalScrollBar()->value() - dx);
            verticalScrollBar()->setValue(verticalScrollBar()->value() - dy);

            lastMousePos = event->pos(); // 更新位置到当前鼠标位置
         }
    }

    void mouseReleaseEvent(QMouseEvent *event) override {
        if (event->button() == Qt::LeftButton) {
            dragging = false;
            unsetCursor(); // 恢复光标
         }
     }

private:
    QPoint lastMousePos;
    bool dragging;
};

class MainWindow : public QMainWindow {
public:
    MainWindow(QWidget *parent = nullptr)
      : QMainWindow(parent)
    {
       setWindowTitle("Grid Example");
       resize(800, 600);

       auto layout = new QVBoxLayout;

       auto leftFrame = new QFrame(this);
       leftFrame->setFixedWidth(200);
       leftFrame->setStyleSheet("background-color: green;");

       auto scrollArea = new QScrollArea(this);
       auto canvas = new CanvasFrame(scrollArea);

       scrollArea->setWidget(canvas);
       scrollArea->setWidgetResizable(true);

       layout->addWidget(leftFrame);
       layout->addWidget(scrollArea);

       QWidget *centralWidget = new QWidget(this);
       centralWidget->setLayout(layout);
       setCentralWidget(centralWidget);
   }
};

int main(int argc, char *argv[]) {
   QApplication a(argc, argv);
   MainWindow w;
   w.show();
   return a.exec();
}

改进点:

  1. 添加光标变化:当按住鼠标左键进行拖拽时,将光标更改为手形,以提供更好的用户体验。
  2. 去掉不必要的事件处理逻辑:仅当正在拖拽(draggingtrue)且按钮仍然按下时才会处理移动事件。

通过以上修改,应该能提升画布滚动的稳定性和流畅度。如果你还有其他需求或者问题,请随时告诉我!


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://qt.0voice.com/?id=13064

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?