C++(QT)画图行车

通过鼠标在窗口上点击形成多个点的连线,绘制一辆汽车沿着绘制的连线轨迹前进。要求连线点数大于20.可以通过清除按钮清除已经绘制的连线,并可以重新绘制一条轨迹连线。当车辆行驶到轨迹终点时,自动停止。(汽车实在可用方块代替)

首先思考:点是可以撤销的,所以我们需要一个数据结构去记录这些点,按顺序绘制,撤销时从数据结构中删除点即可。

这样我们在按下鼠标左键时的动作就很简单了,将具体的点记录到数据结构中。

cpp 复制代码
//鼠标信号处理
void MainWindow::mousePressEvent(QMouseEvent* m)
{
    //左键点击加入点,右键点击撤销操作
    if(m->button() == Qt::LeftButton)
    {
        QPoint p = m->pos();
        m_pointArray.push_back(p);
        update();
    } else if (m->button() == Qt::RightButton) {
        m_pointArray.pop_back();
        update();
    }
}

需要一个定时器,当用户选择让小车跑起来时,动态更新小车的位置。

cpp 复制代码
void MainWindow::on_timer()
{
    car_pos ++;
}

在paintEvent中具体的绘制线路以及小车

cpp 复制代码
//绘制信号处理
void MainWindow::paintEvent(QPaintEvent *)
{
    QPainter painter(this);
    paintRoad(&painter);
    drawCar(&painter);
}

//绘制地图
void MainWindow::paintRoad(QPainter *painter)
{
    //QPainter painter(this);
    painter->setPen(QPen(Qt::blue,2, Qt::SolidLine, Qt::RoundCap));//设置画笔形式
    for(int i = 0; i < m_pointArray.count(); i ++)
    {
        if (i < 1)
        {
            continue;
        }

        painter->drawLine(m_pointArray[i-1],m_pointArray[i]);

    }
}
//绘制小车
void MainWindow::drawCar(QPainter *painter)
{
    if(m_pointArray.count() == 0)
    {
        return;
    }
    painter->setPen(QPen(Qt::red, 2, Qt::SolidLine, Qt::RoundCap));
    if (car_pos >= m_pointArray.count())
    {
        car_pos = m_pointArray.count() -1;
    }
    painter->drawRect(m_pointArray[car_pos].x() - Car_Radius,m_pointArray[car_pos].y() - Car_Radius,
                     Car_Radius*2,Car_Radius*2);
    update();
}
相关推荐
Slow菜鸟1 小时前
Java基础架构设计(三)| 通用响应与异常处理(分布式应用通用方案)
java·开发语言
消失的旧时光-19431 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript
wadesir1 小时前
Rust中的条件变量详解(使用Condvar的wait方法实现线程同步)
开发语言·算法·rust
tap.AI1 小时前
RAG系列(二)数据准备与向量索引
开发语言·人工智能
阿蒙Amon2 小时前
C#每日面试题-重写和重载的区别
开发语言·c#
是一个Bug2 小时前
Java基础20道经典面试题(二)
java·开发语言
Z_Easen2 小时前
Spring 之元编程
java·开发语言
liliangcsdn2 小时前
python下载并转存http文件链接的示例
开发语言·python
Morwit2 小时前
【力扣hot100】64. 最小路径和
c++·算法·leetcode
我命由我123452 小时前
SVG - SVG 引入(SVG 概述、SVG 基本使用、SVG 使用 CSS、SVG 使用 JavaScript、SVG 实例实操)
开发语言·前端·javascript·css·学习·ecmascript·学习方法