最近开始学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. eclipse 配置多个jdk(jre)

      eclipse 配置多个jdk(jre) CreateTime--2018年4月24日08:57:40 Author:Marydon 1.打开设置窗口 输入jre 2.点击"Add... ...

  2. python之函数用法id(),了解即可

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #python之函数用法id(),了解即可 #http://www.cnblogs.com/hongfei/p ...

  3. Windows客户端的JProfiler远程监控Linux上的Tomcat

    1.测试环境 服务器:RedHat Linux 3.4.3-9.EL4(内核版本 2.6.9-5.EL),Tomcat5.5.20,Sun JDK 1.5.0_09,JProfiler 4.3.2 f ...

  4. SSO之CAS + LDAP

    本来主要详细是介绍CAS和LDAP整合实现单点登录的步骤. 1. 依<SSO之安装CAS Server>所述安装好CAS Server.2. 安装ApacheDS.安装好ApacheDS后 ...

  5. 升级 asp.net core 1.1 到 2.0 preview

    Upgrading to .NET Core 2.0 Preview 1 更新 依赖的类库 改为 标准库 2 web app  更改 csproj 文件---升级版本 <PropertyGrou ...

  6. smack 4.1.2+openfire 3.10.2i

    openfire 和以往版本号配置没有多大差别就不具体介绍了,网上搜会有一大堆的图解 以下主要说一下smack 4.1.2 的开发使用,在网上看了好多文章包含stackoverflow的都没有4.1以 ...

  7. Linux下PHP5.5编译参数详解

    一.配置参数 ./configure --prefix=/data/app/php --with-config-file-path=/etc --with-mysql=/usr\ --with-mys ...

  8. 测试化工具XCTestCase

    layout: post title: "Xcode 7智能测试化工具XCTest学习" subtitle: "Xcode 7智能测试化工具XCTest学习" ...

  9. 【LeetCode】128. Longest Consecutive Sequence

    Longest Consecutive Sequence Given an unsorted array of integers, find the length of the longest con ...

  10. bootstrap table 插件 搜索

    以前用过easyui datagrid 每次搜索的时候调用datagrid构造方法 重新获取数据, 发现bootstrap-table 插件不行,只需要初始化一次, 以后每次搜索时,直接调用refre ...