Qt 之图形(简笔画-绘制卡通蚂蚁)

2024-05-27 19:38

本文主要是介绍Qt 之图形(简笔画-绘制卡通蚂蚁),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者: 一去、二三里
个人微信号: iwaleon
微信公众号: 高效程序员

关于简笔画的介绍很多,有动物、水果、蔬菜、交通工具等,通常会对绘制一步步进行拆分、组合。然后绘制为我们想要的结果。

下面来介绍另外的一个种类:昆虫类-卡通蚂蚁。

绘制

效果

具体的效果如下所示,我们可以再进行更好的完善。

这里写图片描述

源码

主要分为以下三部:

  • 绘制屁股
  • 绘制肚子
  • 绘制头部

注意:绘制的时候,由于各个部分的颜色不同,而且坐标不好定位,所以我们采用的图形覆盖的方式。

void MainWindow::paintEvent(QPaintEvent *)
{QPainter painter(this);painter.setRenderHint(QPainter :: Antialiasing, true);/*****屁股*****/QPainterPath path;path.addRoundRect(QRect(200, 60, 150, 150), 1000);painter.setBrush(Qt::white);painter.setPen(Qt::black);painter.drawPath(path);/*****肚子*****/// 腿path = QPainterPath();path.moveTo(170, 180);path.lineTo(120, 260);path.moveTo(185, 180);path.lineTo(145, 280);path.moveTo(200, 180);path.lineTo(180, 290);path.moveTo(200, 180);path.lineTo(220, 290);path.moveTo(215, 180);path.lineTo(250, 280);path.moveTo(230, 180);path.lineTo(280, 260);painter.setBrush(Qt::NoBrush);painter.setPen(Qt::white);painter.drawPath(path);// 肚子path = QPainterPath();path.addRoundRect(QRect(150, 130, 100, 100), 1000);painter.setBrush(Qt::white);painter.setPen(Qt::black);painter.drawPath(path);/*****头*****/// 犄角path = QPainterPath();path.moveTo(80, 100);path.lineTo(60, 20);path.moveTo(140, 100);path.lineTo(160, 20);painter.setBrush(Qt::NoBrush);painter.setPen(Qt::white);painter.drawPath(path);path = QPainterPath();path.addRoundRect(QRect(50, 80, 120, 120), 1000);painter.setBrush(Qt::white);painter.setPen(Qt::black);painter.drawPath(path);// 左眼path = QPainterPath();path.addRoundRect(QRect(70, 120, 25, 25), 1000);painter.setBrush(Qt::black);painter.setPen(Qt::NoPen);painter.drawPath(path);path = QPainterPath();path.addRoundRect(QRect(75, 126, 10, 10), 1000);painter.setBrush(Qt::white);painter.setPen(Qt::NoPen);painter.drawPath(path);// 右眼path = QPainterPath();path.addRoundRect(QRect(120, 110, 25, 25), 1000);painter.setBrush(Qt::black);painter.setPen(Qt::NoPen);painter.drawPath(path);path = QPainterPath();path.addRoundRect(QRect(125, 118, 10, 10), 1000);painter.setBrush(Qt::white);painter.setPen(Qt::NoPen);painter.drawPath(path);// 嘴path = QPainterPath();path.moveTo(160, 108);path.arcTo(QRect(130, 48, 60, 60), 270, 100);painter.rotate(30);painter.setBrush(Qt::NoBrush);painter.setPen(Qt::black);painter.drawPath(path);
}

对于一般图形的绘制比较简单,因为常用、有规律,而且比较规则,像圆、椭圆、矩形、直线这些。如果存在各种复杂的图形那么用原生的绘制方案就很难实现了,需要消耗大量的时间来回折腾,所以这里就不再介绍了。

这篇关于Qt 之图形(简笔画-绘制卡通蚂蚁)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1008405

相关文章

以canvas方式绘制粒子背景效果,感觉还可以

这个是看到项目中别人写好的,感觉这种写法效果还可以,就存留记录下 就是这种的背景效果。如果想改背景颜色可以通过canvas.js文件中的fillStyle值改。 附上demo下载地址。 https://download.csdn.net/download/u012138137/11249872

Android SurfaceFlinger——图形内存分配器(十一)

