返回顶部
首页 > 资讯 > 后端开发 > Python >Python怎样实现"导弹" 自动追踪示例
  • 178
分享到

Python怎样实现"导弹" 自动追踪示例

2023-06-14 05:06:24 178人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要介绍python怎样实现"导弹" 自动追踪示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Python可以做什么Python是一种编程语言,内置了许多有效的工具,Python几乎无所

这篇文章主要介绍python怎样实现"导弹" 自动追踪示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

Python可以做什么

Python是一种编程语言,内置了许多有效的工具,Python几乎无所不能,该语言通俗易懂、容易入门、功能强大,在许多领域中都有广泛的应用,例如最热门的大数据分析人工智能web开发等。

自动追踪算法,在我们设计2D射击类游戏时经常会用到,这个听起来很高大上的东西,其实也并不是军事学的专利,在数学上解决的话需要去解微分方程,

这个没有点数学基础是很难算出来的。但是我们有了计算机就不一样了,依靠计算机极快速的运算速度,我们利用微分的思想,加上一点简单的三角学知识,就可以实现它。

好,话不多说,我们来看看它的算法原理,看图:

Python怎样实现"导弹" 自动追踪示例

由于待会要用pygame演示,他的坐标系是y轴向下,所以这里我们也用y向下的坐标系。

算法总的思想就是根据上图,把时间t分割成足够小的片段(比如1/1000,这个时间片越小越精确),每一个片段分别构造如上三角形,计算出导弹下一个时间片走的方向(即∠a)和走的路程(即vt=|AC|),这时候目标再在第二个时间片移动了位置,这时刚才计算的C点又变成了第二个时间片的初始点,这时再在第二个时间片上在C点和新的目标点构造三角形计算新的vt,然后进入第三个时间片,如此反复即可。

假定导弹和目标的初始状态下坐标分别是(x1,y1),(x,y),构造出直角三角形ABE,这个三角形用来求∠a的正弦和余弦值,因为vt是自己设置的,我们需要计算A到C点x和y坐标分别移动了多少,移动的值就是AD和CD的长度,这两个分别用vt乘cosa和sina即可。

计算sina和cosa,正弦对比斜,余弦邻比斜,斜边可以利用两点距离公式计算出,即:

Python怎样实现"导弹" 自动追踪示例

于是

Python怎样实现"导弹" 自动追踪示例

AC的长度就是导弹的速度乘以时间即 |AC|=vt,然后即可计算出AD和CD的长度,于是这一个时间片过去后,导弹应该出现在新的位置C点,他的坐标就是老的点A的x增加AD和y减去CD。

于是,新的C点坐标就是:

Python怎样实现"导弹" 自动追踪示例

只要一直反复循环执行这个操作即可,好吧,为了更形象,把第一个时间片和第二个时间片放在一起看看:

Python怎样实现"导弹" 自动追踪示例

第一个是时间片构造出的三角形是ABE,经过一个时间片后,目标从B点走到了D点,导弹此时在C点,于是构造新的三角形CDF,重复刚才的计算过程即可,图中的角∠b就是导弹需要旋转的角度,现实中只需要每个时间片修正导弹的方向就可以了,具体怎么让导弹改变方向,这就不是我们需要研究的问题了

好,由于最近在用Python的pygame库制作小游戏玩,接下来我们就用pygame来演示一下这个效果,效果如下图:

Python怎样实现"导弹" 自动追踪示例

很简单的代码如下:

import pygame,sysfrom math import *pygame.init()screen=pygame.display.set_mode((800,700),0,32)missile=pygame.image.load('element/red_pointer.png').convert_alpha()x1,y1=100,600      #导弹的初始发射位置velocity=800      #导弹速度time=1/1000       #每个时间片的长度clock=pygame.time.Clock()old_angle=0while True:  for event in pygame.event.get():    if event.type==pygame.QUIT:      sys.exit()  clock.tick(300)  x,y=pygame.mouse.get_pos()     #获取鼠标位置,鼠标就是需要打击的目标  distance=sqrt(pow(x1-x,2)+pow(y1-y,2))   #两点距离公式  section=velocity*time        #每个时间片需要移动的距离  sina=(y1-y)/distance  cosa=(x-x1)/distance  angle=atan2(y-y1,x-x1)       #两点线段的弧度值  x1,y1=(x1+section*cosa,y1-section*sina)  d_angle = degrees(angle)    #弧度转角度  screen.blit(missile, (x1-missile.get_width(), y1-missile.get_height()/2))  dis_angle=d_angle-old_angle     #dis_angle就是到下一个位置需要改变的角度  old_angle=d_angle          #更新初始角度  pygame.display.update()

如果仅把导弹考虑为一个质点的话,那么以上算法就已经足矣,我没有做导弹的旋转,因为一个质点也不分头尾不需要旋转,当然这前提得是你加载的导弹图片很小的时候不旋转看起来也没什么问题。但是在pygame里面做旋转并不是一件容易的事情(也可能是我无知),好吧我们先把图片替换成一张矩形的,再加入旋转函数看看效果如何

Python怎样实现"导弹" 自动追踪示例

missiled = pygame.transfORM.rotate(missile, -(d_angle))screen.blit(missiled, (x1-missile.get_width(), y1-missile.get_height()/2))

因为图片的坐标点是它的左上角的点,所以如果我们想让图片的坐标固定在箭头尖点,那么把图片实际打印位置x减少图片长度,y减少一半宽度就行。

但是实际运行效果并不好:

Python怎样实现"导弹" 自动追踪示例

大致方向相同,但是图片箭头的尖点并没有一直跟随鼠标,这是为什么呢。经过我的研究(就因为这个问题没解决一直没发布),

我发现原来是这个图旋转的机制问题,我们看看旋转后的图片变成什么样了:

Python怎样实现"导弹" 自动追踪示例

旋转后的图片变成了蓝色的那个范围,根据旋转角度的不同,所变成的图片大小也不一样,我们看旋转90的情况

Python怎样实现"导弹" 自动追踪示例

Python怎样实现"导弹" 自动追踪示例

我们发现,旋转后的图片不仅面积变大了,导弹头的位置也变了。那应该怎么解决这个问题呢?思路是,每一次旋转图片以后,求出旋转图的头位置(图中的绿色箭头点),然后把绿图的打印位置移动一下,下,x,y分别移动两个头的距离,就可以让旋转后的导弹头对准实际我们参与运算的那个导弹头的位置,移动后应该是这样的:

Python怎样实现"导弹" 自动追踪示例

这样,两个导弹头的点就一致了。接下来我们分析求旋转后的导弹头的算法。根据旋转角度的不同,旋转角在不同象限参数不一样,所以我们分为这四种情况

1,2象限

Python怎样实现"导弹" 自动追踪示例

3,4象限,它的旋转只有正负0—180,所以3,4象限就是负角

Python怎样实现"导弹" 自动追踪示例

显示图片的时候我们将他移动

screen.blit(missiled, (x1-width+(x1-C[0]),y1-height/2+(y1-C[1])))

这里的(x1-width,y1-height/2)其实才是上图中的(x1,y1)

所以最后我们加入相关算法代码,效果就比较完美了

Python怎样实现"导弹" 自动追踪示例

大功告成,最后附上全部的算法代码

import pygame,sysfrom math import *pygame.init()font1=pygame.font.SysFont('microsoftyaheimicrosoftyaheiui',23)textc=font1.render('*',True,(250,0,0))screen=pygame.display.set_mode((800,700),0,32)missile=pygame.image.load('element/rect1.png').convert_alpha()height=missile.get_height()width=missile.get_width()pygame.mouse.set_visible(0)x1,y1=100,600      #导弹的初始发射位置velocity=800      #导弹速度time=1/1000       #每个时间片的长度clock=pygame.time.Clock()A=()B=()C=()while True:  for event in pygame.event.get():    if event.type==pygame.QUIT:      sys.exit()  clock.tick(300)  x,y=pygame.mouse.get_pos()     #获取鼠标位置,鼠标就是需要打击的目标  distance=sqrt(pow(x1-x,2)+pow(y1-y,2))   #两点距离公式  section=velocity*time        #每个时间片需要移动的距离  sina=(y1-y)/distance  cosa=(x-x1)/distance  angle=atan2(y-y1,x-x1)       #两点间线段的弧度值  fangle=degrees(angle)        #弧度转角度  x1,y1=(x1+section*cosa,y1-section*sina)  missiled=pygame.transform.rotate(missile,-(fangle))  if 0<=-fangle<=90:    A=(width*cosa+x1-width,y1-height/2)    B=(A[0]+height*sina,A[1]+height*cosa)  if 90<-fangle<=180:    A = (x1 - width, y1 - height/2+height*(-cosa))    B = (x1 - width+height*sina, y1 - height/2)  if -90<=-fangle<0:    A = (x1 - width+missiled.get_width(), y1 - height/2+missiled.get_height()-height*cosa)    B = (A[0]+height*sina, y1 - height/2+missiled.get_height())  if -180<-fangle<-90:    A = (x1-width-height*sina, y1 - height/2+missiled.get_height())    B = (x1 - width,A[1]+height*cosa )  C = ((A[0] + B[0]) / 2, (A[1] + B[1]) / 2)  screen.fill((0,0,0))  screen.blit(missiled, (x1-width+(x1-C[0]),y1-height/2+(y1-C[1])))  screen.blit(textc, (x,y)) #鼠标用一个红色*代替  pygame.display.update()

以上是“Python怎样实现"导弹" 自动追踪示例”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网Python频道!

--结束END--

本文标题: Python怎样实现"导弹" 自动追踪示例

