qt波位图

news2024/11/15 1:56:16

在这里插入图片描述
1,QPainter 绘制,先绘制这一堆蓝色的东西,
2,在用定时器:QTimer,配合绘制棕色的圆。用到取余,取整

#pragma once

#include <QWidget>
#include <QPaintEvent>

#include <QTimer>

QT_BEGIN_NAMESPACE
namespace Ui { class RadarSearchBeam; };
QT_END_NAMESPACE

class RadarSearchBeam : public QWidget
{
	Q_OBJECT

public:
	RadarSearchBeam(QWidget *parent = nullptr);
	~RadarSearchBeam();
  //绘图事件
	void paintEvent(QPaintEvent* event);
   //画横着一排圆圈
	void drawARow(QPainter &painter, QPointF center,int width, int height);
	//画竖着的几排
	void drawAColumn(QPainter& painter, QPointF center, int width, int height);
	.//把上面两个方法封装了
	void drawSearchBeam(QPainter& painter, QPointF center, int width,int height);
	//画棕色的圆圈
	void drawAbearColorCircle(QPainter& painter, QPointF center, int width, int height);

private:
	Ui::RadarSearchBeam *ui;
	int R = 10;
	int diameter = 2 * R;
	QTimer* timer;  //定时器
	int timer_count;//定时器计数
};

cpp文件

#include "RadarSearchBeam.h"
#include "ui_RadarSearchBeam.h"
#include<QPainter>
#include<QDebug>
RadarSearchBeam::RadarSearchBeam(QWidget *parent)
	: QWidget(parent)
	, ui(new Ui::RadarSearchBeam())
{
	ui->setupUi(this);

	//使用定时器
    timer_count = 0;
    timer = new QTimer(this);
    connect(timer, &QTimer::timeout, [=] {
        timer_count++;
        qDebug() << timer_count << "dfddd";
        });
    timer->start(100);
}
RadarSearchBeam::~RadarSearchBeam()
{
	delete ui;
}
void RadarSearchBeam::paintEvent(QPaintEvent* event)
{
    Q_UNUSED(event);

    QPainter painter(this);
    // 设置画笔颜色
    painter.setPen(QColor(0, 160, 230));
 	//把坐标原点移动到正中间
    painter.translate(width()/2,height()/2);
    drawSearchBeam(painter, QPointF(0,0),200,200);
    drawAbearColorCircle(painter, QPointF(0, 0), 200, 200);
}
void RadarSearchBeam::drawSearchBeam(QPainter& painter, QPointF center, int width, int height)
{
	 	//把坐标原点(正中间)移动到矩形左上角
    painter.translate(center.x() - width / 2, center.y() - height / 2);
    //把所有蓝色圆圈画完
    drawARow(painter, QPointF(0,0),width, height);
    drawAColumn(painter, QPointF(0, 0), width, height);
}
//配合定时器画移动的棕色圆圈
void RadarSearchBeam::drawAbearColorCircle(QPainter& painter, QPointF center, int width, int height)
{
   //一排几个圆=宽/直径
    int row_circle_num = width / diameter;
  //一竖几个圆=高/直径
    int column_circle_num = height / diameter;
    //总共多少个圆
    int all_circle_um = row_circle_num * column_circle_num;
    
    //这两个是配合定时器用
    int move_distance_x = diameter;
    int move_distance_y = diameter;
    //计时数小于圆圈数
    if (timer_count < all_circle_um)
    {
        int current_column_num = timer_count % row_circle_num;;
        int current_row_num = timer_count / row_circle_num;
		画棕色的圆圈
        painter.setPen(QColor(185, 122, 87));
        painter.drawEllipse(QPoint(center.x() + move_distance_x*current_column_num, center.y()+ current_row_num* move_distance_y), R, R);
        //刷新绘图事件
        update();
    }
    else
    {
    //  //计时数大于圆圈数,把计时数清零,从新计数
        timer_count = 0;
        update();
    }
 }
  
//画一排
void RadarSearchBeam::drawARow(QPainter& painter, QPointF center,int width, int height)
{
    //一排
    int row_num = width /diameter;
    for (int i = 0; i < row_num; i++)
    {
        painter.drawEllipse(QPoint(center.x()+i*diameter, center.y()), R, R);
    }
}

//竖着画几排
void RadarSearchBeam::drawAColumn(QPainter& painter,QPointF center, int width, int height)
{
    int num = height / diameter;
    for (int i = 0; i < num; i++)
    {
        drawARow(painter, QPointF(center.x(), center.y()+ i* diameter), width, height);
        qDebug() << QPointF(center.x(), center.y() + i * diameter);
    }
}

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

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

相关文章

基于Docker和Springboot两种方式安装与部署Camunda流程引擎

文章目录 前言1、Docker安装1.1、拉取Camunda BPM镜像1.2、编写docker启动camunda容器脚本1.3、docker启动脚本1.4、访问验证 2、SpringBoot启动2.1、下载地址2.2、创建SpringBoot项目并配置基础信息2.3、下载SpringBoot项目并在idea中打开2.4、pom修改2.5、application.yml配置…

神经网络系列---感知机(Neuron)

文章目录 感知机(Neuron)感知机(Neuron)的决策函数可以表示为&#xff1a;感知机(Neuron)的学习算法主要包括以下步骤&#xff1a;感知机可以实现逻辑运算中的AND、OR、NOT和异或(XOR)运算。 感知机(Neuron) 感知机(Neuron)是一种简单而有效的二分类算法&#xff0c;用于将输入…

pclpy Ransac平面分割算法输出的索引从点云中提取点云的子集

