【qt】平面CAD(计算机辅助设计 )项目 上

news2025/2/23 2:37:11

CAD

  • 一.前言
  • 二.界面设计
  • 三.提升类
  • 四.接受槽函数
  • 五.实现图形action
    • 1.矩形
    • 2.椭圆
    • 3.圆形
    • 4.三角形
    • 5.梯形
    • 6.直线
    • 7.文本
  • 六.总结

一.前言

用我们上节课刚刚学过的GraphicsView架构来绘制一个可以交互的CAD项目!
效果图:
在这里插入图片描述

二.界面设计

添加2个工具栏
在这里插入图片描述
需要蔬菜的dd我!
添加action:
在这里插入图片描述

拖放界面:
在这里插入图片描述
设置一些基本的属性:
在这里插入图片描述

三.提升类

自定义一个类,继承QGraphicsView
在这里插入图片描述
找到鼠标和键盘事件.
在这里插入图片描述
添加信号和鼠标事件和键盘事件:
在这里插入图片描述
鼠标事件和键盘事件的重写,功能就是发出信号带出视图坐标:

mygraphicsview.cpp中

#include "mygraphicsview.h"
#include <QMouseEvent>

MyGraphicsView::MyGraphicsView(QWidget *parent) : QGraphicsView(parent)
{
    
}

void MyGraphicsView::keyPressEvent(QKeyEvent *event)
{
    emit keyPress(event);
    QGraphicsView::keyPressEvent(event);
}

void MyGraphicsView::mousePressEvent(QMouseEvent *event)
{
    if(event->button()==Qt::LeftButton)
    {
        QPoint point=event->pos();
        emit mousePress(point);
    }
    QGraphicsView::mousePressEvent(event);
}

void MyGraphicsView::mouseDoubleClickEvent(QMouseEvent *event)
{
    if(event->button()==Qt::LeftButton)
    {
        QPoint point=event->pos();
        emit mouseDoubleClick(point);
    }
    QGraphicsView::mouseDoubleClickEvent(event);
}

void MyGraphicsView::mouseMoveEvent(QMouseEvent *event)
{
    QPoint point=event->pos();
    emit mouseMove(point);
    QGraphicsView::mouseMoveEvent(event);
}

类提升
在这里插入图片描述

四.接受槽函数

用这个命名格式可以自动关联哦
在这里插入图片描述
想做个空实现,不然运行会报错,上面这些都是前面我们讲过的,就不细讲了,接下来进行这节课的重点.

创建场景:
在这里插入图片描述

五.实现图形action

1.矩形

void MainWindow::on_actionRect_triggered()
{
    QGraphicsRectItem*item=new QGraphicsRectItem(-100,-50,200,100);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    item->setBrush(QBrush(Qt::blue));
    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"矩形");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

在构造函数中加一个随机种子:
在这里插入图片描述
在头文件中加
在这里插入图片描述
运行结果:
在这里插入图片描述

2.椭圆

void MainWindow::on_actionEllisp_triggered()
{
    QGraphicsEllipseItem*item=new QGraphicsEllipseItem(-100,-50,200,100);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    item->setBrush(QBrush(Qt::green));
    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"椭圆");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

运行结果:
在这里插入图片描述

3.圆形

void MainWindow::on_actionCircle_triggered()
{
    QGraphicsEllipseItem*item=new QGraphicsEllipseItem(-100,-50,200,200);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    item->setBrush(QBrush(Qt::yellow));
    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"圆形");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

运行结果:
在这里插入图片描述

4.三角形

void MainWindow::on_actionSanjiao_triggered()
{
    QGraphicsPolygonItem*item=new QGraphicsPolygonItem;
    QPolygonF points;
    points.append(QPoint(0,-80));
    points.append(QPoint(-50,0));
    points.append(QPoint(50,0));
    item->setPolygon(points);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    item->setBrush(QBrush(Qt::darkRed));
    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"三角形");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

运行结果:
在这里插入图片描述

5.梯形

void MainWindow::on_actionTixing_triggered()
{
    QGraphicsPolygonItem*item=new QGraphicsPolygonItem;
    QPolygonF points;
    points.append(QPoint(-50,-50));
    points.append(QPoint(-100,100));
    points.append(QPoint(100,100));
    points.append(QPoint(50,-50));
    item->setPolygon(points);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    item->setBrush(QBrush(Qt::darkGreen));
    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"梯形");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

运行结果:
在这里插入图片描述

6.直线

void MainWindow::on_actionLine_triggered()
{
    QGraphicsLineItem*item=new QGraphicsLineItem(-100,-100,100,100);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    QPen pen;
    pen.setWidth(4);
    pen.setColor(Qt::red);
    item->setPen(pen);

    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"直线");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

