近来想用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事件之——控制物体(飞机)的移动的更多相关文章

  1. iOS_2_button控制物体形变

    终于效果图: BeyondViewController.h // // BeyondViewController.h // 02_button控制物体形变 // // Created by beyon ...

  2. [Silverlight 2.0 控制物体绕圆弧运行(C#初探篇)]

    我自己写的第一个 Silverlight 2.0 程序    [Silverlight 2.0 控制物体绕圆弧运行(C#初探篇)]            程序运行时:小地球将绕着圆形轨迹做圆周运动. ...

  3. Android_(游戏)打飞机03:控制玩家飞机

    (游戏)打飞机01:前言 传送门 (游戏)打飞机02:游戏背景滚动 传送门 (游戏)打飞机03:控制玩家飞机 传送门 (游戏)打飞机04:绘画敌机.添加子弹   传送门 (游戏)打飞机05:处理子弹, ...

  4. js键盘事件全面控制详解

      js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件 ...

  5. Maya 脚本控制物体自转

    在Maya中,我们可以用脚本来控制物体的自转方向,速度等等,步骤如下: 选择需要操作的物体object,打开通道盒Channel Box,点击编辑Edit,打开表达式Expressions面板 选择需 ...

  6. 【python游戏编程之旅】第三篇---pygame事件与设备轮询

    本系列博客介绍以python+pygame库进行小游戏的开发.有写的不对之处还望各位海涵. 在上一篇博客中,我们学习了pygame中的IO.数据http://www.cnblogs.com/msxh/ ...

  7. Unity3D 几个基本动画(控制物体移动、旋转、缩放)

    Transform基本移动函数: 1.指定方向移动: //移动速度 float TranslateSpeed = 10f; //Vector3.forward 表示"向前" tra ...

  8. js键盘事件全面控制

    js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...

  9. js键盘事件全面控制详解【转】

    js键盘事件全面控制 主要分四个部分第一部分:浏览器的按键事件第二部分:兼容浏览器第三部分:代码实现和优化第四部分:总结 第一部分:浏览器的按键事件 用js实现键盘记录,要关注浏览器的三种按键事件类型 ...

随机推荐

  1. myeclipse设置环境(最实用的教程)

    1. General --> Workspace --> UTF-82. General --> Editors --> Associations --> JSP --& ...

  2. 原生jdbc操作mysql数据库详解

    首先给大家说一下使用JDBC链接数据库的步骤 1.加载链接数据库驱动 2.建立数据库链接 3.创建数据库操作对象 4.编写sql语句,执行sql语句 5.获取结果集 6.释放资源 我这边采用的是mav ...

  3. 利用XAMPP本地搭建WordPress博客

    现在越来越多的人利用WordPress搭建了自己的博客网站,我也是一样,但是还有一些人不知道怎么搭建WordPress网站的方法,因为怕弄 不好,所以也就没有花钱去做,所以这里我就讲讲怎么样利用XAM ...

  4. 关于del命令

    del命令用于删除具体的文件,但是删除文件的时候如果不指定文件的扩展名就会显示找不到文件 还有如果所要删除文件的文件名中含有空格的话该命令会自动识别为几个文件,就从空格处把文件 分成几份,然后就会显示 ...

  5. 序列化、反序列化(Serializable特性)

    //需要被实例化的类 using System.Collections; using UnityEngine; [Serializable] public class SerializableClas ...

  6. Facebook兆级别图片存储及每秒百万级别图片查询原理

    前言 Facebook(后面简称fb)是世界最大的社交平台,需要存储的数据时刻都在不断剧增(占比最大为图片,每天存储约20亿张,大概是微信的三倍). 那么问题来了,fb是如何存储兆级别的图片?并且又是 ...

  7. .net core实现redisClient

    引言 最近工作上有需要使用redis,于是便心血来潮打算自己写一个C#客户端.经过几天的努力,目前该客户端已经基本成型,下面简单介绍一下. 通信协议 要想自行实现redisClient,则必须先要了解 ...

  8. 在 Scale Up 中使用 Health Check - 每天5分钟玩转 Docker 容器技术(145)

    对于多副本应用,当执行 Scale Up 操作时,新副本会作为 backend 被添加到 Service 的负责均衡中,与已有副本一起处理客户的请求.考虑到应用启动通常都需要一个准备阶段,比如加载缓存 ...

  9. extract-text-webpack-plugin---webpack插件

    var ExtractTextPlugin=require('extract-text-webpack-plugin');//build使用 { test:/\.css$/, use:ExtractT ...

  10. Oracle 12c(12.1.0.5)OEM server agent 安装配置

    注意: 此文档为生产上操作文档,省略了IP,oracle用户server,agent 端至少需要sudo,ping,ssh,创建目录权限. 一.安装要求 1.1. 系统情况一览 IP 数据库 OEM ...