最近开始学Python,感觉挺好玩的,既有脚本语言的灵活性,又有丰富的类库与面向对象的特点,开发起来很方便。

游戏的规则和乒乓球一样,如果妙蛙种子掉地上了就算输,你可以用蓝色的跷跷板弹它,使他不落到地面上。

Game Over后可按任意键继续游戏或选择退出。

代码如下:

 import sys, pygame
from random import *
from pygame.locals import *
from pygame.font import *
class MyPlayer(pygame.sprite.Sprite):
def __init__(self, image_file, location, speed):
pygame.sprite.Sprite.__init__(self)
self.image = pygame.image.load(image_file)
self.rect = self.image.get_rect()
self.rect.left, self.rect.top = location
self.speed = speed
self.status = True
def move(self):
self.rect = self.rect.move(self.speed)
if self.rect.left < or self.rect.right > width:
self.speed[] = -self.speed[]
if self.rect.top < :
self.speed[] = -self.speed[]
if self.rect.bottom > height:
#Game over
self.status = False
class Reflector(pygame.sprite.Sprite):
def __init__(self, image_file, location, speed):
pygame.sprite.Sprite.__init__(self)
self.image = pygame.image.load(image_file)
self.rect = self.image.get_rect()
self.rect.left, self.rect.top = location
self.speed = speed
def move(self):
self.rect = self.rect.move(self.speed)
if self.rect.left < or self.rect.right > width:
self.speed[] = -self.speed[]
if self.rect.top < or self.rect.bottom > height:
self.speed[] = -self.speed[]
def animate(players):
screen.fill([,,])
for player in players:
player.move()
for player in players:
players.remove(player)
if pygame.sprite.spritecollide(player,players,False):
player.speed[] = -player.speed[]
player.speed[] = -player.speed[]
players.add(player)
player.move()
screen.blit(player.image,player.rect)
pygame.display.flip()
pygame.time.delay() pygame.init()
size = width,height = ,
screen = pygame.display.set_mode(size)
screen.fill([,,])
pygame.display.set_caption("MiaoWa Game")
def play():
img_player = "C:\Users\dswu\Desktop\player.png"
players = pygame.sprite.Group()
for row in range(,):
for column in range(,):
playerLocation = [column*+,row*+]
playerSpeed = [choice([-,]), choice([-,])]
player = MyPlayer(img_player, playerLocation, playerSpeed)
players.add(player)
img_ref_path = "C:\Users\dswu\Desktop\Reflector.png"
ref_pos = [,]
ref_speed = [,]
reflector = Reflector(img_ref_path, ref_pos, ref_speed)
players.add(reflector)
running = True
while running:
key_pressed = pygame.key.get_pressed()
for event in pygame.event.get():
if event.type == pygame.QUIT:
game.quit()
if event.type == KEYDOWN:
if event.key == K_LEFT:
ref_speed[] = -
elif event.key == K_RIGHT:
ref_speed[] = +
animate(players)
if player.status == False:
running = False
final_text = "Game Over!"
ft_font = pygame.font.Font(None, )
ft_surf = ft_font.render(final_text, , (,,))
screen.blit(ft_surf, [screen.get_width()/ - ft_surf.get_width()/, ])
tip_text = "Type any key to continue"
tip_font = pygame.font.Font(None, )
tip_surf = tip_font.render(tip_text, , (,,))
screen.blit(tip_surf, [screen.get_width()/ - tip_surf.get_width()/, ])
pygame.display.flip()
keepOn = True
while keepOn:
key_pressed = pygame.key.get_pressed()
for event in pygame.event.get():
if event.type == pygame.QUIT:
pygame.quit()
if event.type == KEYDOWN:
play()
play()

主要是通过pygame.sprite.Sprite类实现碰撞的监控,通过事件的捕捉及判断实现这种弹力球类的游戏,其中涉及到文字在界面上的显示,游戏中的循环控制,以及重新开始游戏等。

把上面这段代码贴到你的IDLE中,找到下面这两行替换成你机器中的图片路径,按F5就可以运行了。

img_player = "C:\Users\dswu\Desktop\player.png"
img_ref_path = "C:\Users\dswu\Desktop\Reflector.png"

由于比较简单,看看代码运行一下应该就差不多明白了,如果有不明白的地方请给我留言,方便一起学习与进步。

平时都在线,欢迎交流。

