百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

雷达模拟:用python的pygame实现和代码分析

off999 2024-10-25 13:41 12 浏览 0 评论

1 说明:

=====

1.1 pygame的扇形绘制:网上没有,只有弧形绘制,自己拓展。

1.2 雷达模拟图,锻炼自己python思维,我的代码还是可以优化的。

1.3 环境:python3.8+pygame 1.9.6

1.4 知识点:pygame中画弧线时,一般宽度是1,当等于半径时就是一个扇形!


2 代码步骤和分析:

==============

第1步:模块导入

import pygame
from pygame.locals import *
import math
import numpy as np

第2步:初始化窗口及大小设置

SIZE = 1000, 1000  #注意这是一个元组
pygame.init() #初始化
pygame.display.set_caption('Python Pygame Radar')  #窗口标题名
screen = pygame.display.set_mode(SIZE)  #窗口大小设置

第3步:颜色定义,便于后面调用,使代码简洁些

black=[0,0,0]
white=[255,255,255]
green=[0,255,0]
blue=[0,0,255]
red=[255,0,0]

第4步:初始化定义相关参数

#设置刷新时钟
FPSCLOCK = pygame.time.Clock()
#屏幕背景颜色为黑色
screen.fill(black)  
#度数
degree=0
#定义字体,显示中文,hwfs(华文仿宋),需要自己下载,放在根目录下
my_fontxy = pygame.font.Font('hwfs.ttf', 20)  #显示xy坐标及动态值的字体
my_fontd = pygame.font.Font('hwfs.ttf', 40)  #显示方向字体
#东南西北文字
textd=['E','S','W','N']
#东南西北坐标,这个可以微调
x_y=[(870,470),(490,870),(100,470),(490,90)]

#目标物参数设置
speed = 60                # 飞行速度
beta = 300 / 180 * np.pi   # 飞行方位角
#初始坐标设置
pointStartX = 500
pointStartY = 10

#转动雷达线的坐标点
radar = (500,500)  
radar_len = 360  #长度

第5步:定义文字显示函数

#红线弧形上的x和y坐标
def loadtext1(x):
    textstr='x坐标: '+str(x)
    text_screen=my_fontxy.render(textstr, True, white)
    screen.blit(text_screen, (50,50))

def loadtext2(y):
    textstr='y坐标: '+str(y)
    text_screen=my_fontxy.render(textstr, True, white)
    screen.blit(text_screen, (50,100))

#定义显示东南西北函数
def loadtext3(textd,x_y):
    textstr=textd
    text_screen=my_fontd.render(textstr, True, white)
    screen.blit(text_screen, x_y)

第6步:游戏循环和扇形设置

#---第6步:游戏循环---
done = False
while not done:
    screen.fill(0)
    # 6-1:游戏退出设置
    for e in pygame.event.get():
        if e.type == QUIT or (e.type == KEYDOWN and e.key == K_ESCAPE):
            done = True
            break
    # 6-2:画同心圆和垂直水平坐标白线
    for x in range(1,400,40):
        pygame.draw.circle(screen,green,(500,500),x,1)  #画圆及坐标点

    #垂直坐标白线
    pygame.draw.line( screen,white,( 500, 140 ),( 500, 860 ),)
    #水平坐标白线
    pygame.draw.line( screen,white,( 140, 500 ),( 860, 500 ),)


    # 6-3:移动的雷达扫描线和扇形
    # 6-3-1:移动雷达线red坐标点
    x = int(radar[0] + math.cos(math.radians(degree)) * radar_len)
    y = int(radar[1] + math.sin(math.radians(degree)) * radar_len)

    # 6-3-2:移动雷达线blue坐标点
    x2 = int(radar[0] + math.cos(math.radians(degree+30)) * radar_len)
    y2 = int(radar[1] + math.sin(math.radians(degree+30)) * radar_len)

    # 6-3-3:转动雷达线的坐标点
    pygame.draw.line(screen, red, radar, (x,y), 1)
    pygame.draw.line(screen, blue, radar, (x2,y2), 1)
    
    # 6-3-4:画雷达扫描扇形
    #弧形的旋转方向反了,难点,小bug
    #注意pygame画扇形是通过画弧形来的,一般弧形宽度为1
    #如果宽度等于半径,就是扇形
    start_angle=math.radians(degree)
    end_angle=math.radians(degree+30)
    position = radar[0] - radar_len, radar[1] - radar_len, radar_len*2, radar_len*2
    #360其实就是最外围的半径,一般为1是弧度
    pygame.draw.arc(screen, white, position, start_angle, end_angle, 360)

    # 6-3-5:文字显示
    #左上角显示文字和动态x和y坐标值
    loadtext1(x)  #显示x坐标动态值
    loadtext2(y)  #显示y坐标动态值

    #显示东南西北方位文字
    for i in range(4):
        loadtext3(textd[i],x_y[i])

    # 6-3-6:外来目标物坐标
    pointStartX += int(speed*degree*0.01*np.cos(beta))
    pointStartY += -int(speed*degree*0.01*np.sin(beta))
    # -----绘制圆外来目标物 -----
    pygame.draw.circle(screen, red, (pointStartX, pointStartY), 10)
    pygame.draw.circle(screen, white, (pointStartX-200, pointStartY-200), 10)
    pygame.draw.circle(screen, blue, (pointStartX-400, pointStartY-400), 10)
    pygame.draw.circle(screen, green, (pointStartX-600, pointStartY-600), 10)
    pygame.draw.circle(screen, red, (pointStartX-800, pointStartY-800), 10)
    
    #循环判断,即5个目标物出现后再从新出现
    #bug后面的的速度越来越快
    if pointStartX>=SIZE[0] and pointStartY>=SIZE[1]: 
        pointStartX=500
        pointStartY=10

    degree+=1  #数值越大,速度越快

    # 6-3-7:刷新
    pygame.display.flip()   
    FPSCLOCK.tick(40)