运行结果:
在这里插入图片描述

7.文本

void MainWindow::on_actionText_triggered()
{
    QString str=QInputDialog::getText(this,"输入文本","请输入文本:");
    QGraphicsTextItem*item=new QGraphicsTextItem(str);
    item->setFlags(QGraphicsItem::ItemIsSelectable|
                   QGraphicsItem::ItemIsMovable|
                   QGraphicsItem::ItemIsFocusable);
    QFont font;
    font.setBold(true);
    font.setPixelSize(30);
    item->setFont(font);
    item->setDefaultTextColor(Qt::red);//设置默认文本颜色

    item->setZValue(ZVaule++);//堆叠的等级,越高越在表面,z的高度

    item->setData(ITEMID,itemID++);//可以为图形项自定义数据
    item->setData(ITEMINFO,"文本");

    item->setPos(qrand()%50,qrand()%50);//在坐标附近生成图形项

    scene->addItem(item);
    scene->clearSelection();//清空选择的
    item->setSelected(true);//添加的设置选中
}

运行结果:
在这里插入图片描述

六.总结

在这里插入图片描述

因时间有限,我们先完成一半!
图形项的添加基本一致.

  • 先创建一个图形项
  • 设置标识,可以移动
  • 设置画刷或者画笔
  • 设置堆叠等级
  • 设置数据
  • 随机设置位置
  • 创建添加图形项
  • 清空原来的选择
  • 设置现在添加的选择

一生摘叶,不知寻根!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1824517.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue 若依框架常见问题