本文链接: https://lsjlt.com/news/268216.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python怎样实现"导弹" 自动追踪示例
    这篇文章主要介绍Python怎样实现"导弹" 自动追踪示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!python可以做什么Python是一种编程语言,内置了许多有效的工具,Python几乎无所...
    99+
    2023-06-14
  • Python实现简单的"导弹" 自动追踪原理解析
    自动追踪算法,在我们设计2D射击类游戏时经常会用到,这个听起来很高大上的东西,其实也并不是军事学的专利,在数学上解决的话需要去解微分方程, 这个没有点数学基础是很难算出来的。但是我们...
    99+
    2024-04-02
  • 用 Python 实现导弹自动追踪,超燃!
    大家好,我是J哥。这个没有点数学基础是很难算出来的。但是我们有了计算机就不一样了,依靠计算机极快速的运算速度,我们利用微分的思想,加上一点简单的三角学知识,就可以实现它。好,话不多说,我们来看看它的算法原理,看图:由于待会要用pygame演...
    99+
    2023-05-14
    代码 Python 自动追踪
  • vue实现自定义"模态弹窗"组件实例代码
    目录前言效果图实例代码总结前言 对话框是很常用的组件 , 在很多地方都会用到,一般我们可以使用自带的alert来弹出对话框,但是假如是设计出的图该怎么办呢 ,所以我们需要自己写一个对...
    99+
    2024-04-02
  • python目标检测基于opencv实现目标追踪示例
    目录主要代码信息封装类更新utilspython-opencv3.0新增了一些比较有用的追踪器算法,这里根据官网示例写了一个追踪器类 程序只能运行在安装有opencv3.0以上版本和...
    99+
    2024-04-02
  • Python编程实现下载器自动爬取采集B站弹幕示例
    目录实现效果UI界面数据采集小结大家好,我是小张! 在《Python编程实现小姐姐跳舞并生成词云视频示例》文章中简单介绍了B站弹幕的爬取方法,只需找到视频中的参数 cid,就能采集到...
    99+
    2024-04-02
  • python+requests+pytest接口自动化的实现示例
    目录1、发送get请求2、发送post请求3、发送https请求4、文件上传5、文件下载6、timeout超时7、鉴权 7.1、auth参数鉴权7.2、session操作7.3、to...
    99+
    2024-04-02
  • Python怎么实现直播弹幕自动发送功能
    这篇文章主要讲解了“Python怎么实现直播弹幕自动发送功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python怎么实现直播弹幕自动发送功能”吧!前言先打开一个直播间按F12打开开发者...
    99+
    2023-06-29
  • Python实现视频自动打码的示例代码
    目录序言准备工作实现原理模块素材工具代码解析完整代码序言 我们在观看视频的时候,有时候会出现一些奇怪的马赛克,影响我们的观影体验,那么这些马赛克是如何精确的加上去的呢? 本次我们就...
    99+
    2024-04-02
  • Python实现邮件自动下载的示例详解
    开始码代码之前,我们先来了解一下三种邮件服务协议: 1、SMTP协议 SMTP(Simple Mail Transfer Protocol),即简单邮件传输协议。相当于中转站,将邮件...
    99+
    2024-04-02
  • Python实现自动整理文件的示例代码
    目录一、前言二、遍历文件三、移动文件四、自动整理文件1、将图片集中存放2、同步整理文件3、获取文件属性一、前言 今天我们就带大家来实现一下文件自动整理的操作。在我们日常生活中,文件总...
    99+
    2024-04-02
  • Python实现自动整理表格的示例代码
    目录前言原理目标实现运行效果前言 今天,在工作的时候,我的美女同事问我有没有办法自动生成一个这样的表格: 第一列是院校+科目,第二列是年份,第三列是数量。 这张表格是基于这一文件夹...
    99+
    2023-03-02
    Python自动整理表格 Python整理表格 Python表格
  • python实现自动抢课脚本的示例代码
    目录自动抢课脚本使用手册1.准备工作2.配合使用py脚本和xlsx文件3.auto_get_lesson_pic_recognize功能介绍4.坐标版本(不建议使用)5.代码自动抢课...
    99+
    2024-04-02
  • python+appium实现自动化测试的示例代码
    目录1.什么是Appium2.启动一个app自动化程序的步骤3.appium服务介绍4. appium客户端使用5.adb的使用 6.Appium启动过程分析1....
    99+
    2024-04-02
  • Python中怎么实现自动导入缺失的库
    本篇内容主要讲解“Python中怎么实现自动导入缺失的库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中怎么实现自动导入缺失的库”吧!在写 Python 项目的时候,我们可能经常会遇...
    99+
    2023-06-02
  • Python实现Telnet自动连接检测密码的示例
    最近在学习Python网络相关编程,这个代码实现了Telnet自动连接检测root用户密码,密码取自密码本,一个一个检测密码是否匹配,直到匹配成功,屏幕输出停止。 Python内置了...
    99+
    2024-04-02
  • Python实现自动化整理文件的示例代码
    目录自动化整理计算机文件1. 文件的自动分类2. 文件和文件夹的快速查找3. 自动清理重复文件4. 批量转换图片格式5. 按拍摄日期自动分类图片自动化整理计算机文件 通过Python...
    99+
    2024-04-02
  • 怎样用Python实现自动化操作Android手机
    本篇文章给大家分享的是有关怎样用Python实现自动化操作Android手机,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、【必须】安装adb工具adb全称Android D...
    99+
    2023-06-02
  • 简单介绍Python实现邮件自动下载的示例
    本篇文章给大家带来了关于Python的相关知识,详细介绍了如何利用Python语言实现邮件自动下载以及附件解析功能,文中的示例代码讲解详细,感下面一起来看一下,希望对大家有帮助。【相关推荐:Python3视频教程 】开始码代码之前,我们先来...
    99+
    2022-08-17
    python
  • python+pywinauto+lackey实现PC端exe自动化的示例代码
    欢迎阅读 最近一年多一直在从事PC端exe的测试,也是趁着闲余时间,调研了下exe的自动化。 核心框架为python+pywinauto+lackey这样的一个组合方式 本文以大家...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作