3 效果图:

=======


3 思考问题:

=========

3.1 为什么速度越来越快,后来又变慢了呢?如何修改匀速呢?

3.2 本来pygame画扇形是两条线(红+蓝线)+一个弧度(arc),发现运动方向相反了,如何同步同向运动呢?

欢迎大家调试和改进。

相关推荐

每天一个 Python 库:datetime 模块全攻略,时间操作太丝滑!

在日常开发中,时间处理是绕不开的一块,比如:生成时间戳比较两个时间差转换为可读格式接口传参/前端展示/日志记录今天我们就用一个案例+代码+思维导图,带你完全搞定datetime模块的用法!...

字节跳动!2023全套Python入门笔记合集

学完python出来,已经工作3年啦,最近有很多小伙伴问我,学习python有什么用其实能做的有很多可以提高工作效率增强逻辑思维还能做爬虫网站数据分析等等!!最近也是整理了很多适合零基...

为什么你觉得Matplotlib用起来困难?因为你还没看过这个思维导图

前言Matplotlib是一个流行的Python库,可以很容易地用于创建数据可视化。然而,设置数据、参数、图形和绘图在每次执行新项目时都可能变得非常混乱和繁琐。而且由于应用不同,我们不知道选择哪一个图...

Python新手必看!30分钟搞懂break/continue(附5个实战案例)

一、跳转语句的使命当程序需要提前结束循环或跳过特定迭代时,break和continue就是你的代码急刹按钮和跳步指令。就像在迷宫探险中:break=发现出口立即离开continue=跳过陷阱继续前进二...

刘心向学(24)Python中的数据类(python中5种简单的数据类型)

分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。今天小编为大家带来文章“刘心向学(24)Python中的数据类”欢迎您的访问。Shareinterest,...

刘心向学(25)Python中的虚拟环境(python虚拟环境安装和配置)

分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。今天小编为大家带来文章“刘心向学(25)Python中的虚拟环境”欢迎您的访问。Shareinte...

栋察宇宙(八):Python 中的 wordcloud 库学习介绍

分享乐趣,传播快乐,增长见识,留下美好。亲爱的您,这里是LearingYard学苑!今天小编为大家带来“Python中的wordcloud库学习介绍”欢迎您的访问!Sharethefun,...

AI在用|ChatGPT、Claude 3助攻,1分钟GET高颜值思维导图

机器之能报道编辑:Cardinal以大模型、AIGC为代表的人工智能浪潮已经在悄然改变着我们生活及工作方式,但绝大部分人依然不知道该如何使用。因此,我们推出了「AI在用」专栏,通过直观、有趣且简洁的人...

使用DeepSeek + Python开发AI思维导图应用,非常强!

最近基于Deepseek+PythonWeb技术开发了一个AI对话自动生成思维导图的应用,用来展示下如何基于低门槛的Python相关技术栈,高效结合deepseek实现从应用场景到实际应用的快速落地...

10幅思维导图告诉你 - Python 核心知识体系

首先,按顺序依次展示了以下内容的一系列思维导图:基础知识,数据类型(数字,字符串,列表,元组,字典,集合),条件&循环,文件对象,错误&异常,函数,模块,面向对象编程;接着,结合这些思维导图主要参考的...

Python基础核心思维导图,让你轻松入门

Python基础核心思维导图【高清图文末获取】学习路线图就给大家看到这里了,需要的小伙伴下方获取获取方式看下方图片...

Python基础核心思维导图,学会事半功倍

Python基础核心思维导图【高清图文末获取】学习路线图就给大家看到这里了,需要的小伙伴下方获取获取方式看下方图片...

硬核!288页Python核心知识笔记(附思维导图,建议收藏)

今天就给大家分享一份288页Python核心知识笔记,相较于部分朋友乱糟糟的笔记,这份笔记更够系统地总结相关知识,巩固Python知识体系。文末获取完整版PDF该笔记学习思维导图:目录内容展示【领取方...

Python学习知识思维导图(高效学习)

Python学习知识思维导图python基础知识python数据类型条件循环列表元组字典集合字符串序列函数面向对象编程模块错误异常文件对象#python##python自学##编程#...

别找了!288页Python核心知识笔记(附思维导图,建议收藏)

今天就给大家分享一份288页Python核心知识笔记,相较于部分朋友乱糟糟的笔记,这份笔记更够系统地总结相关知识,巩固Python知识体系。文末获取完整版PDF该笔记学习思维导图:目录内容展示【领取方...

取消回复欢迎 发表评论: