婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python實現簡單的導彈 自動追蹤原理解析

Python實現簡單的導彈 自動追蹤原理解析

熱門標簽:長春人工智能電銷機器人官網 地圖標注推廣單頁 女王谷地圖標注 百應ai電銷機器人鄭州 ai地圖標注 如何在地圖標注文字 西藏快速地圖標注地點 廈門crm外呼系統如何 n400電話申請多少錢

自動追蹤算法,在我們設計2D射擊類游戲時經常會用到,這個聽起來很高大上的東西,其實也并不是軍事學的專利,在數學上解決的話需要去解微分方程,

這個沒有點數學基礎是很難算出來的。但是我們有了計算機就不一樣了,依靠計算機極快速的運算速度,我們利用微分的思想,加上一點簡單的三角學知識,就可以實現它。

好,話不多說,我們來看看它的算法原理,看圖:

由于待會要用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,正弦對比斜,余弦鄰比斜,斜邊可以利用兩點距離公式計算出,即:

于是

AC的長度就是導彈的速度乘以時間即 |AC|=vt,然后即可計算出AD和CD的長度,于是這一個時間片過去后,導彈應該出現在新的位置C點,他的坐標就是老的點A的x增加AD和y減去CD。

于是,新的C點坐標就是:

只要一直反復循環執行這個操作即可,好吧,為了更形象,把第一個時間片和第二個時間片放在一起看看:

第一個是時間片構造出的三角形是ABE,經過一個時間片后,目標從B點走到了D點,導彈此時在C點,于是構造新的三角形CDF,重復剛才的計算過程即可,圖中的角∠b就是導彈需要旋轉的角度,現實中只需要每個時間片修正導彈的方向就可以了,具體怎么讓導彈改變方向,這就不是我們需要研究的問題了

好,由于最近在用Python的pygame庫制作小游戲玩,接下來我們就用pygame來演示一下這個效果,效果如下圖:

很簡單的代碼如下:

import pygame,sys
from 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=0
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)       #兩點線段的弧度值
  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里面做旋轉并不是一件容易的事情(也可能是我無知),好吧我們先把圖片替換成一張矩形的,再加入旋轉函數看看效果如何

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

因為圖片的坐標點是它的左上角的點,所以如果我們想讓圖片的坐標固定在箭頭尖點,那么把圖片實際打印位置x減少圖片長度,y減少一半寬度就行。

但是實際運行效果并不好:

大致方向相同,但是圖片箭頭的尖點并沒有一直跟隨鼠標,這是為什么呢。經過我的研究(就因為這個問題沒解決一直沒發布),

我發現原來是這個圖旋轉的機制問題,我們看看旋轉后的圖片變成什么樣了:

旋轉后的圖片變成了藍色的那個范圍,根據旋轉角度的不同,所變成的圖片大小也不一樣,我們看旋轉90的情況

我們發現,旋轉后的圖片不僅面積變大了,導彈頭的位置也變了。那應該怎么解決這個問題呢?思路是,每一次旋轉圖片以后,求出旋轉圖的頭位置(圖中的綠色箭頭點),然后把綠圖的打印位置移動一下,下,x,y分別移動兩個頭的距離,就可以讓旋轉后的導彈頭對準實際我們參與運算的那個導彈頭的位置,移動后應該是這樣的:

這樣,兩個導彈頭的點就一致了。接下來我們分析求旋轉后的導彈頭的算法。根據旋轉角度的不同,旋轉角在不同象限參數不一樣,所以我們分為這四種情況

1,2象限

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

顯示圖片的時候我們將他移動

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

這里的(x1-width,y1-height/2)其實才是上圖中的(x1,y1)

所以最后我們加入相關算法代碼,效果就比較完美了

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

import pygame,sys
from 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=-fangle0:
    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自動追蹤內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 使用python自動追蹤你的快遞(物流推送郵箱)
  • Python函數調用追蹤實現代碼
  • python 追蹤except信息方式
  • 如何用OpenCV -python3實現視頻物體追蹤
  • Python+OpenCV實現實時眼動追蹤的示例代碼
  • 淺析Python+OpenCV使用攝像頭追蹤人臉面部血液變化實現脈搏評估
  • OpenCV3.0+Python3.6實現特定顏色的物體追蹤
  • python+opencv實現動態物體追蹤

標簽:內江 拉薩 綿陽 渭南 興安盟 黔東 亳州 廊坊

