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

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

off999 2024-10-25 13:41 44 浏览 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),发现运动方向相反了,如何同步同向运动呢?

欢迎大家调试和改进。

相关推荐

安全教育登录入口平台(安全教育登录入口平台官网)

122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...

大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)

大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...

谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)

要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...

2026-02-04 09:03 off999

电信宽带测速官网入口(电信宽带测速官网入口app)

这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...

植物大战僵尸95版手机下载(植物大战僵尸95 版下载)

1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...

免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)

1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...

2025世界杯赛程表(2025世界杯在哪个国家)

2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...

下载搜狐视频电视剧(搜狐电视剧下载安装)

搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...

pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
永久免费听歌网站(丫丫音乐网)

可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...

音乐格式转换mp3软件(音乐格式转换器免费版)

有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...

电子书txt下载(免费的最全的小说阅读器)

1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...

最好免费观看高清电影(播放免费的最好看的电影)

在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...

孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)

要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...

取消回复欢迎 发表评论: