当前位置:   article > 正文

Python快速实现简易飞机大战小游戏(完整源码+图片素材)_python飞机大战素材

python飞机大战素材

       在今天的数字时代,计算机游戏一直是人们娱乐和放松的一种重要方式。而作为程序员或编程爱好者,将自己的创意融入游戏开发中,不仅可以带来乐趣,还可以提高编程技能。本文将带您走进游戏开发的精彩世界,通过使用 Python 编程语言,快速创建一个简单的飞机大战小游戏,仅供娱乐。

以下为相关素材图片:

敌机图片:

我方飞机:

子弹:

背景图:

完整源码如下:

主函数代码main.py:

  1. from PySide2 import QtCore, QtWidgets, QtGui
  2. from settings import Settings
  3. from map import Map
  4. from hero import Hero
  5. from enemy import Enemy
  6. from random import randint
  7. class MainScene(QtWidgets.QWidget):
  8. def __init__(self):
  9. super().__init__()
  10. self.settings = Settings()
  11. self.setWindowTitle(self.settings.game_title)
  12. self.setWindowIcon(QtGui.QIcon(self.settings.game_ico))
  13. self.setFixedSize(self.settings.game_width, self.settings.game_height)
  14. self.map = Map() # 构造一个地图对象
  15. self.hero = Hero() # 构造一个英雄对象
  16. # 初始化敌机
  17. self.enemys = []
  18. self.enemy_interval = 0
  19. for i in range(self.settings.enemy_num):
  20. self.enemys.append(Enemy())
  21. self.timer_main = QtCore.QTimer(self)
  22. self.timer_main.setInterval(20)
  23. self.timer_main.timeout.connect(self.run)
  24. self.timer_main.start()
  25. self.presskeys = []
  26. self.timer_key = QtCore.QTimer(self)
  27. self.timer_key.setInterval(50)
  28. self.timer_key.timeout.connect(self.handleKey)
  29. def enemyToScene(self):
  30. self.enemy_interval += 1
  31. if self.enemy_interval < 30:
  32. return
  33. self.enemy_interval = 0
  34. for i in range(self.settings.enemy_num):
  35. if self.enemys[i].free:
  36. self.enemys[i].free = False
  37. self.enemys[i].x = randint(0, self.settings.game_width-self.enemys[i].img.width())
  38. self.enemys[i].y = -self.enemys[i].img.height()
  39. break
  40. def collisionDetect(self):
  41. for i in range(self.settings.enemy_num):
  42. if self.enemys[i].free:
  43. continue
  44. for j in range(self.settings.bullet_num):
  45. if self.hero.bullets[j].free:
  46. continue
  47. if self.enemys[i].rect.intersects(self.hero.bullets[j].rect):
  48. self.enemys[i].free = True
  49. self.hero.bullets[j].free = True
  50. def handleKey(self):
  51. x = self.hero.x
  52. y = self.hero.y
  53. if self.presskeys.count(QtCore.Qt.Key_Left) > 0:
  54. x -= self.hero.speed
  55. if self.presskeys.count(QtCore.Qt.Key_Right) > 0:
  56. x += self.hero.speed
  57. if self.presskeys.count(QtCore.Qt.Key_Space) > 0:
  58. self.hero.shoot()
  59. if self.presskeys.count(QtCore.Qt.Key_Q) > 0:
  60. self.close()
  61. self.hero.move(x, y)
  62. def keyPressEvent(self, event):
  63. '''按键按下时,自动调用此函数'''
  64. self.presskeys.append(event.key())
  65. if not self.timer_key.isActive():
  66. self.timer_key.start()
  67. def keyReleaseEvent(self, event):
  68. '''松开按键时,自动调用'''
  69. if self.timer_key.isActive() and len(self.presskeys) == 0:
  70. self.timer_key.stop()
  71. self.handleKey()
  72. while event.key() in self.presskeys:
  73. self.presskeys.remove(event.key())
  74. def updatePosition(self):
  75. self.map.move()
  76. '''更新子弹的位置'''
  77. for i in range(self.settings.bullet_num):
  78. if not self.hero.bullets[i].free:
  79. self.hero.bullets[i].move()
  80. '''更新敌机位置'''
  81. for i in range(self.settings.enemy_num):
  82. if not self.enemys[i].free:
  83. self.enemys[i].move()
  84. def run(self):
  85. self.enemyToScene()
  86. self.updatePosition()
  87. self.update()
  88. self.collisionDetect()
  89. def paintEvent(self, event):
  90. painter = QtGui.QPainter(self)
  91. painter.drawPixmap(0, self.map.y1, self.map.img1)
  92. painter.drawPixmap(0, self.map.y2, self.map.img2)
  93. painter.drawPixmap(self.hero.x, self.hero.y, self.hero.img)
  94. '''绘制子弹'''
  95. for i in range(self.settings.bullet_num):
  96. if not self.hero.bullets[i].free:
  97. painter.drawPixmap(self.hero.bullets[i].x, self.hero.bullets[i].y, self.hero.bullets[i].img)
  98. '''绘制敌机'''
  99. for i in range(self.settings.enemy_num):
  100. if not self.enemys[i].free:
  101. painter.drawPixmap(self.enemys[i].x, self.enemys[i].y, self.enemys[i].img)
  102. if __name__ == "__main__":
  103. app = QtWidgets.QApplication([])
  104. w = MainScene()
  105. w.show()
  106. app.exec_()

