當前位置: 首頁>>代碼示例>>Python>>正文


Python Vector.le方法代碼示例

本文整理匯總了Python中Vector.le方法的典型用法代碼示例。如果您正苦於以下問題:Python Vector.le方法的具體用法?Python Vector.le怎麽用?Python Vector.le使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Vector的用法示例。


在下文中一共展示了Vector.le方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: update

# 需要導入模塊: import Vector [as 別名]
# 或者: from Vector import le [as 別名]
 def update(self, acceleration, E):
     """ Responsible for time keeping. """
     # Update the velocity for gravity
     self.vy -= acceleration
     
     #Basic Wall interaction
     if self.x >= width - 10:
         self.x = width - 11
         self.vx = -self.vx*E
     if self.y >= height:
         return True
     if self.x <= 5:
         self.x = 6
         self.vx = abs(self.vx*E)
     if self.y <= 5:
         self.y = 6
         self.vy =  abs(self.vy*E)
         
     #Line interaction
     p0 = Vector(mouseX/10, mouseY/10)
     p1 = Vector(80 - mouseX/10, 60 - mouseY/10)
     be = Vector(self.x%80 + self.vx, self.y%60+ self.vy)
     bs = Vector(self.x%80, self.y%60)
     xblo = floor(self.x/80)
     yblo = floor(self.y/60)   
     temp = p0 - p1
     n = Vector(-temp.Y(),temp.X())   
     
     #No collision case
     if n.le() == 0:
         self.x += self.vx
         self.y += self.vy
         return
     
     n = n*(1/n.le())
     v = Vector(self.vx,self.vy) 
     d = self.R
     
     #if n.dotp(bs) - n.dotp(p0) < 0: #This is test code for preventing the ball from going through moving lines
         #d = -d
         
     t = (n.dotp(p0) - n.dotp(bs)) / n.dotp(v) #+d?
     #t2 = (n.dotp(p0) - n.dotp(bs)) / n.dotp(v) #+d?
     bi = bs + v*t
     #bi2 = bs + v*t2    
     
     q = bi - p0
     r = bi - p1
     d0 = (p0 - bi).le()
     d1 = (p1 - bi).le()
     
     #Another collision check
     if q.dotp(r)> 0 or (t<0 or t>1):
         self.x += self.vx
         self.y += self.vy
         return
     
     """ #Further line movement collision testing
     if (t<0 or t>1):
         if not (d0<self.R or d1<self.R):
             self.x += self.vx
             self.y += self.vy
             print("b")
             return
         else:
             print("a")
     """
     
     i = be - bi
     s = i.dotp(n) * n
     u = i-2*s
     bep = u + bi
     nv = u* (1 / u.le())
     speed = v.le()
     self.vx = nv.X()*speed*.95 #This slows it down a little
     self.vy = nv.Y()*speed*.95 #This slows it down a little
     self.x = bep.X() + xblo*80
     self.y = bep.Y() + yblo*60
     
     
     
     
     
     #VVVVVVVVV Old collision CODE DON"T UNCOMMENT ANY OF THIS VVVVVVV
     # Checks for Line interaction   
     #TF LOCAL COORDS
     #NEED FOR LOOP CHECKING FOR MORE THAN JUST ONE INTERACTION
     """
開發者ID:morirete,項目名稱:CS167pgame,代碼行數:90,代碼來源:Ball.py


注:本文中的Vector.le方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。