Version2,增加score计分功能,结构有改动:

import sys, pygame
from random import *
from pygame.locals import *
from pygame.font import *
class MyPlayer(pygame.sprite.Sprite):
def __init__(self, image_file, location, speed):
pygame.sprite.Sprite.__init__(self)
self.image = pygame.image.load(image_file)
self.rect = self.image.get_rect()
self.rect.left, self.rect.top = location
self.speed = speed
self.status = True
def move(self):
global score, score_font, score_surf
self.rect = self.rect.move(self.speed)
if self.rect.left < or self.rect.right > width:
self.speed[] = -self.speed[]
if self.rect.top < :
self.speed[] = -self.speed[]
score = score +
score_surf = score_font.render(str(score),,(,,))
if self.rect.bottom > height:
#Game over
self.status = False
class Reflector(pygame.sprite.Sprite):
def __init__(self, image_file, location, speed):
pygame.sprite.Sprite.__init__(self)
self.image = pygame.image.load(image_file)
self.rect = self.image.get_rect()
self.rect.left, self.rect.top = location
self.speed = speed
def move(self):
self.rect = self.rect.move(self.speed)
if self.rect.left < or self.rect.right > width:
self.speed[] = -self.speed[]
if self.rect.top < or self.rect.bottom > height:
self.speed[] = -self.speed[]
def animate(players):
screen.fill([,,])
for player in players:
player.move()
for player in players:
players.remove(player)
if pygame.sprite.spritecollide(player,players,False):
player.speed[] = -player.speed[]
player.speed[] = -player.speed[]
players.add(player)
player.move()
screen.blit(player.image,player.rect)
pygame.display.flip()
pygame.time.delay()
def end():
#
final_text = "Game Over!"
ft_font = pygame.font.Font(None, )
ft_surf = ft_font.render(final_text, , (,,))
screen.blit(ft_surf, [screen.get_width()/ - ft_surf.get_width()/, ])
#
tip_text = "Type any key to continue"
tip_font = pygame.font.Font(None, )
tip_surf = tip_font.render(tip_text, , (,,))
screen.blit(tip_surf, [screen.get_width()/ - tip_surf.get_width()/, ])
#
sc_text = "Your score is "+ str(score)
sc_font = pygame.font.Font(None, )
sc_surf = sc_font.render(sc_text, , (,,))
screen.blit(sc_surf, [screen.get_width()/ - sc_surf.get_width()/, ])
pygame.display.flip()
pygame.init()
size = width,height = ,
screen = pygame.display.set_mode(size)
screen.fill([,,])
pygame.display.set_caption("MiaoWa Game")
score =
score_pos = [, ]
score_font = pygame.font.Font(None, )
score_surf = score_font.render(str(score),,(,,))
img_player = "C:\Users\dswu\Desktop\player.png"
playerSpeed = [choice([-,]), choice([-,])]
player = MyPlayer(img_player, [,], playerSpeed)
players = pygame.sprite.Group()
players.add(player)
img_ref_path = "C:\Users\dswu\Desktop\Reflector.png"
ref_pos = [,]
ref_speed = [,]
reflector = Reflector(img_ref_path, ref_pos, ref_speed)
players.add(reflector)
running = True
while running:
key_pressed = pygame.key.get_pressed()
for event in pygame.event.get():
if player.status == True:
if event.type == pygame.QUIT:
game.quit()
if event.type == KEYDOWN:
if event.key == K_LEFT:
ref_speed[] = -
elif event.key == K_RIGHT:
ref_speed[] = +
if player.status == False:
if event.type == pygame.QUIT:
pygame.quit()
if event.type == KEYDOWN:
player.rect.topleft = [,]
player.status = True
score =
score_surf = score_font.render(str(score),,(,,))
if player.status == True:
animate(players)
screen.blit(score_surf, score_pos)
pygame.display.flip()
if player.status == False:
end()