参数设定代码settings.py:

app.ico图片为游戏运行界面左上角图标,随便用那张图片都行,例如直接使用我方飞机图片重命名即可

  1. class Settings:
  2. def __init__(self):
  3. self.game_title = "python飞机大战"
  4. self.game_ico = r"D:\images\app.ico"
  5. self.game_width = 512
  6. self.game_height = 700
  7. self.map_path = r"D:\images\img_bg_level_2.png"
  8. self.map_speed = 2
  9. self.hero_path = r"D:\images\hero2.png"
  10. self.hero_speed = 20
  11. self.bullet_path = r"D:\images\bullet_11.png"
  12. self.bullet_speed = 10
  13. self.bullet_num = 10
  14. self.enemy_path = r"D:\images\img-plane_5.png"
  15. self.enemy_speed = 3
  16. self.enemy_num = 10

敌机代码enemy.py:

  1. from PySide2 import QtGui
  2. from settings import Settings
  3. class Enemy:
  4. def __init__(self):
  5. self.settings = Settings()
  6. self.img = QtGui.QPixmap(self.settings.enemy_path)
  7. self.rect = self.img.rect()
  8. self.x = 0
  9. self.y = 0
  10. self.free = True
  11. self.speed = self.settings.enemy_speed
  12. def move(self):
  13. if self.free:
  14. return
  15. self.y += self.speed
  16. self.rect.moveTo(self.x, self.y)
  17. if self.y >= self.settings.game_height:
  18. self.free = True

我方飞机代码hero.py:

  1. from PySide2 import QtGui
  2. from settings import Settings
  3. from bullet import Bullet
  4. class Hero:
  5. def __init__(self):
  6. self.settings = Settings()
  7. self.img = QtGui.QPixmap(self.settings.hero_path)
  8. self.x = self.settings.game_width*0.5 - self.img.width()*0.5
  9. self.y = self.settings.game_height - self.img.height()
  10. self.speed = self.settings.hero_speed
  11. # 创建一个弹夹,放入10颗子弹
  12. self.bullets = []
  13. for i in range(self.settings.bullet_num):
  14. self.bullets.append(Bullet())
  15. def move(self, x, y):
  16. '''飞机移动'''
  17. self.x = x
  18. self.y = y
  19. def shoot(self):
  20. '''飞机发射子弹,按空格键时,调用此函数'''
  21. for i in range(self.settings.bullet_num):
  22. if self.bullets[i].free:
  23. self.bullets[i].free = False
  24. self.bullets[i].x = self.x + self.img.width()*0.5 - self.bullets[i].img.width()*0.5
  25. self.bullets[i].y = self.y - 30
  26. break

地图代码map.py:

  1. from PySide2 import QtGui
  2. from settings import Settings
  3. class Map:
  4. def __init__(self):
  5. self.settings = Settings()
  6. self.img1 = QtGui.QPixmap(self.settings.map_path)
  7. self.img2 = QtGui.QPixmap(self.settings.map_path)
  8. self.y1 = -self.settings.game_height
  9. self.y2 = 0
  10. def move(self):
  11. self.y1 += self.settings.map_speed
  12. if self.y1 >= 0:
  13. self.y1 = -self.settings.game_height
  14. self.y2 += self.settings.map_speed
  15. if self.y2 >= self.settings.game_height:
  16. self.y2 = 0

子弹代码bullet.py:

  1. from PySide2 import QtGui
  2. from settings import Settings
  3. class Bullet:
  4. def __init__(self):
  5. self.settings = Settings()
  6. self.img = QtGui.QPixmap(self.settings.bullet_path)
  7. self.rect = self.img.rect()
  8. self.speed = self.settings.bullet_speed
  9. self.x = 0
  10. self.y = 0
  11. self.free = True
  12. def move(self):
  13. if self.free:
  14. return
  15. self.y -= self.speed
  16. self.rect.moveTo(self.x, self.y)
  17. if self.y <= -self.rect.height():
  18. self.free = True

运行方式:运行main.py即可

注意点一:

如果直接用文章中的背景图保存到本地后运行代码,运行结果如下:

 于是自己替换了背景图片,和样例中的背景图调整像素到了一样大小:512x768(游戏界面参数设定是512和700,背景图大小有差别不影响,自己觉得可以就行):

 

 替换背景后运行结果如下:

运行结果视频展示(方向键左右移动,空格射击):

20221011_182548

注意点二:

需要安装Pyside2依赖库,直接pip install Pyside2即可,如果出现

qt.qpa.plugin: Could not load the Qt platform plugin "windows" in "" even though it was found.
This application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem.

Available platform plugins are: minimal, offscreen, windows.错误

参照以下方法解决

关于qt.qpa.plugin: Could not load the Qt platform plugin “windows“ in ““ even though it was found.问题_ASS-ASH的博客-CSDN博客

参考:用python实现简单的飞机大战小游戏_化华桦的博客-CSDN博客_python飞机大战

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/394432?site=
推荐阅读
相关标签
  

闽ICP备14008679号