巨人網絡通訊聲明:本文標題《Python實現簡單的導彈 自動追蹤原理解析》,本文關鍵詞  Python,實現,簡單,的,導彈,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python實現簡單的導彈 自動追蹤原理解析》相關的同類信息!
  • 本頁收集關于Python實現簡單的導彈 自動追蹤原理解析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩精品三区| 日韩美一区二区三区| 一区二区三区国产| 日韩一卡二卡三卡| 欧美丰满少妇xxxxx高潮对白 | 日韩网站在线看片你懂的| 精品一区二区三区视频在线观看 | 亚洲欧美激情小说另类| 色综合久久66| 91麻豆精品国产自产在线| 国产在线精品一区二区夜色| 亚洲精品国产a久久久久久| 久久精品这里都是精品| 精品动漫一区二区三区在线观看| 免费观看成人av| 天堂在线亚洲视频| www.欧美日韩| 在线一区二区三区做爰视频网站| 成人深夜视频在线观看| 制服丝袜成人动漫| 欧美视频一区二区三区在线观看| 337p亚洲精品色噜噜| 色94色欧美sute亚洲线路一久| 91女神在线视频| 亚洲精品一区二区三区99| 午夜久久久影院| 在线影院国内精品| 日本一区二区视频在线观看| 亚洲色图.com| 中文字幕在线不卡| 亚洲色图另类专区| 亚洲视频中文字幕| 美女视频黄a大片欧美| www.欧美亚洲| 在线不卡中文字幕| 蜜桃视频一区二区| 亚洲三级视频在线观看| 亚洲免费av观看| 久久久久久久久久久久电影| 精品国产在天天线2019| 欧美成人一区二区三区在线观看| 欧美激情中文字幕| 国产欧美日韩在线视频| 久久成人免费网| 欧美精品成人一区二区三区四区| 亚洲视频一二区| 粉嫩aⅴ一区二区三区四区五区| 成人黄色a**站在线观看| 久久久国际精品| 777午夜精品免费视频| 一区二区在线观看免费 | 精品一区二区日韩| 国产精品网站导航| 91激情在线视频| 国产精品毛片大码女人| 日韩欧美激情四射| www.欧美亚洲| 国产成人精品免费看| 亚洲一区二区三区中文字幕在线| 欧美日韩在线免费视频| 精久久久久久久久久久| 青青草国产成人99久久| 国产精品女主播av| 国产三级精品视频| 在线不卡中文字幕播放| 欧美三级乱人伦电影| 成人a区在线观看| 亚洲色图在线看| 亚洲欧洲精品一区二区三区不卡 | 日日嗨av一区二区三区四区| 亚洲欧美日韩中文字幕一区二区三区 | 日韩一区二区影院| 不卡av电影在线播放| 日韩电影免费一区| 免费在线观看视频一区| 亚洲国产精品自拍| 奇米影视在线99精品| 夜夜精品视频一区二区| 亚洲成a人v欧美综合天堂下载| 中文字幕在线不卡| 国产丝袜美腿一区二区三区| 国产精品久久三区| 精品99一区二区| 日本一区二区不卡视频| 久久久久久久久久久99999| 亚洲国产激情av| 国产欧美一区二区三区沐欲| 亚洲手机成人高清视频| 国产精品久久久久影院亚瑟| 成人毛片在线观看| 成人黄页在线观看| 成人美女视频在线看| 欧美情侣在线播放| 欧美日韩在线亚洲一区蜜芽| 精品国产电影一区二区| 精品国产三级a在线观看| 亚洲欧美日韩系列| 亚洲精品成人少妇| 国产自产v一区二区三区c| 国产在线一区观看| 日本不卡视频在线| 成人国产精品视频| 91美女片黄在线| 久久免费偷拍视频| 国产精品免费人成网站| 婷婷成人激情在线网| 麻豆一区二区三| 国产清纯美女被跳蛋高潮一区二区久久w| 日韩一区二区不卡| 精品处破学生在线二十三| 久久久蜜桃精品| 午夜激情一区二区| 国产在线观看一区二区| 色999日韩国产欧美一区二区| 欧美人与z0zoxxxx视频| 欧美性猛交xxxx乱大交退制版| 欧美三区在线观看| 精品国产露脸精彩对白| 日韩限制级电影在线观看| 国产喷白浆一区二区三区| 欧美a级理论片| 成人黄色软件下载| 精品va天堂亚洲国产| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 免费的成人av| 91免费版在线| 亚洲色图色小说| 精品一二线国产| 日韩一区二区在线免费观看| 日本一区二区不卡视频| 韩国欧美国产一区| 欧美午夜电影一区| 国产99久久久久| 亚洲日本在线看| 日韩不卡一二三区| 99久久精品99国产精品| 精品久久五月天| 久久国产精品色| 欧美视频在线播放| 一区二区成人在线| 国产成人亚洲综合a∨猫咪| 日韩欧美精品三级| 视频一区中文字幕国产| 欧美另类变人与禽xxxxx| 亚洲欧美日韩国产一区二区三区| 日韩精品视频网站| 欧美精品久久99| 亚洲综合免费观看高清完整版在线| 色综合久久66| 亚洲色图在线视频| 欧美在线观看视频一区二区三区| 国产精品午夜电影| 色噜噜久久综合| 国产精品免费观看视频| 成人丝袜高跟foot| 中文字幕av不卡| 91福利国产成人精品照片| 亚洲欧美一区二区视频| 欧美午夜精品电影| 亚洲国产美国国产综合一区二区| 欧美精品在线视频| 午夜私人影院久久久久| 久久天天做天天爱综合色| 九一九一国产精品| 日本一区二区电影| 成人av资源在线| 五月天欧美精品| 欧美日韩一区二区不卡| 人禽交欧美网站| 91精品国产91久久久久久最新毛片 | 亚洲精品一区二区三区福利| 99久久免费国产| 一区二区欧美精品| 日韩一级免费一区| 另类小说图片综合网| 日本一区免费视频| 色综合久久88色综合天天| 九九热在线视频观看这里只有精品| 日韩视频一区二区在线观看| 自拍偷自拍亚洲精品播放| 激情综合色播激情啊| 欧美经典三级视频一区二区三区| 91色综合久久久久婷婷| 亚洲一区二区综合| 欧美一区二区三区免费大片| 激情久久五月天| 国产精品久久久久影院色老大| 欧美成人一区二区三区| 国产91在线观看| 久久av中文字幕片| 中文字幕在线不卡视频| 国产午夜亚洲精品午夜鲁丝片| 成人一级片在线观看| 麻豆视频一区二区| 亚洲国产成人一区二区三区| 日韩欧美精品在线视频| 成人国产在线观看| 懂色av一区二区三区免费观看| 一区二区三区产品免费精品久久75| 久久精品在线观看|