pclpy Ransac平面分割算法输出的索引从点云中提取点云的子集 一、算法原理二、代码三、结果1.sor统计滤波2.Ransac内点分割平面3.Ransac外点分割平面 四、相关数据 一、算法原理 1、Ransac介绍 RANSAC(RAndom SAmple Consensus,随机采样一致)算法是从一组含有“外点”(outlier…

第6.3章:StarRocks查询加速——Bucket Shuffle Join

目录 一、StarRocks数据划分 1.1 分区 1.2 分桶 二、Bucket Shuffle Join实现原理 2.1 Bucket Shuffle Join概述 2.2 Bucket Shuffle Join工作原理 2.3 Bucket Shuffle Join规划规则 三、应用案例 注&#xff1a;本篇文章阐述的是StarRocks-3.2版本的Bucket Shuffle Jo…

计网 - 深入理解HTTPS:加密技术的背后

文章目录 Pre发展历史Http VS HttpsHTTPS 解决了 HTTP 的哪些问题HTTPS是如何解决上述三个风险的混合加密摘要算法 数字签名数字证书 Pre PKI - 数字签名与数字证书 PKI - 借助Nginx 实现Https 服务端单向认证、服务端客户端双向认证 发展历史 HTTP&#xff08;超文本传输协…

DAY30--learning English

一、积累 1.budget 2.fabulous 3.strait 4.jut 5.grater 6.fillet 7.fin 8.decay 9.cartilage 10.gill 11.convex 12.concave 13.tender 14.trim 15.workload 16.knuckle 17.crevice 18.skew 19.membrane 20.delicate 二、练习 1.牛津原译 Budget /ˈbʌdʒɪt/ 1.[ CU]the…

HarmonyOS创建一个ArkTS卡片

创建一个ArkTS卡片 在已有的应用工程中&#xff0c;创建ArkTS卡片&#xff0c;具体操作方式如下。 创建卡片。 根据实际业务场景&#xff0c;选择一个卡片模板。 在选择卡片的开发语言类型&#xff08;Language&#xff09;时&#xff0c;选择ArkTS选项&#xff0c;然后单…

UI设计中,2D、2.5D、3D、4D该如何辨别?教会你

hello&#xff0c;我是大千UI工场&#xff0c;从事UI设计8年之久&#xff0c;在日常工作中经常听到一些概念&#xff0c;现在将这些概念图文并茂的呈现给您&#xff0c;欢迎点赞评论&#xff0c;如有设计需求&#xff0c;可以私信我们。 在UI设计中&#xff0c;2D、2.5D、3D和4…

Android RecyclerView 如何展示自定义列表 Kotlin

Android RecyclerView 如何展示自定义列表 Kotlin 一、前提 有这么一个对象 class DeviceDemo (val name: String, val type: String, val address: String)要展示一个包含这个对象的列表 bluetoothDevices.add(DeviceDemo("bb 9800", "LE", "32:…

旋转齿轮加载

效果演示 实现了一个旋转齿轮的动画效果。具体来说&#xff0c;页面背景为深灰色&#xff0c;中间有一个齿轮装置&#xff0c;包括四个齿轮。每个齿轮都有内部的齿轮条&#xff0c;整体呈现出旋转的效果。其中&#xff0c;齿轮2是顺时针旋转的&#xff0c;齿轮1、3、4是逆时针旋…

安卓OpenGL添加水印并录制(二)---抖音录制原理

文章目录 前文回顾音频处理留个小思考总结 本文首发地址 https://h89.cn/archives/146.html 最新更新地址 https://gitee.com/chenjim/chenjimblog 源码地址: Gitee: OpenGLRecorder 通过 前文 我们知道了如何采集 Camera 视频&#xff0c;叠加水印、贴纸保存为MP4&#xff0c;…

JavaScript+PHP实现视频文件分片上传

摘要 视频文件分片上传&#xff0c;整体思路是利用JavaScript将文件切片&#xff0c;然后循环调用上传接口 upload.php 将切片上传到服务器。这样将由原来的一个大文件上传变为多个小文件同时上传&#xff0c;节省了上传时间&#xff0c;这就是文件分片上传的其中一个好处。 上…

从故宫修建看「软件物料清单」的重要性 @安全历史01

故宫&#xff0c;这座中国传统文化的重要代表和象征性建筑已屹立近600年&#xff0c;是世界上现存规模最大、保存最为完整的木质结构古建筑之一。 故宫之所以能至今保存完好&#xff0c;除持续保护和修缮外&#xff0c;其使用的木材和砖石等材料也经过了精挑细选&#xff0c;保…

C++基础学习——哈希表的封装

目录 ​编辑 一&#xff0c;实现一个可封装的哈希表 1&#xff0c;哈希表的节点 2&#xff0c;哈希表的成员 3&#xff0c;哈希表成员方法的实现 4&#xff0c;迭代器的实现 5&#xff0c;在哈希表中加入迭代器 二&#xff0c;封装哈希表 1&#xff0c;unorder_map封装 2…

吴恩达deeplearning.ai:矩阵运算代码实战

神经网络向量化指的是将输入数据转化为向量形式&#xff0c;以便于神经网络的处理。向量化的作用包括以下几点&#xff1a; 提高计算效率&#xff1a;使用向量化的输入数据可以进行并行计算&#xff0c;加速神经网络的训练和推断过程。 减少存储空间&#xff1a;向量化可以将…

一种确定FET小信号等效电路的新方法

来源&#xff1a;A New Method for Determining the FET Small-Signal Equivalent Circuit&#xff08;88年 TMTT&#xff09; 摘要 - 提出了一种确定FET&#xff08;场效应晶体管&#xff09;小信号等效电路的新方法。该方法包括在低频段直接测定器件的外在和内在小信号参数。…

STM32_DS18B20_1_芯片简介及初始化配置

DS18B20介绍 DS18B20数字温度计提供9位到12位摄氏度的温度测量&#xff0c;并具有非易失性&#xff0c;用户可编程的上下触发点的报警功能。DS18B20通过1线总线进行通信&#xff0c;根据定义&#xff0c;该总线只需要一条数据线&#xff0c;即可与中央微处理器进行通信…

给定一个边与边可能相交的多边形,求它的轮廓线

大家好&#xff0c;我是前端西瓜哥。 最近遇到一个需求&#xff0c;给定一个多边形&#xff08;边与边可能相交&#xff09;&#xff0c;求这个多边形的轮廓线。 需要注意的是&#xff0c;轮廓线多边形内不能有空洞&#xff0c;使用的不是常见的非零绕数规则&#xff08;nonze…

2.23 Qt day4 事件机制+定时器事件+键盘事件+鼠标事件

思维导图&#xff1a; 做一个闹钟&#xff0c;在行编辑器里输入定闹钟的时间&#xff0c;时间到了就语音播报文本里的内容&#xff0c;播报五次 widget.h&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include<QDebug>//输出类 #include<…

JSON(javaScript Object Notation,Js对象标记)—我耀学IT

Json是一种轻量级的数据交换格式&#xff0c;目前使用非常广泛&#xff0c;是一种轻量级的数据交换格式。易于人阅读和编写&#xff0c;可以在多种语言之间进行数据交换 。同时也易于机器解析和生成 1.1json的值: 值可以是对象、数组、数字、字符串或者三个字面值(false、nul…