ZBLOG

要c++实现

下面是一个使用 C++ 和 Qt 框架实现的示例,演示如何在 QGraphicsView 中移动图片,并与水平滚动条(QScrollBar)限制结合。

示例代码

#include <QApplication>
#include <QMainWindow>
#include <QGraphicsView>
#include <QGraphicsScene>
#include <QGraphicsPixmapItem>
#include <QSlider>
#include <QVBoxLayout>
#include <QWidget>

class ImageMover : public QMainWindow {
    Q_OBJECT

public:
    ImageMover() {
        setWindowTitle("Image Mover with Scrollbar");
        setGeometry(100, 100, 600, 500);

        // 创建场景和视图
        scene = new QGraphicsScene(this);
        view = new QGraphicsView(scene);

        // 加载图像并添加到场景中
        pixmapItem = new QGraphicsPixmapItem(QPixmap("your-image-url.jpg"));
        scene->addItem(pixmapItem);

        // 设置视图属性
        view->setRenderHint(QPainter::Antialiasing);

        // 创建滚动条
        scrollbar = new QSlider(Qt::Horizontal);
        scrollbar->setMinimum(-300);  // 根据需要设置最小值
        scrollbar->setMaximum(0);      // 根据需要设置最大值
        connect(scrollbar, &QSlider::valueChanged, this, &ImageMover::updateImagePosition);

        // 布局设置
        QVBoxLayout *layout = new QVBoxLayout();
        layout->addWidget(view);
        layout->addWidget(scrollbar);

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

protected:
    void mousePressEvent(QMouseEvent *event) override {
            if (event->button() == Qt::LeftButton) {
                QPointF scenePos = view->mapToScene(event->pos());
                if (pixmapItem->isUnderMouse()) {
                    offsetX = scenePos.x() - pixmapItem->x();
                    offsetY = scenePos.y() - pixmapItem->y();

                    dragging = true;
                }
            }
            event->accept();
    }

    void mouseMoveEvent(QMouseEvent *event) override {
            if (dragging) {
                QPointF newScenePos = view->mapToScene(event->pos());
                qreal newX = newScenePos.x() - offsetX;
                qreal newY = newScenePos.y() - offsetY;

                // 更新图片位置,限制在滚动条范围内
                qreal limitedX = std::max(newX, -300.0);  // 最小限制为-300,根据你的需求调整 
                limitedX = std::min(limitedX, 0.0);       // 最大限制为0

                pixmapItem->setPos(limitedX, newY);
            }
            event->accept();
    }

    void mouseReleaseEvent(QMouseEvent *event) override {
            if (event->button() == Qt::LeftButton) {
                 dragging = false;   
             }
             event-accept();   
     }

private slots:
    void updateImagePosition() {
         qreal value = scrollbar.value();
         pixmapItem-setX(value);
     }

private:
   QGraphicsView *view;
   QGraphicsScene *scene;
   QGraphicsPixmapItem *pixmapItem;
   QSlider *scrollbar;

   bool dragging{false};
   qreal offsetX{0}, offsetY{0};
};

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);
    
    ImageMover window;
    window.show();

    return app.exec();
}

#include "main.moc"

编译与运行

  1. 安装 Qt:确保你已经安装了 Qt 开发环境,可以从 Qt 官方网站 下载。

  2. 创建项目

    • 使用 Qt Creator 创建一个新的 Qt Widgets Application。
  3. 修改主源文件

    • 将上面的代码粘贴到项目的主源文件中,比如 main.cpp
  4. 替换图像路径

    • "your-image-url.jpg" 替换为实际的图像路径。
  5. 构建和运行

    • 使用 Qt Creator 构建并运行项目。你将看到一个窗口,其中可以通过鼠标拖拽来移动图片,同时可以使用滑块来控制图片的位置。

注意事项:

  • 确保你的项目包含 QT += widgets.pro 文件中。
  • 调整滚动条的最大和最小值,以适应你的需求。
  • 如果有其他功能需求或者问题,请随时问我!


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

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

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

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

联系我们

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

微信号:3007537140

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

关注我们
x

注册

已经有帐号?