pygame事件之——控制物体(飞机)的移动
近来想用pygame做做游戏,在 xishui 大神的目光博客中学了学这东西,就上一段自己写的飞机大战的代码,主要是对键盘控制飞机的移动做了相关的优化
# -*- coding: utf-8 -*- import pygame
from pygame.locals import *
import sys
import time pygame.init()
screen_width = 640
screen_height = 480
# 设置游戏窗口的大小
screen = pygame.display.set_mode((screen_width,screen_height), 0, 32)
pygame.display.set_caption('飞机大战')
image = 'feiji.png'
mv_image = pygame.image.load(image) # 获取飞机的长度
mv_image_width = mv_image.get_width() # 获取飞机的宽度
mv_image_height = mv_image.get_height() # 飞机的起始位置,应该在下面的正中间
x, y = screen_width/2-mv_image_width/2, screen_height-mv_image_height # 标记1
# 飞机的移动偏移量,每个方向设置一个
move_a, move_d, move_w, move_s = 0, 0, 0, 0 while True:
for event in pygame.event.get():
if event.type == QUIT:
sys.exit()
elif event.type == KEYDOWN:
if event.key == K_a or event.key == K_LEFT:
move_a = 1
elif event.key == K_d or event.key == K_RIGHT:
move_d = 1
elif event.key == K_UP or event.key == K_w:
move_w = 1
elif event.key == K_DOWN or event.key == K_s:
move_s = 1
elif event.type == KEYUP:
# 某一个方向的键盘被松开,这个方向的偏移量赋为0
if event.key == K_a or event.key == K_LEFT:
move_a = 0
elif event.key == K_d or event.key == K_RIGHT:
move_d = 0
elif event.key == K_UP or event.key == K_w:
move_w = 0
elif event.key == K_DOWN or event.key == K_s:
move_s = 0 # 按下键盘时,飞机对应的移动偏移量会变成1,飞机的位置进行相应的加减操作,刷新显示来控制飞机的移动
# 如果一直按住键盘不动,飞机对应的移动偏移量就会一直为1,飞机的位置就会随着while的不断循环而改变 # 飞机移动后的位置
x = x + move_d - move_a
y = y + move_s - move_w
# 标记2
# 控制飞机的范围,不能超出屏幕,还要考虑到子弹应该能够发射到任意一个地方
# 左右边界飞机应该可以进入一半
if x > screen_width-mv_image_width/2:
x = screen_width-mv_image_width/2
elif x < 0-mv_image_width/2:
x = 0-mv_image_width/2
# 下边界的话能够看到飞机头部就行
if y > screen_height-mv_image_height/5:
y = screen_height-mv_image_height/5
# 上边界不允许飞机进入
elif y < 0:
y = 0 # 填充背景颜色以RGB形式
screen.fill((255, 255, 255))
# 在新的位置上画图
screen.blit(mv_image, (x, y))
pygame.display.update()
# 减少CPU负担,测试后感觉这个数值最恰当
time.sleep(0.001)
在这里,飞机的偏移量之所以设置四个而不是两个,是因为如果设置的是两个,即控制x和y轴,那么飞机控制的方向只能是x轴或y轴,
就比如说,当按住a键的时候,飞机往左移动,此时不松开a键而继续按住d键,飞机就会停止往左移动转而向右移动,这里明显是不对的,我们目标应该是同时按住a键和d键时飞机停止移动,
紧接着,松开d键,此时飞机却不动了,但我们的a键此时还按着呢,他不是应该向左边移动吗?
所以用四个偏移量控制飞机的移动,各个方向互不影响,才能让飞机顺利的移动。
下面是飞机用两个偏移量时的代码
# 标记1
move_x, move_y = 0, 0
while True:
for event in pygame.event.get():
if event.type == QUIT:
exit()
if event.type == KEYDOWN:
if event.key == K_a or event.key == K_LEFT:
move_x = -1
elif event.key == K_d or event.key == K_RIGHT:
move_x = 1
elif event.key == K_UP or event.key == K_w:
move_y = -1
elif event.key == K_DOWN or event.key == K_s:
move_y = 1
elif event.type == KEYUP:
# 如果用户放开了键盘,图就不要动了
move_x = 0
move_y = 0
# 计算出新的坐标
x += move_x
y += move_y
# 标记2
需要的图片feiji.png,纯手工绘,不好看莫怪
如果还想做一个更酷的效果(其实也不怎么酷啦),比如游戏开始时飞机不是直接出现在屏幕上,而是缓缓的从下方移动到开始位置。
代码如下:
# 使游戏开始时飞机缓缓到达战场
y1 = screen_height
while True:
if y1 <= y:
break
screen.fill((255, 255, 255))
screen.blit(mv_image, (x, y1))
pygame.display.update()
y1 -= 1
# 每0.01秒前进一步
time.sleep(0.01)
这段代码插入到#标记1的前面

