- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我知道已经有其他关于此的帖子,但我的运动系统与我发现的那些有一点不同,所以后来我问了这个问题。
我的移动系统基于名为 Move(up,left,right,down)
的命名元组然后是这个:
def update(self, move, blocks):
# check if we can jump
if move.up and self.on_ground:
self.yvel -= self.jump_speed
# simple left/right movement
if move.left:
self.xvel = -self.move_speed
if move.right:
self.xvel = self.move_speed
# if in the air, fall down
if not self.on_ground:
self.yvel += 0.3
# but not too fast
if self.yvel > max_gravity: self.yvel = max_gravity
# if no left/right movement, x speed is 0, of course
if not (move.left or move.right):
self.xvel = 0
# move horizontal, and check for horizontal collisions
self.rect.left += self.xvel
self.collide(self.xvel, 0, blocks)
# move vertically, and check for vertical collisions
self.rect.top += self.yvel
self.on_ground = False
self.collide(0, self.yvel, blocks)
def collide(self, xvel, yvel, blocks):
# all blocks that we collide with
for block in [blocks[i] for i in self.rect.collidelistall(blocks)]:
# if xvel is > 0, we know our right side bumped
# into the left side of a block etc.
if xvel > 0:
self.rect.right = block.rect.left;self.xvel=0
if xvel < 0:
self.rect.left = block.rect.right;self.xvel=0
# if yvel > 0, we are falling, so if a collision happpens
# we know we hit the ground (remember, we seperated checking for
# horizontal and vertical collision, so if yvel != 0, xvel is 0)
if yvel > 0:
self.rect.bottom = block.rect.top
self.on_ground = True
self.yvel = 0
# if yvel < 0 and a collision occurs, we bumped our head
# on a block above us
if yvel < 0: self.rect.top = block.rect.bottom;self.yvel=0
我尝试将第五个变量添加到名为 upUp
的元组中,当调用它时它会触发另一个跳转,无论 on_ground
是否为真。
为了触发它,我在事件循环中使用了这个:
if e.type==KEYUP:
if dj==0:
dj=-1
if dj=-1:
dj='true'
Move(K_w,K_a,K_d,K_s,dj)
但这根本行不通!有人有什么建议吗?
最佳答案
您必须保持某种状态以跟踪您所处的跳跃“阶段”。
这些“阶段”是:
所以你应该能够做这样的事情:
def update(self, move, blocks):
if self.on_ground:
self.jump_state = 'on_ground'
if move.up and self.on_ground:
# jump!
self.yvel -= self.jump_speed
self.jump_state = 'jumped'
if self.jump_state = 'jumped' and not move.up and not self.on_ground:
self.jump_state = 'ready_for_double_jump'
if self.jump_state = 'ready_for_double_jump' and move.up:
# jump!
self.yvel -= self.jump_speed
self.jump_state = 'double_jumped'
...
你会明白的。
关于python - Pygame:谁能帮我实现双跳?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20610845/
我正在尝试使用 nx 在图中找到一些特定节点(比方说 l 节点)的 1 跳、2 跳,如果需要,k 跳邻居。 single_source_dijkstra_path_length. 每个步骤的时间复杂度
假设在下一段中我的光标位于第一句中的第一个are上(希望我可以突出显示它,但我不能这样...... )。按两次 ff 后,第一句话就会傻瓜,然后of 。再按下去我将一事无成。 Some people
给定一个无向图,一个起始顶点和一个结束顶点。求出从源到汇的步行次数(这样一个顶点可以被多次访问)正好涉及 h 跳。例如,如果图形是三角形,则具有 h 跳的此类路径的数量由第 h 个 Jakobstah
我正在制作 Winston Wolf 的交互式 map 。我有一张世界地图,每个大陆都可以点击并显示该大陆的国家。当我点击非洲大陆时,页面会跳转到非洲国家(如您所料)。我的问题是,我可以阻止它跳跃吗?
这是我的第一个问题,所以如果我问错了,我很抱歉。 在我的实验中,多个 android 设备使用 WiFi Direct 连接。为了利用无线 tx 的广播特性,所有设备都加入一个多播组来交换它们的信息。
我最近开发了一个 WCF Facade 服务。我是 WCF 的新手,无法理解安全实现部分。 服务如下: 一个 asp.net 公共(public)网站有一个 WCF 客户端,它访问: DMZ 中的 W
序言: 当问楼梯问题时,通常给定的允许步幅数组是 [1,2,3] 在 SO 上看到很多相同问题的例子,比如 n-steps-with-1-2-or-3-steps-taken-how-many-way
我是一名优秀的程序员,十分优秀!