Python中写一个乒乓球类的游戏的更多相关文章

  1. python Tkinter 写一个弹球的小游戏

    #!usr/bin/python #-*- coding:utf-8 -*- from Tkinter import * import Tkinter import random import tim ...

  2. Python 中写一个装饰器实现限制频率访问

    1.思路: 首先要在装饰器中确定访问的方法名, 第一次可以访问成功,之后要在规定的时间(变量)之后才可以访问. 初始应该有一个变量为0;访问成功之后把当前的时间赋值给这个变零. 这样再次访问时把当前的 ...

  3. 【Filter 不登陆无法访问】web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面的功能

    在web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面,而重定向到登陆界面的功能. 项目是用springMVC+spring+hibernate实现 (和这个没有多大关系) 第一步: 首先 ...

  4. python中写shell(转)

    python中写shell,亲测可用,转自stackoverflow To run a bash script, copy from stackoverflow def run_script(scri ...

  5. python 之路,200行Python代码写了个打飞机游戏!

    早就知道pygame模块,就是没怎么深入研究过,恰逢这周未没约到妹子,只能自己在家玩自己啦,一时兴起,花了几个小时写了个打飞机程序. 很有意思,跟大家分享下. 先看一下项目结构 "" ...

  6. 转--python 中写单例

    原文地址 原文地址2 Python中的单例模式的几种实现方式的及优化 阅读目录(Content) 单例模式 实现单例模式的几种方式 1.使用模块 2.使用装饰器 3.使用类 4.基于__new__方法 ...

  7. 10分钟用scratch写一个大鱼吃小鱼的小游戏

    第一次给张江小朋友教Scratch课程之前,还在担心一些概念能不能向小朋友解释清楚,可上完课发现,我严重低估了小朋友的聪明程度,发现现在的孩子相比较自己8.9岁的时候,简直聪明太多倍了. 所以总结了半 ...

  8. Cocos2D iOS之旅:如何写一个敲地鼠游戏(九):创建动画

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...

  9. python中导入一个需要传参的模块

    最近跑实验,遇到了一个问题:由于实验数据集比较多,每次跑完一个数据集就需要手动更改文件路径,再将文件传到服务器,再运行实验,这样的话效率很低,必须要专门看着这个实验,啥时候跑完就手动修改运行下一个实验 ...

随机推荐

  1. hdu 4893 Wow! Such Sequence!(线段树)

    题目链接:hdu 4983 Wow! Such Sequence! 题目大意:就是三种操作 1 k d, 改动k的为值添加d 2 l r, 查询l到r的区间和 3 l r. 间l到r区间上的所以数变成 ...

  2. 错误:google-chrome-stable-44.0.2403.157-1.x86_64.rpm 的公钥没有安装

    错误:google-chrome-stable-44.0.2403.157-1.x86_64.rpm 的公钥没有安装 Fedora22 系统更新软件包.出现: warning: /var/cache/ ...

  3. 交叉编译OpenWrt 定制固件

    在Centos7上交叉编译生成OpenWrt固件 安装ss-* 获取最新的ss, 当前是 wget https://github.com/shadowsocks/shadowsocks-libev/a ...

  4. 用户研究Q&A(1)

    近来,不少同事开始认同用户研究的价值,希望通过接触,理解和研究用户来获取提升产品的有效信息.这绝对是件好事,因为我一直抱持的理念是,研究并不是藏在实验室或者握在少部分人手中的稀罕货,更重要是一种理念和 ...

  5. jquery 事件小事例

    用户名变灰 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> & ...

  6. [CXF REST标准实战系列] 一、JAXB xml与javaBean的转换(转)

    转自:[CXF REST标准实战系列] 一.JAXB xml与javaBean的转换 文章Points: 1.不认识到犯错,然后得到永久的教训. 2.认识JAXB 3.代码实战 1.不认识到犯错,然后 ...

  7. RCF库ClientStub.setAutoReconnect

    这个选项为false时,当连接断开时,第一次调用服务会抛出异常,而第二次调用时,也会自动连接.

  8. java配置使用手册

    进行java开发,首先要安装jdk,安装了jdk后还要进行环境变量配置: 1.下载jdk(http://java.sun.com/javase/downloads/index.jsp),我下载的版本是 ...

  9. 常见Web前端开发笔试题

    1.什么是web标准? WEB标准不是某一个标准,而是一系列标准的集合.网页主要由三部分组成:结构(Structure).表现(Presentation)和行为 (Behavior). 对应的标准也分 ...

  10. JMeter学习笔记--JMeter执行顺序规则

    JMeter执行顺序规则: 配置元件 前置处理器 定时器 采样器 后置处理器(除非服务器响应为空) 断言 监听器 只有当作用域内存在采样器时,定时器.断言.前置/后置处理器才会被执行,逻辑控制器和采样 ...