pygame事件之——控制物体(飞机)的移动的更多相关文章
- iOS_2_button控制物体形变
终于效果图: BeyondViewController.h // // BeyondViewController.h // 02_button控制物体形变 // // Created by beyon ...
- [Silverlight 2.0 控制物体绕圆弧运行(C#初探篇)]
我自己写的第一个 Silverlight 2.0 程序 [Silverlight 2.0 控制物体绕圆弧运行(C#初探篇)] 程序运行时:小地球将绕着圆形轨迹做圆周运动. ...
- Android_(游戏)打飞机03:控制玩家飞机
(游戏)打飞机01:前言 传送门 (游戏)打飞机02:游戏背景滚动 传送门 (游戏)打飞机03:控制玩家飞机 传送门 (游戏)打飞机04:绘画敌机.添加子弹 传送门 (游戏)打飞机05:处理子弹, ...
- js键盘事件全面控制详解
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件 ...
- Maya 脚本控制物体自转
在Maya中,我们可以用脚本来控制物体的自转方向,速度等等,步骤如下: 选择需要操作的物体object,打开通道盒Channel Box,点击编辑Edit,打开表达式Expressions面板 选择需 ...
- 【python游戏编程之旅】第三篇---pygame事件与设备轮询
本系列博客介绍以python+pygame库进行小游戏的开发.有写的不对之处还望各位海涵. 在上一篇博客中,我们学习了pygame中的IO.数据http://www.cnblogs.com/msxh/ ...
- Unity3D 几个基本动画(控制物体移动、旋转、缩放)
Transform基本移动函数: 1.指定方向移动: //移动速度 float TranslateSpeed = 10f; //Vector3.forward 表示"向前" tra ...
- js键盘事件全面控制
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...
- js键盘事件全面控制详解【转】
js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...
随机推荐
- angular2 实现的小项目
之前根据官网的demo做了一个小例子,将的都比较基本,为了更好的提高对angular的认知,又做了一个小例子,目前还不完善.主要有路由,http,组件之间的通信,服务等基本知识. 项目地址:https ...
- 平衡树(Splay)模板
支持区间操作. 单点操作和区间操作分开使用,需要一起使用需要部分修改. 对应题目FJUTOJ2490 #include<cstdio> #include<cstring> #i ...
- kill 掉所有正在运行的hadoop jobs
# get list of job's process IDs JOB_LIST=$(hadoop job -list 2> /dev/null | grep job_ | awk '{prin ...
- 大数据(3):基于sogou.500w.utf8数据Hbase和Spark实践
1. HBase安装部署操作 a) 解压HBase安装包tar –zxvf hbase-0.98.0-hadoop2-bin.tar.gzb) 修改环境变量 hbase-env.shexport JA ...
- gradle build docker image
前言:其实gradle-docker插件干的事和我们手动制作镜像是一样的,只不过它封装了一些步骤而已. eg:如果我们要将项目打包成镜像,首先我们要写Dockerfile,这是制作镜像的不可或缺的第一 ...
- Jquery EasyUI datagrid 的一些问题
在使用 Easy UI datagrid时 出现了一下小问题: table 中 有数据,但是 没有标题行名..在其他页面同样使用了datagrid 但是没有这样问题. 仔细检查了js代码,确认无误后 ...
- IPFS网络是如何运行的(p2p网络)
IPFS是一个p2p网络,先来看看BitTorrent的p2p网络是如何工作的? 想要bt下载一个文件,首先你需要一个种子文件torrent,种子文件包含至少一个 Tracker(一台服务器地址)信息 ...
- Knowledge point
静态网页的特点:以htm.html.sbtml.xml.js.css等为后缀扩展名. 1)程序在客户浏览器端解析,不需要读取数据库,性能和效率较高: 2)后端没有数据库支持,所以和用户的交互性差,功能 ...
- SQL server 2008 安装提示:属性不匹配
问题 安装SQL server 2008提示属性不匹配 解决方案 确保C盘以及其子文件夹C:\Program Files\Microsoft SQL Server和C:\Program Files ( ...
- 【jQuery】 JQ和AJAX
AJAX AJAX全称异步 JavaScript 和 XML(Asynchronous JavaScript and XML),是一种用于网页前端和网站后台进行数据交互的手段.关于AJAX的详细介绍在 ...