前面的文章中的图层合成器(HWC),这里我们接着看一下 SurfaceFlinger 中的另一个重要服务——图形内存分配器。 一、简介         android.hardware.graphics.allocator@2.0 是 Android 系统中硬件抽象层(HAL)的一个组件,专门用于图形内存的分配和管理。它是 SurfaceFlinger 在处理图形数据时所依赖的

QT 中ListView和ListWidget有什么区别

ListView和ListWidget在Qt框架中都是用于显示列表数据的控件,但它们在使用方法和特性上存在一些明显的差异。以下是关于它们用法不一样的地方的详细分析: 数据管理方式: ListView:使用QAbstractItemModel数据模型来管理和显示列表数据。QAbstractItemModel是一个抽象类,允许开发者自定义数据模型以适应特定的数据结构和需求。这使得ListView在处

XMG 绘制形状

1. 除非是绘制曲线直接使用原生的。如果绘制形状直接使用UIBezerPath  2. 命名原则,类方法以类名开头 UIBezierPath bezierPathWithRect 3.圆角半径 画圆的大小 以每个顶点为圆心。给定的半径为半径画一个1/4圆。把周边的给切掉 4.只有封闭的形状调用这个方法才有用 [path fill] 5. stroke 描边一下

图形编辑器基于Paper.js教程03:认识Paper.js中的所有类

先来认一下Paper的资源对象,小弟有哪些,有个整体的认识。认个脸。 在Paper.js的 官方文档中类大致有如下这些: 基类: ProjectViewItemPointToolSizeSegmentRectangleCurveCurveLocationMatrixColorStyleTweenToolEventGradientGradientStopEvent 二级或三级类 继承Ite

如何使用Qt的PIMPL习惯用法(PIMPL Idiom

) PIMPL是指“Pointer to IMPLementation”(指向实现的指针),意味着将实现细节隐藏起来,用户类无需关注这些实现细节。在Qt中常用PIMPL习惯用法来清晰地区分接口与实现,尽管Qt官方文档并未详细说明该机制。本文将演示如何在Qt中使用PIMPL习惯用法,并以一个简单的坐标输入对话框作为实例。 原理与动机 PIMPL的核心在于将类的实现细节封装在一个私有类中,这个私

【Qt6.3 基础教程 17】 Qt布局管理详解:创建直观和响应式UI界面

文章目录 前言布局管理的基础为什么需要布局管理器? 盒布局:水平和垂直排列小部件示例:创建水平盒布局 栅格布局:在网格中对齐小部件示例:创建栅格布局 表单布局:为表单创建标签和字段示例:创建表单布局 调整空间和伸缩性示例:增加弹性空间 总结 前言 当您开始使用Qt设计用户界面(UI)时,理解布局管理是至关重要的。布局管理不仅关系到UI的外观,更直接影响用户交互的体验。本篇博

【Qt6.3 基础教程 16】 掌握Qt中的时间和日期:QTimer和QDateTime的高效应用

文章目录 前言QTimer:定时任务的强大工具QTimer的基本用法高级特性:单次定时器 QDateTime:处理日期和时间获取当前日期和时间日期和时间的格式化输出日期和时间计算 用例:创建一个倒计时应用结论 前言 在开发桌面应用程序时,处理时间和日期是一个常见且重要的任务。Qt框架提供了强大的工具来处理与时间相关的功能,其中QTimer和QDateTime是最核心的类。本

基于ZYNQ7000的交叉编译工具链Qt+OpenCV+ffmpeg等库支持总结

最近刚刚接触XILINX的ZYNQ板,刚接触没有十天。XILINX定位它为SOC,我也很认同,起码比TI定位MPU为SOC强很多。据说今年TI的最新产品也加入了ZYNQ板。 之前的MIPS处理器设计与实现的项目就算做告一段落,搞了将近7个月,成果显著,收获颇多,最近打算搞搞ZYNQ。 之前MIPS也有一套交叉编译工具,不过是老师提供的,自己也尝试搞了搞,太辛苦了,而且也没什么成果,因为我

Qt 5.2.0 qwt-6.1.0

环境:win7(32) qt-5.2.0 qwt-6.1.0(qt-6.1.0说支持qt5以上的版本,但是我在配置前没找到最新的qt-5.2.0与qwt-6.1.0,其实步骤的差不多,暂时没发现版本引起的问题) 一.添加环境变量(在cmd测试下qmake,如果有问题重启电脑):  Add "C:\Qt\Qt5.0.1\5.0.1\mingw47_32\bin" to your systems