获取当前用户id或其它信息 user.js import { login, logout, getInfo } from /api/login import { getToken, setToken, removeToken } from /utils/authconst user {state: {token: getToken(),id: ,name: ,avatar: ,roles: [],permissions: [], shop: [] // 店铺列表},mu…

Zig标准库:最全数据结构深度解析(1)

最近新闻看到17岁中专女生拿下阿里全球数学竞赛第12名。咱们学习标准库中的数据结构是和学习数学是一脉相承的&#xff0c;结构体很多&#xff0c;也非常枯燥&#xff0c;但是不能全面解读过一遍&#xff0c;你很难写出合理的代码。所以&#xff0c;这一章节我们开始深度解析Zi…

HTML静态网页成品作业(HTML+CSS)—— 校园贷主题网页(2个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有2个页面。 二、作品演示 三、代…

理解Python的元类

1.type()函数 type 函数是一个内置函数&#xff0c;用来获取一个对象的类型。它可以接受一个参数&#xff0c;返回这个参数的数据类型。type也可以用来创建类&#xff0c;type就是元类 x333 list["ab"] tuple (1, "a", True, 3.14) dict {name: Alice,…

驱动开发(四):Linux内核中断

驱动开发系列文章&#xff1a; 驱动开发&#xff08;一&#xff09;&#xff1a;驱动代码的基本框架 驱动开发&#xff08;二&#xff09;&#xff1a;创建字符设备驱动 驱动开发&#xff08;三&#xff09;&#xff1a;内核层控制硬件层 驱动开发&#xff08;四&#xf…

JDK17 你的下一个白月光

JDK版本升级的非常快&#xff0c;现在已经到JDK20了。JDK版本虽多&#xff0c;但应用最广泛的还得是JDK8&#xff0c;正所谓“他发任他发&#xff0c;我用Java8”。 但实际情况却不是这样&#xff0c;越来越多的java工程师拥抱 JDK17&#xff0c;于是了解了一下 JDK17新语法&a…

浅谈TARA在汽车网络安全中的关键角色

随着现代汽车技术的迅猛发展&#xff0c;网络安全成为汽车行业一个不可忽视的领域。为了应对日益复杂的网络威胁&#xff0c;ISO/SAE 21434标准和UN R155法规提供了系统化的网络安全管理框架。其中&#xff0c;TARA&#xff08;威胁分析与风险评估&#xff09;作为核心方法论&a…

MGRS坐标

一 概述 MGRS坐标系统&#xff0c;即军事格网参考系统&#xff0c;是北约(NATO)军事组织使用的标准坐标系统。它基于UTM&#xff08;通用横向墨卡托&#xff09;系统&#xff0c;并将每个UTM区域进一步划分为100km100km的小方块。这些方块通过两个相连的字母标识&#xff0c;其…

从GAN到WGAN(02/2)

文章目录 一、说明二、GAN中的问题2.1 难以实现纳什均衡(Nash equilibrium)2.2 低维度支撑2.3 梯度消失2.4 模式坍缩2.5 缺乏适当的评估指标 三、改进的GAN训练四、瓦瑟斯坦&#xff08;Wasserstein&#xff09;WGAN4.1 什么是 Wasserstein 距离&#xff1f;4.2 为什么 Wassers…

AI大模型应用落地:AI+任何行业都是王炸

AI大模型物流&#xff1a;顺丰案例分享&#xff1a; 顺丰集团作为物流行业的领军企业&#xff0c;如何通过新质生产力的注入&#xff0c;重塑科技驱动的物流服务。 “天网”航空资源和“地网”地面运输网络一直是顺丰的两大优势&#xff0c;而多年来&#xff0c;通过在技术方…

除了程序员,你又是谁呢?别说!保护自己能量最好的方式——早读(逆天打工人爬取热门微信文章解读)

你很困的时候&#xff0c;会不会遵循本心直接睡觉呢&#xff1f; 引言Python 代码第一篇 洞见 保护自己能量最好的方式第二篇 视频新闻结尾 引言 现在真的是越来越遵循本心了 昨天晚上10点多 觉得好困 但是又没有洗澡 然后就想着算了 躺一个 没想到一躺 早上6点了 起来速速洗刷…

Scrum Day盛大启幕【限时优惠】

关于 Scrum Day 智驭未来&#xff0c;敏捷先行 —— 2024中国Scrum大会启航 在全球数字化转型的浪潮中&#xff0c;敏捷已成为企业脱颖而出的关键。 Scrum中文网携手全球敏捷行业巨擘 —— Scrum.org 联袂呈现年度敏捷盛会 Scrum Day&#xff0c;将于今秋盛大启幕&#xff01…

通过MATLAB实现PID控制器,积分分离控制器以及滑模控制器

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 通过MATLAB实现PID控制器,积分分离控制器以及滑模控制器。通过对比三个算法可知&#xff0c;采用滑模控制算法&#xff0c;其具有最快的收敛性能&#xff0c;较强的鲁棒性&…

普通LED显示屏与柔性LED显示屏如何选择?

在数字化时代的浪潮中&#xff0c;LED显示屏作为信息展示的重要媒介&#xff0c;其市场发展迅速&#xff0c;产品种类也日益丰富。面对普通LED显示屏与柔性LED显示屏两种选择&#xff0c;消费者和企业常常陷入纠结。那么&#xff0c;究竟该如何选择呢&#xff1f;让我们来深入探…

QUIC 和 TCP: 深入解析为什么 QUIC 更胜一筹

引言 在过去的三十年里&#xff0c;HTTP&#xff08;超文本传输协议&#xff09;一直是互联网的支柱。我们可以通过 HTTP 浏览网页、下载文件、流式传输电影等。这一协议随着时间的推移已经得到了重大改进。 HTTP 协议是一个应用层协议&#xff0c;它基于 TCP&#xff08;传输…

手机IP地址距离多远会变:解析移动设备的网络定位奥秘

在移动互联网时代&#xff0c;手机IP地址扮演着至关重要的角色&#xff0c;它不仅是我们访问网络的基础&#xff0c;还常常与网络定位、地理位置服务等相关联。那么&#xff0c;手机IP地址在距离多远时会发生变化呢&#xff1f;手机IP地址距离多远会变&#xff1f;下面跟着虎观…

C# 中的日志记录技术详细解析与示例

文章目录 1. C# 日志记录的基本概念与重要性2. C# 中的日志记录主要方法使用 Console.WriteLine使用 System.Log* 类使用第三方日志库 3. 创建和配置日志记录器的基本步骤4. 不同情境下的日志记录应用示例示例 1&#xff1a;使用 Console.WriteLine示例 2&#xff1a;使用 Debu…

HTML静态网页成品作业(HTML+CSS+JS)——游戏天天酷跑网页(4个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;使用Javacsript代码实现图片切换轮播&#xff0c;共有4个页面。 二、…

【Ardiuno】使用ESP32单片机网络功能调用API接口(图文)

接着上文连通wifi后&#xff0c;我们通过使用HTTPClient库进行网络相关操作&#xff0c;这里我们通过http协议进行接口调用。 为了简化操作&#xff0c;小飞鱼这里使用了本地服务器上的文件作为接口&#xff0c;正常操作时会调用接口后&#xff0c;将服务器返回的数据进行解析…

AI办公自动化:批量在多个Word文档中插入对应图片

工作任务&#xff1a;文件夹中有多个word文档和word文档名称一致的图片&#xff0c;要把这些图片都插入到word文档中 在chatpgt中输入提示词&#xff1a; 你是一个Python编程专家&#xff0c;写一个Python脚本&#xff0c;具体步骤如下&#xff1a; 打开文件夹&#xff1a;F:…