diff --git a/Plane_Fighting/README.md b/Plane_Fighting/README.md
index 9b6df51..2e4232f 100644
--- a/Plane_Fighting/README.md
+++ b/Plane_Fighting/README.md
@@ -1,6 +1,12 @@
-# Plane Fighting
-## 一个跨平台的简易"飞机大战"程序
-## 基于 Python & PyGame 运行
-## 图标库来自 IconFont
-## 相应的版权归作者所有
-## 本目录中其他所有的文件根据 GPL 3.0 协议开源
+# Plane Fighting (plane_fighting)
+## 简介
+一个跨平台的简易"飞机大战"小游戏
+## 支持
+基于Python & PyGame 运行
+可通过 Buildozer 打包为移动应用
+## 协议
+图标库(./images/)来自 IconFont
+音效库(./sound/)来自网络
+字体库(./font)来自 Ubuntu
+相应的版权归作者所有
+本目录中其他所有的源代码文件根据 GPL 3.0 协议开源
\ No newline at end of file
diff --git a/Plane_Fighting/__pycache__/bullet.cpython-310.pyc b/Plane_Fighting/__pycache__/bullet.cpython-310.pyc
deleted file mode 100644
index a6cbdfd..0000000
Binary files a/Plane_Fighting/__pycache__/bullet.cpython-310.pyc and /dev/null differ
diff --git a/Plane_Fighting/__pycache__/enemy.cpython-310.pyc b/Plane_Fighting/__pycache__/enemy.cpython-310.pyc
deleted file mode 100644
index bbe5c60..0000000
Binary files a/Plane_Fighting/__pycache__/enemy.cpython-310.pyc and /dev/null differ
diff --git a/Plane_Fighting/__pycache__/myplane.cpython-310.pyc b/Plane_Fighting/__pycache__/myplane.cpython-310.pyc
deleted file mode 100644
index e1a1836..0000000
Binary files a/Plane_Fighting/__pycache__/myplane.cpython-310.pyc and /dev/null differ
diff --git a/Plane_Fighting/__pycache__/supply.cpython-310.pyc b/Plane_Fighting/__pycache__/supply.cpython-310.pyc
deleted file mode 100644
index bfd325b..0000000
Binary files a/Plane_Fighting/__pycache__/supply.cpython-310.pyc and /dev/null differ
diff --git a/Plane_Fighting/buildozer.spec b/Plane_Fighting/buildozer.spec
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/bullet.py b/Plane_Fighting/bullet.py
old mode 100755
new mode 100644
index 84ff6c3..eeb6641
--- a/Plane_Fighting/bullet.py
+++ b/Plane_Fighting/bullet.py
@@ -1,4 +1,5 @@
import pygame,os
+
abspath = os.getcwd() + "/"
class Bullet1(pygame.sprite.Sprite):
def __init__(self, position):
diff --git a/Plane_Fighting/enemy.py b/Plane_Fighting/enemy.py
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/font/font-2.ttf b/Plane_Fighting/font/font-2.ttf
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/font/font.ttf b/Plane_Fighting/font/font.ttf
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/again.png b/Plane_Fighting/images/again.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/background.png b/Plane_Fighting/images/background.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/bomb.png b/Plane_Fighting/images/bomb.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/bomb_supply.png b/Plane_Fighting/images/bomb_supply.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/bullet1.png b/Plane_Fighting/images/bullet1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/bullet2.png b/Plane_Fighting/images/bullet2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/bullet_supply.png b/Plane_Fighting/images/bullet_supply.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy1.png b/Plane_Fighting/images/enemy1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy1_down1.png b/Plane_Fighting/images/enemy1_down1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy1_down2.png b/Plane_Fighting/images/enemy1_down2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy1_down3.png b/Plane_Fighting/images/enemy1_down3.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy1_down4.png b/Plane_Fighting/images/enemy1_down4.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy2.png b/Plane_Fighting/images/enemy2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy2_down1.png b/Plane_Fighting/images/enemy2_down1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy2_down2.png b/Plane_Fighting/images/enemy2_down2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy2_down3.png b/Plane_Fighting/images/enemy2_down3.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy2_down4.png b/Plane_Fighting/images/enemy2_down4.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy2_hit.png b/Plane_Fighting/images/enemy2_hit.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_down1.png b/Plane_Fighting/images/enemy3_down1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_down2.png b/Plane_Fighting/images/enemy3_down2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_down3.png b/Plane_Fighting/images/enemy3_down3.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_down4.png b/Plane_Fighting/images/enemy3_down4.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_down5.png b/Plane_Fighting/images/enemy3_down5.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_down6.png b/Plane_Fighting/images/enemy3_down6.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_hit.png b/Plane_Fighting/images/enemy3_hit.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_n1.png b/Plane_Fighting/images/enemy3_n1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/enemy3_n2.png b/Plane_Fighting/images/enemy3_n2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/gameover.png b/Plane_Fighting/images/gameover.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/icon.png b/Plane_Fighting/images/icon.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/life.png b/Plane_Fighting/images/life.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/loading.png b/Plane_Fighting/images/loading.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/me1.png b/Plane_Fighting/images/me1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/me2.png b/Plane_Fighting/images/me2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/me_destroy_1.png b/Plane_Fighting/images/me_destroy_1.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/me_destroy_2.png b/Plane_Fighting/images/me_destroy_2.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/me_destroy_3.png b/Plane_Fighting/images/me_destroy_3.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/me_destroy_4.png b/Plane_Fighting/images/me_destroy_4.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/pause_nor.png b/Plane_Fighting/images/pause_nor.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/pause_pressed.png b/Plane_Fighting/images/pause_pressed.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/resume_nor.png b/Plane_Fighting/images/resume_nor.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/images/resume_pressed.png b/Plane_Fighting/images/resume_pressed.png
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/main.py b/Plane_Fighting/main.py
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/myplane.py b/Plane_Fighting/myplane.py
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/pyinstaller.spec b/Plane_Fighting/pyinstaller.spec
old mode 100755
new mode 100644
index a180fab..2d2c17f
--- a/Plane_Fighting/pyinstaller.spec
+++ b/Plane_Fighting/pyinstaller.spec
@@ -4,10 +4,10 @@
block_cipher = None
-a = Analysis(['main.py'],
+a = Analysis(['main.py','bullet.py','enemy.py','myplane.py','supply.py'],
pathex=[],
- binaries=[(‘./images/*.png’, ‘images’)]
- datas=[],
+ binaries=[("font", "images", "sound")]
+ datas=["record.dat"],
hiddenimports=[],
hookspath=[],
hooksconfig={},
@@ -26,7 +26,7 @@ exe = EXE(pyz,
a.zipfiles,
a.datas,
[],
- name='main',
+ name='Plane Fighting',
debug=False,
bootloader_ignore_signals=False,
strip=False,
diff --git a/Plane_Fighting/record.dat b/Plane_Fighting/record.dat
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/bullet.wav b/Plane_Fighting/sound/bullet.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/button.wav b/Plane_Fighting/sound/button.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/enemy1_down.wav b/Plane_Fighting/sound/enemy1_down.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/enemy2_down.wav b/Plane_Fighting/sound/enemy2_down.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/enemy3_down.wav b/Plane_Fighting/sound/enemy3_down.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/enemy3_flying.wav b/Plane_Fighting/sound/enemy3_flying.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/game_music.ogg b/Plane_Fighting/sound/game_music.ogg
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/get_bomb.wav b/Plane_Fighting/sound/get_bomb.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/get_bullet.wav b/Plane_Fighting/sound/get_bullet.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/loading_game.ogg b/Plane_Fighting/sound/loading_game.ogg
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/me_down.wav b/Plane_Fighting/sound/me_down.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/supply.wav b/Plane_Fighting/sound/supply.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/upgrade.wav b/Plane_Fighting/sound/upgrade.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/sound/use_bomb.wav b/Plane_Fighting/sound/use_bomb.wav
old mode 100755
new mode 100644
diff --git a/Plane_Fighting/supply.py b/Plane_Fighting/supply.py
old mode 100755
new mode 100644
index 2720dca..70d7986
--- a/Plane_Fighting/supply.py
+++ b/Plane_Fighting/supply.py
@@ -1,11 +1,12 @@
-import pygame
+import pygame,os
from random import *
+abspath = os.getcwd() + "/"
class Bullet_Supply(pygame.sprite.Sprite):
def __init__(self, bg_size):
pygame.sprite.Sprite.__init__(self)
- self.image = pygame.image.load("images/bullet_supply.png").convert_alpha()
+ self.image = pygame.image.load(abspath + "images/bullet_supply.png").convert_alpha()
self.rect = self.image.get_rect()
self.width, self.height = bg_size[0], bg_size[1]
self.rect.left, self.rect.bottom = \
@@ -29,7 +30,7 @@ class Bomb_Supply(pygame.sprite.Sprite):
def __init__(self, bg_size):
pygame.sprite.Sprite.__init__(self)
- self.image = pygame.image.load("images/bomb_supply.png").convert_alpha()
+ self.image = pygame.image.load(abspath + "images/bomb_supply.png").convert_alpha()
self.rect = self.image.get_rect()
self.width, self.height = bg_size[0], bg_size[1]
self.rect.left, self.rect.bottom = \
diff --git a/README.md b/README.md
index 5bfbb3d..8cdbca9 100644
--- a/README.md
+++ b/README.md
@@ -1,2 +1,17 @@
-# 我的一些分散的代码文件
-# 主要用于通过 GitPod 在线编译
+# Tiny Project
+## 说明
+分散的代码文件
+一个文件夹代表一个小的代码集合
+不同文件夹所使用的开源协议不同
+有些工具虽然很小, 但却十分有用
+## 列表
+### 单目录 (root)
+|名称|路径|介绍|语言|
+|:---|:---|----|----|
+|LAN++|./lanpp|一个跨平台的简易局域网文件传输工具|Python|
+|Plane Fighting|./plane_fighting|一个跨平台的简易"飞机大战"小游戏|Python|
+|Python HTTPS Server|./python_https_server|一个 HTTPS 网络服务器程序|Python|
+### 单文件 (onefile)
+|文件名|介绍|语言|
+|----|----|----|
+|file_reader.cpp|输出文件内容至终端|C++|
\ No newline at end of file
diff --git a/lanpp/README.md b/lanpp/README.md
new file mode 100644
index 0000000..a8dff38
--- /dev/null
+++ b/lanpp/README.md
@@ -0,0 +1,10 @@
+# LAN++ (lanpp)
+## 简介
+一个跨平台的简易局域网文件传输工具
+## 支持
+基于 Python 语言编写
+底层依赖库: pyperclip & pyftpdlib
+UI 基于 Tkinter, 准备改写成 KivyMD
+将来可通过 Buildozer 打包为移动应用
+## 协议
+本目录中所有的源代码文件根据 GPL 3.0 协议开源
\ No newline at end of file
diff --git a/lanpp/ftpserver.py b/lanpp/ftpserver.py
new file mode 100644
index 0000000..031b46b
--- /dev/null
+++ b/lanpp/ftpserver.py
@@ -0,0 +1,21 @@
+# -*- coding: utf-8 -*-
+
+from pyftpdlib.handlers import FTPHandler
+from pyftpdlib.servers import FTPServer
+from pyftpdlib.authorizers import DummyAuthorizer
+import json
+def jsonget(key_name):
+ with open("setting.json") as f:
+ json_data = f.read()
+ data = json.loads(json_data)
+ f.close()
+ return data[key_name]
+def start():
+ authorizer = DummyAuthorizer()
+ authorizer.add_user(jsonget("ftpserveruser"), jsonget("ftpserverpass"), jsonget("ftpserverroot"), perm='elradfmwM')
+ handler = FTPHandler
+ handler.authorizer = authorizer
+ server = FTPServer(('localhost', int(jsonget("ftpserverport"))), handler)
+ server.serve_forever()
+if __name__ == '__main__':
+ start()
\ No newline at end of file
diff --git a/lanpp/main-gui.py b/lanpp/main-gui.py
new file mode 100644
index 0000000..7bb9df0
--- /dev/null
+++ b/lanpp/main-gui.py
@@ -0,0 +1,142 @@
+import pyperclip
+import ftpserver
+import os
+import json
+import sys
+import socket
+import webserver
+import webbrowser
+from tkinter import *
+from tkinter import messagebox
+from ttkthemes import *
+from tkinter.ttk import *
+from multiprocessing import Process
+
+def getip():
+ try:
+ s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
+ s.connect(('192.168.1.1', 0))
+ ip = s.getsockname()[0]
+ except:
+ ip = "localhost"
+ finally:
+ s.close()
+ return ip
+def jsonget(key_name):
+ with open("setting.json") as f:
+ json_data = f.read()
+ data = json.loads(json_data)
+ f.close()
+ return data[key_name]
+def webserver_ui():
+ if True :
+ #webserverui_status = 1
+ subwindow = ThemedTk(theme="yaru", toplevel=True, themebg=True)
+ subwindow.title("WebServer | LAN++ Manager")
+ subwindow.geometry("850x500")
+ os.chdir(static_path)
+ task = Process(target=webserver.start)
+ def start():
+ task.start()
+ print("started")
+ def __close__():
+ task.terminate()
+ os.chdir(static_path)
+ print("closed")
+ def close():
+ if task.is_alive() == False:
+ start()
+ __close__()
+ os.chdir(static_path)
+ subwindow.destroy()
+ def copylink():
+ pyperclip.copy("http://" + str(getip()) + ":" + jsonget("webserverport"))
+ ntext = " 点击按钮以控制[浏览器文件管理服务]\n [启动] - 启动服务\n [关闭窗口并退出] - 退出窗口(退出服务)\n [复制访问链接] - 复制链接以便访问服务" + '当前配置:\n 端口:' + jsonget("ftpserverport") + "\n 目录: " + jsonget("webserverroot") + "\n 打开服务后请用浏览器打开此链接以操作文件: [http://" + str(getip()) + ":" + jsonget("webserverport") + "]\n"
+ lbl1 = Label(subwindow, text=ntext)
+ lbl1.grid(column=1, row=1)
+ wtext = " 已知Bug:终止服务后,端口仍会占用一段时间,建议终止服务后一分钟后重新启动服务\n 注意:在不了解此程序文档时请勿打开多个相同服务,如需要,可在Wiki的[特技]一栏中找到方法."
+ lbl2 = Label(subwindow, text=wtext)
+ lbl2.grid(column=1, row=2)
+ start_btn = Button(subwindow, text="启动", command=start)
+ start_btn.grid(column=1, row=3)
+ close_btn = Button(subwindow, text="关闭窗口并退出", command=close)
+ close_btn.grid(column=1, row=4)
+ copy_btn = Button(subwindow, text="复制访问链接", command=copylink)
+ copy_btn.grid(column=1, row=5)
+ subwindow.protocol("WM_DELETE_WINDOW", close)
+ subwindow.mainloop()
+def ftpserver_ui():
+ if True :
+ #webserverui_status = 1
+ subwindow = ThemedTk(theme="yaru", toplevel=True, themebg=True)
+ subwindow.title("FTPServer | LAN++ Manager")
+ subwindow.geometry("850x500")
+ os.chdir(static_path)
+ task = Process(target=ftpserver.start)
+ def start():
+ task.start()
+ print("started")
+ def __close__():
+ task.terminate()
+ os.chdir(static_path)
+ print("closed")
+ def close():
+ if task.is_alive() == False:
+ start()
+ __close__()
+ os.chdir(static_path)
+ subwindow.destroy()
+ def copylink():
+ pyperclip.copy("ftp://" + jsonget("ftpserveruser") + "@" + str(getip()) + ":" + jsonget("ftpserverport"))
+ ntext = " 点击按钮以控制[FTP文件传输服务]\n [启动] - 启动服务\n [关闭窗口并退出] - 退出窗口(退出服务)\n [复制访问链接] - 复制链接以便访问服务" + '当前配置:\n 端口:' + jsonget("ftpserverport") + "\n 目录: " + jsonget("ftpserverroot") + "\n 用户名:" + jsonget("ftpserveruser") + "\n 密码:" + jsonget("ftpserverpass") + "\n 打开服务后请通过此链接连接FTP服务器: [ftp://" + jsonget("ftpserveruser") + "@" + str(getip()) + ":" + jsonget("ftpserverport") + "]"
+ lbl1 = Label(subwindow, text=ntext)
+ lbl1.grid(column=1, row=1)
+ wtext = " 已知Bug:终止服务后,端口仍会占用一段时间,建议终止服务后一分钟后重新启动服务\n 注意:在不了解此程序文档时请勿打开多个相同服务,如需要,可在Wiki的[特技]一栏中找到方法."
+ lbl2 = Label(subwindow, text=wtext)
+ lbl2.grid(column=1, row=2)
+ start_btn = Button(subwindow, text="启动", command=start)
+ start_btn.grid(column=1, row=3)
+ close_btn = Button(subwindow, text="关闭窗口并退出", command=close)
+ close_btn.grid(column=1, row=4)
+ copy_btn = Button(subwindow, text="复制访问链接", command=copylink)
+ copy_btn.grid(column=1, row=5)
+ subwindow.protocol("WM_DELETE_WINDOW", close)
+ subwindow.mainloop()
+def setting_ui():
+ pass
+def runexit():
+ sys.exit()
+def about_ui():
+ def visit():
+ webbrowser.open("http://github.com/david-ajax/LANPP", new=0)
+ subwindow = ThemedTk(theme="yaru", toplevel=True, themebg=True)
+ subwindow.title("About | LAN++")
+ subwindow.geometry("470x270")
+ ntext = " LAN++ -- A powerful tool for local area network \n Version: 1.0 (Beta) \n Repo: http://github.com/david-ajax/LANpp \n Powered By Wang Zhiyu \n Use GPL 3.0 License"
+ lbl1 = Label(subwindow, text=ntext)
+ lbl1.grid(column=1, row=1)
+ visit_btn = Button(subwindow, text="Visit The Repository", command=visit)
+ visit_btn.grid(column=1, row=2)
+ exit_btn = Button(subwindow, text="Exit", command=subwindow.destroy)
+ exit_btn.grid(column=1, row=3)
+def main():
+ window = ThemedTk(theme="yaru", toplevel=True, themebg=True)
+ window.title("LAN++ Manager")
+ window.geometry("800x200")
+ webserver = Button(window, text="浏览器文件管理服务", command=webserver_ui)
+ webserver.grid(column=0, row=2)
+ ftpserver = Button(window, text="FTP文件传输服务", command=ftpserver_ui)
+ ftpserver.grid(column=1, row=2)
+ setting = Button(window, text="设置", command=setting_ui)
+ setting.grid(column=2, row=2)
+ about = Button(window, text="关于", command=about_ui)
+ about.grid(column=3, row=2)
+ exit_btn = Button(window, text="退出", command=runexit)
+ exit_btn.grid(column=4, row=2)
+ window.mainloop()
+if __name__ == '__main__':
+ static_path = os.getcwd()
+ fw=Tk()
+ fw.withdraw()
+ messagebox.showinfo(title='Welcome',message='欢迎使用LAN++ Beta Edition')
+ main()
\ No newline at end of file
diff --git a/lanpp/setting.json b/lanpp/setting.json
new file mode 100644
index 0000000..6f30dc8
--- /dev/null
+++ b/lanpp/setting.json
@@ -0,0 +1,9 @@
+{
+ "webserverport": "8083",
+ "webserverroot": "/",
+ "ftpserverport": "8082",
+ "ftpserverroot": "/",
+ "ftpserveruser": "default",
+ "ftpserverpass": "000000",
+ "A Prompt For You": "Unless the program is not available,DO NOT EDIT THIS FILE"
+}
\ No newline at end of file
diff --git a/lanpp/webserver.py b/lanpp/webserver.py
new file mode 100644
index 0000000..484ed84
--- /dev/null
+++ b/lanpp/webserver.py
@@ -0,0 +1,326 @@
+#!/usr/bin/env python3
+
+"""
+Powered by "Simple HTTP Server With Upload."
+https://gist.github.com/UniIsland/3346170
+"""
+
+
+__version__ = "1.0"
+__all__ = ["SimpleHTTPRequestHandler"]
+__author__ = "bones7456"
+__home_page__ = "https://gist.github.com/UniIsland/3346170"
+import getpass
+import os
+import posixpath
+import http.server
+import socketserver
+import urllib.request, urllib.parse, urllib.error
+import html
+import shutil
+import mimetypes
+import re
+import argparse
+import base64
+from io import BytesIO
+import json
+
+def jsonget(key_name):
+ with open("setting.json") as f:
+ json_data = f.read()
+ data = json.loads(json_data)
+ f.close()
+ return data[key_name]
+def start():
+ theport = int(jsonget('webserverport'))
+ os.chdir(jsonget('webserverroot'))
+ class SimpleHTTPRequestHandler(http.server.BaseHTTPRequestHandler):
+
+ """Simple HTTP request handler with GET/HEAD/POST commands.
+
+ This serves files from the current directory and any of its
+ subdirectories. The MIME type for files is determined by
+ calling the .guess_type() method. And can reveive file uploaded
+ by client.
+
+ The GET/HEAD/POST requests are identical except that the HEAD
+ request omits the actual contents of the file.
+
+ """
+
+ server_version = "SimpleHTTPWithUpload/" + __version__
+
+ def do_GET(self):
+ """Serve a GET request."""
+ f = self.send_head()
+ if f:
+ self.copyfile(f, self.wfile)
+ f.close()
+
+ def do_HEAD(self):
+ """Serve a HEAD request."""
+ f = self.send_head()
+ if f:
+ f.close()
+
+ def do_POST(self):
+ """Serve a POST request."""
+ r, info = self.deal_post_data()
+ print((r, info, "by: ", self.client_address))
+ f = BytesIO()
+ f.write(b'')
+ f.write(b"\n
\xe4\xb8\x8a\xe4\xbc\xa0\xe7\xbb\x93\xe6\x9e\x9c\xe9\xa1\xb5\xe9\x9d\xa2\n")
+ f.write(b"\n\xe4\xb8\x8a\xe4\xbc\xa0\xe7\xbb\x93\xe6\x9e\x9c\xe9\xa1\xb5\xe9\x9d\xa2
\n")
+ f.write(b"
\n")
+ if r:
+ f.write(b"\xe6\x88\x90\xe5\x8a\x9f:")
+ else:
+ f.write(b"\xe5\xa4\xb1\xe8\xb4\xa5:")
+ f.write(info.encode())
+ f.write(("
返回" % self.headers['referer']).encode())
+ f.write(b"
\xe4\xbb\xa5LAN++\xe4\xb8\xba\xe9\xa9\xb1\xe5\x8a\xa8 | \xe6\xba\x90\xe4\xbb\xa3\xe7\xa0\x81\xe5\x8f\x96\xe8\x87\xaabones7456")
+ f.write(b'
')
+ f.write(b"\xe5\xae\x98\xe6\x96\xb9\xe7\xbd\x91\xe7\xab\x99.\n\n")
+ length = f.tell()
+ f.seek(0)
+ self.send_response(200)
+ self.send_header("Content-type", "text/html")
+ self.send_header("Content-Length", str(length))
+ self.end_headers()
+ if f:
+ self.copyfile(f, self.wfile)
+ f.close()
+
+ def deal_post_data(self):
+ uploaded_files = []
+ content_type = self.headers['content-type']
+ if not content_type:
+ return (False, "内容类型头不含有边界")
+ boundary = content_type.split("=")[1].encode()
+ remainbytes = int(self.headers['content-length'])
+ line = self.rfile.readline()
+ remainbytes -= len(line)
+ if not boundary in line:
+ return (False, "内容没有边界")
+ while remainbytes > 0:
+ line = self.rfile.readline()
+ remainbytes -= len(line)
+ fn = re.findall(r'Content-Disposition.*name="file"; filename="(.*)"', line.decode())
+ if not fn:
+ return (False, "无法获取文件名...")
+ path = self.translate_path(self.path)
+ fn = os.path.join(path, fn[0])
+ line = self.rfile.readline()
+ remainbytes -= len(line)
+ line = self.rfile.readline()
+ remainbytes -= len(line)
+ try:
+ out = open(fn, 'wb')
+ except IOError:
+ return (False, "无法写入文件
您是否以足够的权限运行LAN++及其组件?您是否选择了文件以上传?")
+ else:
+ with out:
+ preline = self.rfile.readline()
+ remainbytes -= len(preline)
+ while remainbytes > 0:
+ line = self.rfile.readline()
+ remainbytes -= len(line)
+ if boundary in line:
+ preline = preline[0:-1]
+ if preline.endswith(b'\r'):
+ preline = preline[0:-1]
+ out.write(preline)
+ uploaded_files.append(fn)
+ break
+ else:
+ out.write(preline)
+ preline = line
+ return (True, "文件 '%s' 上传成功" % ",".join(uploaded_files))
+
+ def send_head(self):
+ path = self.translate_path(self.path)
+ f = None
+ if os.path.isdir(path):
+ if not self.path.endswith('/'):
+ # redirect browser - doing basically what apache does
+ self.send_response(301)
+ self.send_header("Location", self.path + "/")
+ self.end_headers()
+ return None
+ for index in "index.html", "index.htm":
+ index = os.path.join(path, index)
+ if os.path.exists(index):
+ path = index
+ break
+ else:
+ return self.list_directory(path)
+ ctype = self.guess_type(path)
+ try:
+ # Always read in binary mode. Opening files in text mode may cause
+ # newline translations, making the actual size of the content
+ # transmitted *less* than the content-length!
+ f = open(path, 'rb')
+ except IOError:
+ self.send_error(404, "没有找到文件 错误码:404")
+ return None
+ self.send_response(200)
+ self.send_header("Content-type", ctype)
+ fs = os.fstat(f.fileno())
+ self.send_header("Content-Length", str(fs[6]))
+ self.send_header("Last-Modified", self.date_time_string(fs.st_mtime))
+ self.end_headers()
+ return f
+
+ def list_directory(self, path):
+ try:
+ list = os.listdir(path)
+ except os.error:
+ self.send_error(404, "No permission to list directory")
+ return None
+ list.sort(key=lambda a: a.lower())
+ f = BytesIO()
+ displaypath = html.escape(urllib.parse.unquote(self.path))
+ f.write(b'')
+ f.write(("\n此目录下的文件列表: %s\n" % displaypath).encode())
+ f.write(b'\n')
+ f.write(("\n此目录下的文件列表:" + displaypath + "2>
注意:
1:您当前以[" + getpass.getuser() + "]用户查看文件(您或许对某些文件没有查看权限)
2:选择文件上传后,如文件较大,请只点击一次按钮直到页面刷新
").encode())
+ f.write(b"
\n")
+ f.write(b"
\n")
+ f.write(b"
\n")
+ f.write(b'
\xe8\xbf\x94\xe5\x9b\x9e\xe7\x88\xb6\xe7\x9b\xae\xe5\xbd\x95
\n')
+ for name in list:
+ dirimage = ''
+ fullname = os.path.join(path, name)
+ displayname = linkname = name
+ # Append / for directories or @ for symbolic links
+ if os.path.isdir(fullname):
+ dirimage = ''
+ displayname = name + "/"
+ linkname = name + "/"
+ if os.path.islink(fullname):
+ dirimage = ''
+ displayname = name + "@"
+ if name.endswith(('.bmp','.gif','.jpg','.png')):
+ dirimage = ''
+ if name.endswith(('.avi','.mpg')):
+ dirimage = ''
+ if name.endswith(('.idx','.srt','.sub')):
+ dirimage = name
+ if name.endswith('.iso'):
+ dirimage = name
+ # Note: a link to a directory displays with @ and links with /
+ f.write(('
%s
\n'
+ % (urllib.parse.quote(linkname), dirimage , html.escape(displayname))).encode())
+ f.write(b"
\n\n\n")
+ length = f.tell()
+ f.seek(0)
+ self.send_response(200)
+ self.send_header("Content-type", "text/html")
+ self.send_header("Content-Length", str(length))
+ self.end_headers()
+ return f
+
+ def translate_path(self, path):
+ """Translate a /-separated PATH to the local filename syntax.
+ Components that mean special things to the local file system
+ (e.g. drive or directory names) are ignored. (XXX They should
+ probably be diagnosed.)
+
+ """
+ # abandon query parameters
+ path = path.split('?',1)[0]
+ path = path.split('#',1)[0]
+ path = posixpath.normpath(urllib.parse.unquote(path))
+ words = path.split('/')
+ words = [_f for _f in words if _f]
+ path = os.getcwd()
+ for word in words:
+ drive, word = os.path.splitdrive(word)
+ head, word = os.path.split(word)
+ if word in (os.curdir, os.pardir): continue
+ path = os.path.join(path, word)
+ return path
+
+ def copyfile(self, source, outputfile):
+ """Copy all data between two file objects.
+
+ The SOURCE argument is a file object open for reading
+ (or anything with a read() method) and the DESTINATION
+ argument is a file object open for writing (or
+ anything with a write() method).
+
+ The only reason for overriding this would be to change
+ the block size or perhaps to replace newlines by CRLF
+ -- note however that this the default server uses this
+ to copy binary data as well.
+
+ """
+ shutil.copyfileobj(source, outputfile)
+
+ def guess_type(self, path):
+ """Guess the type of a file.
+
+ Argument is a PATH (a filename).
+
+ Return value is a string of the form type/subtype,
+ usable for a MIME Content-type header.
+
+ The default implementation looks the file's extension
+ up in the table self.extensions_map, using application/octet-stream
+ as a default; however it would be permissible (if
+ slow) to look inside the data to make a better guess.
+
+ """
+
+ base, ext = posixpath.splitext(path)
+ if ext in self.extensions_map:
+ return self.extensions_map[ext]
+ ext = ext.lower()
+ if ext in self.extensions_map:
+ return self.extensions_map[ext]
+ else:
+ return self.extensions_map['']
+
+ if not mimetypes.inited:
+ mimetypes.init() # try to read system mime.types
+ extensions_map = mimetypes.types_map.copy()
+ extensions_map.update({
+ '': 'application/octet-stream', # Default
+ '.py': 'text/plain',
+ '.c': 'text/plain',
+ '.h': 'text/plain',
+ })
+
+ parser = argparse.ArgumentParser()
+ parser.add_argument('--bind', '-b', default='', metavar='ADDRESS',
+ help='Specify alternate bind address '
+ '[default: all interfaces]')
+ parser.add_argument('port', action='store',
+ default=theport, type=int,
+ nargs='?',
+ help='Specify alternate port [default:' + str(theport) + ']')
+ args = parser.parse_args()
+
+ PORT = args.port
+ BIND = args.bind
+ HOST = BIND
+
+ if HOST == '':
+ HOST = 'localhost'
+
+ Handler = SimpleHTTPRequestHandler
+
+ with socketserver.TCPServer((BIND, PORT), Handler) as httpd:
+ serve_message = "[Webserver - 1.0]\nServing HTTP on {host} port {port} (http://{host}:{port}/) ..."
+ print(serve_message.format(host=HOST, port=PORT))
+ httpd.serve_forever()
+if __name__ == "__main__":
+ start()
\ No newline at end of file
diff --git a/onefile/README.md b/onefile/README.md
new file mode 100644
index 0000000..8a9dc32
--- /dev/null
+++ b/onefile/README.md
@@ -0,0 +1,9 @@
+# 单文件 (onefile)
+## 简介
+单文件小程序
+## 支持
+每个文件都是一个不同的程序
+请分别根据注释运行
+## 协议
+详见文件内部注释
+如无注释, 根据 GPL 3.0 协议开源
diff --git a/onefile/file_reader.cpp b/onefile/file_reader.cpp
new file mode 100644
index 0000000..944e1f1
--- /dev/null
+++ b/onefile/file_reader.cpp
@@ -0,0 +1,31 @@
+// main.cpp
+// author: Wang Zhiyu
+// SFIS C++ Project
+#include
+using namespace std;
+
+int main(int argc, char *argv[]){
+ fstream config;
+ config.open(argv[1], ios::in);
+ if(config){
+ cout << "Reading Data" << endl;
+ vector data;
+ string tmp;
+ while(getline(config,tmp)){
+ data.push_back(tmp);
+ }
+ cout << "Redirect to terminal:" << endl;
+ for(int i = 0;i < data.size();i++){
+ cout << data[i] << endl;
+ }
+ config.close();
+ }
+ else{
+ cout << "File NOT Found" << endl;
+ }
+ cout << "Press any key to Continue...";
+ cin.clear();
+ cin.sync();
+ cin.get();
+ return 0;
+}
diff --git a/plane_fighting/README.md b/plane_fighting/README.md
new file mode 100644
index 0000000..2e4232f
--- /dev/null
+++ b/plane_fighting/README.md
@@ -0,0 +1,12 @@
+# Plane Fighting (plane_fighting)
+## 简介
+一个跨平台的简易"飞机大战"小游戏
+## 支持
+基于Python & PyGame 运行
+可通过 Buildozer 打包为移动应用
+## 协议
+图标库(./images/)来自 IconFont
+音效库(./sound/)来自网络
+字体库(./font)来自 Ubuntu
+相应的版权归作者所有
+本目录中其他所有的源代码文件根据 GPL 3.0 协议开源
\ No newline at end of file
diff --git a/plane_fighting/buildozer.spec b/plane_fighting/buildozer.spec
new file mode 100644
index 0000000..665c3ea
--- /dev/null
+++ b/plane_fighting/buildozer.spec
@@ -0,0 +1,427 @@
+[app]
+
+# (str) Title of your application
+title = Plane Fighting
+
+# (str) Package name
+package.name = plane_fighting
+
+# (str) Package domain (needed for android/ios packaging)
+package.domain = ga.imwangzhiyu
+
+# (str) Source code where the main.py live
+source.dir = .
+
+# (list) Source files to include (let empty to include all the files)
+source.include_exts = py,png,ogg,wav,ttf,dat
+
+# (list) List of inclusions using pattern matching
+source.include_patterns = font/*,sound/*,images/*,record.dat
+
+# (list) Source files to exclude (let empty to not exclude anything)
+#source.exclude_exts = spec
+
+# (list) List of directory to exclude (let empty to not exclude anything)
+#source.exclude_dirs = tests, bin, venv
+
+# (list) List of exclusions using pattern matching
+# Do not prefix with './'
+#source.exclude_patterns = license,images/*/*.jpg
+
+# (str) Application versioning (method 1)
+version = 0.1
+
+# (str) Application versioning (method 2)
+# version.regex = __version__ = ['"](.*)['"]
+# version.filename = %(source.dir)s/main.py
+
+# (list) Application requirements
+# comma separated e.g. requirements = sqlite3,kivy
+requirements = python3,pygame
+
+# (str) Custom source folders for requirements
+# Sets custom source for any requirements with recipes
+# requirements.source.kivy = ../../kivy
+
+# (str) Presplash of the application
+#presplash.filename = %(source.dir)s/data/presplash.png
+
+# (str) Icon of the application
+icon.filename = %(source.dir)s/images/icon.png
+
+# (str) Supported orientation (one of landscape, sensorLandscape, portrait or all)
+orientation = portrait
+
+# (list) List of service to declare
+#services = NAME:ENTRYPOINT_TO_PY,NAME2:ENTRYPOINT2_TO_PY
+
+#
+# OSX Specific
+#
+
+#
+# author = © Copyright Info
+
+# change the major version of python used by the app
+osx.python_version = 3
+
+# Kivy version to use
+osx.kivy_version = 1.9.1
+
+#
+# Android specific
+#
+
+# (bool) Indicate if the application should be fullscreen or not
+fullscreen = 0
+
+# (string) Presplash background color (for android toolchain)
+# Supported formats are: #RRGGBB #AARRGGBB or one of the following names:
+# red, blue, green, black, white, gray, cyan, magenta, yellow, lightgray,
+# darkgray, grey, lightgrey, darkgrey, aqua, fuchsia, lime, maroon, navy,
+# olive, purple, silver, teal.
+#android.presplash_color = #FFFFFF
+
+# (string) Presplash animation using Lottie format.
+# see https://lottiefiles.com/ for examples and https://airbnb.design/lottie/
+# for general documentation.
+# Lottie files can be created using various tools, like Adobe After Effect or Synfig.
+#android.presplash_lottie = "path/to/lottie/file.json"
+
+# (str) Adaptive icon of the application (used if Android API level is 26+ at runtime)
+#icon.adaptive_foreground.filename = %(source.dir)s/data/icon_fg.png
+#icon.adaptive_background.filename = %(source.dir)s/data/icon_bg.png
+
+# (list) Permissions
+#android.permissions = INTERNET
+
+# (list) features (adds uses-feature -tags to manifest)
+#android.features = android.hardware.usb.host
+
+# (int) Target Android API, should be as high as possible.
+#android.api = 27
+
+# (int) Minimum API your APK / AAB will support.
+#android.minapi = 21
+
+# (int) Android SDK version to use
+#android.sdk = 20
+
+# (str) Android NDK version to use
+#android.ndk = 19b
+
+# (int) Android NDK API to use. This is the minimum API your app will support, it should usually match android.minapi.
+#android.ndk_api = 21
+
+# (bool) Use --private data storage (True) or --dir public storage (False)
+#android.private_storage = True
+
+# (str) Android NDK directory (if empty, it will be automatically downloaded.)
+#android.ndk_path =
+
+# (str) Android SDK directory (if empty, it will be automatically downloaded.)
+#android.sdk_path =
+
+# (str) ANT directory (if empty, it will be automatically downloaded.)
+#android.ant_path =
+
+# (bool) If True, then skip trying to update the Android sdk
+# This can be useful to avoid excess Internet downloads or save time
+# when an update is due and you just want to test/build your package
+# android.skip_update = False
+
+# (bool) If True, then automatically accept SDK license
+# agreements. This is intended for automation only. If set to False,
+# the default, you will be shown the license when first running
+# buildozer.
+# android.accept_sdk_license = False
+
+# (str) Android entry point, default is ok for Kivy-based app
+#android.entrypoint = org.kivy.android.PythonActivity
+
+# (str) Full name including package path of the Java class that implements Android Activity
+# use that parameter together with android.entrypoint to set custom Java class instead of PythonActivity
+#android.activity_class_name = org.kivy.android.PythonActivity
+
+# (str) Extra xml to write directly inside the element of AndroidManifest.xml
+# use that parameter to provide a filename from where to load your custom XML code
+#android.extra_manifest_xml = ./src/android/extra_manifest.xml
+
+# (str) Extra xml to write directly inside the tag of AndroidManifest.xml
+# use that parameter to provide a filename from where to load your custom XML arguments:
+#android.extra_manifest_application_arguments = ./src/android/extra_manifest_application_arguments.xml
+
+# (str) Full name including package path of the Java class that implements Python Service
+# use that parameter to set custom Java class instead of PythonService
+#android.service_class_name = org.kivy.android.PythonService
+
+# (str) Android app theme, default is ok for Kivy-based app
+# android.apptheme = "@android:style/Theme.NoTitleBar"
+
+# (list) Pattern to whitelist for the whole project
+#android.whitelist =
+
+# (str) Path to a custom whitelist file
+#android.whitelist_src =
+
+# (str) Path to a custom blacklist file
+#android.blacklist_src =
+
+# (list) List of Java .jar files to add to the libs so that pyjnius can access
+# their classes. Don't add jars that you do not need, since extra jars can slow
+# down the build process. Allows wildcards matching, for example:
+# OUYA-ODK/libs/*.jar
+#android.add_jars = foo.jar,bar.jar,path/to/more/*.jar
+
+# (list) List of Java files to add to the android project (can be java or a
+# directory containing the files)
+#android.add_src =
+
+# (list) Android AAR archives to add
+#android.add_aars =
+
+# (list) Put these files or directories in the apk assets directory.
+# Either form may be used, and assets need not be in 'source.include_exts'.
+# 1) android.add_assets = source_asset_relative_path
+# 2) android.add_assets = source_asset_path:destination_asset_relative_path
+#android.add_assets =
+
+# (list) Gradle dependencies to add
+#android.gradle_dependencies =
+
+# (bool) Enable AndroidX support. Enable when 'android.gradle_dependencies'
+# contains an 'androidx' package, or any package from Kotlin source.
+# android.enable_androidx requires android.api >= 28
+#android.enable_androidx = False
+
+# (list) add java compile options
+# this can for example be necessary when importing certain java libraries using the 'android.gradle_dependencies' option
+# see https://developer.android.com/studio/write/java8-support for further information
+# android.add_compile_options = "sourceCompatibility = 1.8", "targetCompatibility = 1.8"
+
+# (list) Gradle repositories to add {can be necessary for some android.gradle_dependencies}
+# please enclose in double quotes
+# e.g. android.gradle_repositories = "maven { url 'https://kotlin.bintray.com/ktor' }"
+#android.add_gradle_repositories =
+
+# (list) packaging options to add
+# see https://google.github.io/android-gradle-dsl/current/com.android.build.gradle.internal.dsl.PackagingOptions.html
+# can be necessary to solve conflicts in gradle_dependencies
+# please enclose in double quotes
+# e.g. android.add_packaging_options = "exclude 'META-INF/common.kotlin_module'", "exclude 'META-INF/*.kotlin_module'"
+#android.add_packaging_options =
+
+# (list) Java classes to add as activities to the manifest.
+#android.add_activities = com.example.ExampleActivity
+
+# (str) OUYA Console category. Should be one of GAME or APP
+# If you leave this blank, OUYA support will not be enabled
+#android.ouya.category = GAME
+
+# (str) Filename of OUYA Console icon. It must be a 732x412 png image.
+#android.ouya.icon.filename = %(source.dir)s/data/ouya_icon.png
+
+# (str) XML file to include as an intent filters in tag
+#android.manifest.intent_filters =
+
+# (str) launchMode to set for the main activity
+#android.manifest.launch_mode = standard
+
+# (list) Android additional libraries to copy into libs/armeabi
+#android.add_libs_armeabi = libs/android/*.so
+#android.add_libs_armeabi_v7a = libs/android-v7/*.so
+#android.add_libs_arm64_v8a = libs/android-v8/*.so
+#android.add_libs_x86 = libs/android-x86/*.so
+#android.add_libs_mips = libs/android-mips/*.so
+
+# (bool) Indicate whether the screen should stay on
+# Don't forget to add the WAKE_LOCK permission if you set this to True
+#android.wakelock = False
+
+# (list) Android application meta-data to set (key=value format)
+#android.meta_data =
+
+# (list) Android library project to add (will be added in the
+# project.properties automatically.)
+#android.library_references =
+
+# (list) Android shared libraries which will be added to AndroidManifest.xml using tag
+#android.uses_library =
+
+# (str) Android logcat filters to use
+#android.logcat_filters = *:S python:D
+
+# (bool) Android logcat only display log for activity's pid
+#android.logcat_pid_only = False
+
+# (str) Android additional adb arguments
+#android.adb_args = -H host.docker.internal
+
+# (bool) Copy library instead of making a libpymodules.so
+#android.copy_libs = 1
+
+# (list) The Android archs to build for, choices: armeabi-v7a, arm64-v8a, x86, x86_64
+# In past, was `android.arch` as we weren't supporting builds for multiple archs at the same time.
+android.archs = arm64-v8a, armeabi-v7a
+
+# (int) overrides automatic versionCode computation (used in build.gradle)
+# this is not the same as app version and should only be edited if you know what you're doing
+# android.numeric_version = 1
+
+# (bool) enables Android auto backup feature (Android API >=23)
+android.allow_backup = True
+
+# (str) XML file for custom backup rules (see official auto backup documentation)
+# android.backup_rules =
+
+# (str) If you need to insert variables into your AndroidManifest.xml file,
+# you can do so with the manifestPlaceholders property.
+# This property takes a map of key-value pairs. (via a string)
+# Usage example : android.manifest_placeholders = [myCustomUrl:\"org.kivy.customurl\"]
+# android.manifest_placeholders = [:]
+
+# (bool) disables the compilation of py to pyc/pyo files when packaging
+# android.no-compile-pyo = True
+
+# (str) The format used to package the app for release mode (aab or apk).
+# android.release_artifact = aab
+
+#
+# Python for android (p4a) specific
+#
+
+# (str) python-for-android URL to use for checkout
+#p4a.url =
+
+# (str) python-for-android fork to use in case if p4a.url is not specified, defaults to upstream (kivy)
+#p4a.fork = kivy
+
+# (str) python-for-android branch to use, defaults to master
+#p4a.branch = master
+
+# (str) python-for-android specific commit to use, defaults to HEAD, must be within p4a.branch
+#p4a.commit = HEAD
+
+# (str) python-for-android git clone directory (if empty, it will be automatically cloned from github)
+#p4a.source_dir =
+
+# (str) The directory in which python-for-android should look for your own build recipes (if any)
+#p4a.local_recipes =
+
+# (str) Filename to the hook for p4a
+#p4a.hook =
+
+# (str) Bootstrap to use for android builds
+# p4a.bootstrap = sdl2
+
+# (int) port number to specify an explicit --port= p4a argument (eg for bootstrap flask)
+#p4a.port =
+
+# Control passing the --use-setup-py vs --ignore-setup-py to p4a
+# "in the future" --use-setup-py is going to be the default behaviour in p4a, right now it is not
+# Setting this to false will pass --ignore-setup-py, true will pass --use-setup-py
+# NOTE: this is general setuptools integration, having pyproject.toml is enough, no need to generate
+# setup.py if you're using Poetry, but you need to add "toml" to source.include_exts.
+#p4a.setup_py = false
+
+# (str) extra command line arguments to pass when invoking pythonforandroid.toolchain
+#p4a.extra_args =
+
+
+#
+# iOS specific
+#
+
+# (str) Path to a custom kivy-ios folder
+#ios.kivy_ios_dir = ../kivy-ios
+# Alternately, specify the URL and branch of a git checkout:
+ios.kivy_ios_url = https://github.com/kivy/kivy-ios
+ios.kivy_ios_branch = master
+
+# Another platform dependency: ios-deploy
+# Uncomment to use a custom checkout
+#ios.ios_deploy_dir = ../ios_deploy
+# Or specify URL and branch
+ios.ios_deploy_url = https://github.com/phonegap/ios-deploy
+ios.ios_deploy_branch = 1.10.0
+
+# (bool) Whether or not to sign the code
+ios.codesign.allowed = false
+
+# (str) Name of the certificate to use for signing the debug version
+# Get a list of available identities: buildozer ios list_identities
+#ios.codesign.debug = "iPhone Developer: ()"
+
+# (str) The development team to use for signing the debug version
+#ios.codesign.development_team.debug =
+
+# (str) Name of the certificate to use for signing the release version
+#ios.codesign.release = %(ios.codesign.debug)s
+
+# (str) The development team to use for signing the release version
+#ios.codesign.development_team.release =
+
+# (str) URL pointing to .ipa file to be installed
+# This option should be defined along with `display_image_url` and `full_size_image_url` options.
+#ios.manifest.app_url =
+
+# (str) URL pointing to an icon (57x57px) to be displayed during download
+# This option should be defined along with `app_url` and `full_size_image_url` options.
+#ios.manifest.display_image_url =
+
+# (str) URL pointing to a large icon (512x512px) to be used by iTunes
+# This option should be defined along with `app_url` and `display_image_url` options.
+#ios.manifest.full_size_image_url =
+
+
+[buildozer]
+
+# (int) Log level (0 = error only, 1 = info, 2 = debug (with command output))
+log_level = 2
+
+# (int) Display warning if buildozer is run as root (0 = False, 1 = True)
+warn_on_root = 1
+
+# (str) Path to build artifact storage, absolute or relative to spec file
+# build_dir = ./.buildozer
+
+# (str) Path to build output (i.e. .apk, .aab, .ipa) storage
+# bin_dir = ./bin
+
+# -----------------------------------------------------------------------------
+# List as sections
+#
+# You can define all the "list" as [section:key].
+# Each line will be considered as a option to the list.
+# Let's take [app] / source.exclude_patterns.
+# Instead of doing:
+#
+#[app]
+#source.exclude_patterns = license,data/audio/*.wav,data/images/original/*
+#
+# This can be translated into:
+#
+#[app:source.exclude_patterns]
+#license
+#data/audio/*.wav
+#data/images/original/*
+#
+
+
+# -----------------------------------------------------------------------------
+# Profiles
+#
+# You can extend section / key with a profile
+# For example, you want to deploy a demo version of your application without
+# HD content. You could first change the title to add "(demo)" in the name
+# and extend the excluded directories to remove the HD content.
+#
+#[app@demo]
+#title = My Application (demo)
+#
+#[app:source.exclude_patterns@demo]
+#images/hd/*
+#
+# Then, invoke the command line with the "demo" profile:
+#
+#buildozer --profile demo android debug
diff --git a/plane_fighting/bullet.py b/plane_fighting/bullet.py
new file mode 100644
index 0000000..eeb6641
--- /dev/null
+++ b/plane_fighting/bullet.py
@@ -0,0 +1,45 @@
+import pygame,os
+
+abspath = os.getcwd() + "/"
+class Bullet1(pygame.sprite.Sprite):
+ def __init__(self, position):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image = pygame.image.load(abspath + "images/bullet1.png").convert_alpha()
+ self.rect = self.image.get_rect()
+ self.rect.left, self.rect.top = position
+ self.speed = 11
+ self.active = False
+ self.mask = pygame.mask.from_surface(self.image)
+
+ def move(self):
+ self.rect.top -= self.speed
+
+ if self.rect.top < 0:
+ self.active = False
+
+ def reset(self, position):
+ self.rect.left, self.rect.top = position
+ self.active = True
+
+class Bullet2(pygame.sprite.Sprite):
+ def __init__(self, position):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image = pygame.image.load(abspath + "images/bullet2.png").convert_alpha()
+ self.rect = self.image.get_rect()
+ self.rect.left, self.rect.top = position
+ self.speed = 14#14
+ self.active = False
+ self.mask = pygame.mask.from_surface(self.image)
+
+ def move(self):
+ self.rect.top -= self.speed
+
+ if self.rect.top < 0:
+ self.active = False
+
+ def reset(self, position):
+ self.rect.left, self.rect.top = position
+ self.active = True
+
diff --git a/plane_fighting/enemy.py b/plane_fighting/enemy.py
new file mode 100644
index 0000000..1ab4d9b
--- /dev/null
+++ b/plane_fighting/enemy.py
@@ -0,0 +1,118 @@
+import pygame,os
+from random import *
+abspath = os.getcwd() + "/"
+class SmallEnemy(pygame.sprite.Sprite):
+ def __init__(self, bg_size):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image = pygame.image.load(abspath + "images/enemy1.png").convert_alpha()
+ self.destroy_images = []
+ self.destroy_images.extend([\
+ pygame.image.load(abspath + "images/enemy1_down1.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy1_down2.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy1_down3.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy1_down4.png").convert_alpha() \
+ ])
+ self.rect = self.image.get_rect()
+ self.width, self.height = bg_size[0], bg_size[1]
+ self.speed = 2
+ self.active = True
+ self.rect.left, self.rect.top = \
+ randint(0, self.width - self.rect.width), \
+ randint(-5 * self.height, 0)
+ self.mask = pygame.mask.from_surface(self.image)
+
+ def move(self):
+ if self.rect.top < self.height:
+ self.rect.top += self.speed
+ else:
+ self.reset()
+
+ def reset(self):
+ self.active = True
+ self.rect.left, self.rect.top = \
+ randint(0, self.width - self.rect.width), \
+ randint(-5 * self.height, 0)
+
+
+class MidEnemy(pygame.sprite.Sprite):
+ energy = 8
+
+ def __init__(self, bg_size):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image = pygame.image.load(abspath + "images/enemy2.png").convert_alpha()
+ self.image_hit = pygame.image.load(abspath + "images/enemy2_hit.png").convert_alpha()
+ self.destroy_images = []
+ self.destroy_images.extend([\
+ pygame.image.load(abspath + "images/enemy2_down1.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy2_down2.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy2_down3.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy2_down4.png").convert_alpha() \
+ ])
+ self.rect = self.image.get_rect()
+ self.width, self.height = bg_size[0], bg_size[1]
+ self.speed = 1
+ self.active = True
+ self.rect.left, self.rect.top = \
+ randint(0, self.width - self.rect.width), \
+ randint(-10 * self.height, -self.height)
+ self.mask = pygame.mask.from_surface(self.image)
+ self.energy = MidEnemy.energy
+ self.hit = False
+
+ def move(self):
+ if self.rect.top < self.height:
+ self.rect.top += self.speed
+ else:
+ self.reset()
+
+ def reset(self):
+ self.active = True
+ self.energy = MidEnemy.energy
+ self.rect.left, self.rect.top = \
+ randint(0, self.width - self.rect.width), \
+ randint(-10 * self.height, -self.height)
+
+
+class BigEnemy(pygame.sprite.Sprite):
+ energy = 20
+
+ def __init__(self, bg_size):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image1 = pygame.image.load(abspath + "images/enemy3_n1.png").convert_alpha()
+ self.image2 = pygame.image.load(abspath + "images/enemy3_n2.png").convert_alpha()
+ self.image_hit = pygame.image.load(abspath + "images/enemy3_hit.png").convert_alpha()
+ self.destroy_images = []
+ self.destroy_images.extend([\
+ pygame.image.load(abspath + "images/enemy3_down1.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy3_down2.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy3_down3.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy3_down4.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy3_down5.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/enemy3_down6.png").convert_alpha() \
+ ])
+ self.rect = self.image1.get_rect()
+ self.width, self.height = bg_size[0], bg_size[1]
+ self.speed = 1
+ self.active = True
+ self.rect.left, self.rect.top = \
+ randint(0, self.width - self.rect.width), \
+ randint(-15 * self.height, -5 * self.height)
+ self.mask = pygame.mask.from_surface(self.image1)
+ self.energy = BigEnemy.energy
+ self.hit = False
+
+ def move(self):
+ if self.rect.top < self.height:
+ self.rect.top += self.speed
+ else:
+ self.reset()
+
+ def reset(self):
+ self.active = True
+ self.energy = BigEnemy.energy
+ self.rect.left, self.rect.top = \
+ randint(0, self.width - self.rect.width), \
+ randint(-15 * self.height, -5 * self.height)
diff --git a/plane_fighting/font/font-2.ttf b/plane_fighting/font/font-2.ttf
new file mode 100644
index 0000000..ed0f5bc
Binary files /dev/null and b/plane_fighting/font/font-2.ttf differ
diff --git a/plane_fighting/font/font.ttf b/plane_fighting/font/font.ttf
new file mode 100644
index 0000000..b173da2
Binary files /dev/null and b/plane_fighting/font/font.ttf differ
diff --git a/plane_fighting/images/again.png b/plane_fighting/images/again.png
new file mode 100644
index 0000000..cbcc54d
Binary files /dev/null and b/plane_fighting/images/again.png differ
diff --git a/plane_fighting/images/background.png b/plane_fighting/images/background.png
new file mode 100644
index 0000000..2197c0f
Binary files /dev/null and b/plane_fighting/images/background.png differ
diff --git a/plane_fighting/images/bomb.png b/plane_fighting/images/bomb.png
new file mode 100644
index 0000000..1c92d5b
Binary files /dev/null and b/plane_fighting/images/bomb.png differ
diff --git a/plane_fighting/images/bomb_supply.png b/plane_fighting/images/bomb_supply.png
new file mode 100644
index 0000000..07f242b
Binary files /dev/null and b/plane_fighting/images/bomb_supply.png differ
diff --git a/plane_fighting/images/bullet1.png b/plane_fighting/images/bullet1.png
new file mode 100644
index 0000000..9b575e3
Binary files /dev/null and b/plane_fighting/images/bullet1.png differ
diff --git a/plane_fighting/images/bullet2.png b/plane_fighting/images/bullet2.png
new file mode 100644
index 0000000..43e3246
Binary files /dev/null and b/plane_fighting/images/bullet2.png differ
diff --git a/plane_fighting/images/bullet_supply.png b/plane_fighting/images/bullet_supply.png
new file mode 100644
index 0000000..9c51e82
Binary files /dev/null and b/plane_fighting/images/bullet_supply.png differ
diff --git a/plane_fighting/images/enemy1.png b/plane_fighting/images/enemy1.png
new file mode 100644
index 0000000..51cfce7
Binary files /dev/null and b/plane_fighting/images/enemy1.png differ
diff --git a/Plane_Fighting/images/enemy1_down.png b/plane_fighting/images/enemy1_down1.png
old mode 100755
new mode 100644
similarity index 90%
rename from Plane_Fighting/images/enemy1_down.png
rename to plane_fighting/images/enemy1_down1.png
index 1e0fa49..95e211b
Binary files a/Plane_Fighting/images/enemy1_down.png and b/plane_fighting/images/enemy1_down1.png differ
diff --git a/plane_fighting/images/enemy1_down2.png b/plane_fighting/images/enemy1_down2.png
new file mode 100644
index 0000000..508b769
Binary files /dev/null and b/plane_fighting/images/enemy1_down2.png differ
diff --git a/plane_fighting/images/enemy1_down3.png b/plane_fighting/images/enemy1_down3.png
new file mode 100644
index 0000000..3c4630c
Binary files /dev/null and b/plane_fighting/images/enemy1_down3.png differ
diff --git a/plane_fighting/images/enemy1_down4.png b/plane_fighting/images/enemy1_down4.png
new file mode 100644
index 0000000..e7aebbf
Binary files /dev/null and b/plane_fighting/images/enemy1_down4.png differ
diff --git a/plane_fighting/images/enemy2.png b/plane_fighting/images/enemy2.png
new file mode 100644
index 0000000..7f7e68d
Binary files /dev/null and b/plane_fighting/images/enemy2.png differ
diff --git a/plane_fighting/images/enemy2_down1.png b/plane_fighting/images/enemy2_down1.png
new file mode 100644
index 0000000..f7c68de
Binary files /dev/null and b/plane_fighting/images/enemy2_down1.png differ
diff --git a/plane_fighting/images/enemy2_down2.png b/plane_fighting/images/enemy2_down2.png
new file mode 100644
index 0000000..8a72aca
Binary files /dev/null and b/plane_fighting/images/enemy2_down2.png differ
diff --git a/plane_fighting/images/enemy2_down3.png b/plane_fighting/images/enemy2_down3.png
new file mode 100644
index 0000000..e510526
Binary files /dev/null and b/plane_fighting/images/enemy2_down3.png differ
diff --git a/plane_fighting/images/enemy2_down4.png b/plane_fighting/images/enemy2_down4.png
new file mode 100644
index 0000000..2031b6c
Binary files /dev/null and b/plane_fighting/images/enemy2_down4.png differ
diff --git a/plane_fighting/images/enemy2_hit.png b/plane_fighting/images/enemy2_hit.png
new file mode 100644
index 0000000..9f4d8c3
Binary files /dev/null and b/plane_fighting/images/enemy2_hit.png differ
diff --git a/Plane_Fighting/images/enemy3_down.png b/plane_fighting/images/enemy3_down1.png
old mode 100755
new mode 100644
similarity index 100%
rename from Plane_Fighting/images/enemy3_down.png
rename to plane_fighting/images/enemy3_down1.png
diff --git a/plane_fighting/images/enemy3_down2.png b/plane_fighting/images/enemy3_down2.png
new file mode 100644
index 0000000..3e7469c
Binary files /dev/null and b/plane_fighting/images/enemy3_down2.png differ
diff --git a/plane_fighting/images/enemy3_down3.png b/plane_fighting/images/enemy3_down3.png
new file mode 100644
index 0000000..3e7469c
Binary files /dev/null and b/plane_fighting/images/enemy3_down3.png differ
diff --git a/plane_fighting/images/enemy3_down4.png b/plane_fighting/images/enemy3_down4.png
new file mode 100644
index 0000000..3e7469c
Binary files /dev/null and b/plane_fighting/images/enemy3_down4.png differ
diff --git a/plane_fighting/images/enemy3_down5.png b/plane_fighting/images/enemy3_down5.png
new file mode 100644
index 0000000..1a6d711
Binary files /dev/null and b/plane_fighting/images/enemy3_down5.png differ
diff --git a/plane_fighting/images/enemy3_down6.png b/plane_fighting/images/enemy3_down6.png
new file mode 100644
index 0000000..3e7469c
Binary files /dev/null and b/plane_fighting/images/enemy3_down6.png differ
diff --git a/plane_fighting/images/enemy3_hit.png b/plane_fighting/images/enemy3_hit.png
new file mode 100644
index 0000000..3e7469c
Binary files /dev/null and b/plane_fighting/images/enemy3_hit.png differ
diff --git a/Plane_Fighting/images/enemy3.png b/plane_fighting/images/enemy3_n1.png
old mode 100755
new mode 100644
similarity index 100%
rename from Plane_Fighting/images/enemy3.png
rename to plane_fighting/images/enemy3_n1.png
diff --git a/plane_fighting/images/enemy3_n2.png b/plane_fighting/images/enemy3_n2.png
new file mode 100644
index 0000000..0e8bfc9
Binary files /dev/null and b/plane_fighting/images/enemy3_n2.png differ
diff --git a/plane_fighting/images/gameover.png b/plane_fighting/images/gameover.png
new file mode 100644
index 0000000..09d2df5
Binary files /dev/null and b/plane_fighting/images/gameover.png differ
diff --git a/plane_fighting/images/icon.png b/plane_fighting/images/icon.png
new file mode 100644
index 0000000..6059812
Binary files /dev/null and b/plane_fighting/images/icon.png differ
diff --git a/plane_fighting/images/life.png b/plane_fighting/images/life.png
new file mode 100644
index 0000000..d759806
Binary files /dev/null and b/plane_fighting/images/life.png differ
diff --git a/plane_fighting/images/loading.png b/plane_fighting/images/loading.png
new file mode 100644
index 0000000..9b6d9c5
Binary files /dev/null and b/plane_fighting/images/loading.png differ
diff --git a/plane_fighting/images/me1.png b/plane_fighting/images/me1.png
new file mode 100644
index 0000000..b28bf94
Binary files /dev/null and b/plane_fighting/images/me1.png differ
diff --git a/plane_fighting/images/me2.png b/plane_fighting/images/me2.png
new file mode 100644
index 0000000..f971015
Binary files /dev/null and b/plane_fighting/images/me2.png differ
diff --git a/plane_fighting/images/me_destroy_1.png b/plane_fighting/images/me_destroy_1.png
new file mode 100644
index 0000000..d46ad28
Binary files /dev/null and b/plane_fighting/images/me_destroy_1.png differ
diff --git a/plane_fighting/images/me_destroy_2.png b/plane_fighting/images/me_destroy_2.png
new file mode 100644
index 0000000..a480bef
Binary files /dev/null and b/plane_fighting/images/me_destroy_2.png differ
diff --git a/plane_fighting/images/me_destroy_3.png b/plane_fighting/images/me_destroy_3.png
new file mode 100644
index 0000000..e1908bd
Binary files /dev/null and b/plane_fighting/images/me_destroy_3.png differ
diff --git a/plane_fighting/images/me_destroy_4.png b/plane_fighting/images/me_destroy_4.png
new file mode 100644
index 0000000..446b4fb
Binary files /dev/null and b/plane_fighting/images/me_destroy_4.png differ
diff --git a/plane_fighting/images/pause_nor.png b/plane_fighting/images/pause_nor.png
new file mode 100644
index 0000000..d2b9cc2
Binary files /dev/null and b/plane_fighting/images/pause_nor.png differ
diff --git a/plane_fighting/images/pause_pressed.png b/plane_fighting/images/pause_pressed.png
new file mode 100644
index 0000000..8df8d2d
Binary files /dev/null and b/plane_fighting/images/pause_pressed.png differ
diff --git a/plane_fighting/images/resume_nor.png b/plane_fighting/images/resume_nor.png
new file mode 100644
index 0000000..19a185e
Binary files /dev/null and b/plane_fighting/images/resume_nor.png differ
diff --git a/plane_fighting/images/resume_pressed.png b/plane_fighting/images/resume_pressed.png
new file mode 100644
index 0000000..3bfc993
Binary files /dev/null and b/plane_fighting/images/resume_pressed.png differ
diff --git a/plane_fighting/main.py b/plane_fighting/main.py
new file mode 100644
index 0000000..9716a85
--- /dev/null
+++ b/plane_fighting/main.py
@@ -0,0 +1,603 @@
+# main.py
+import pygame
+import sys
+import traceback
+import myplane
+import enemy
+import bullet
+import supply
+import time
+import os
+
+abspath = os.getcwd() + "/"
+from pygame.locals import *
+from random import *
+jj = 0
+pygame.init()
+pygame.mixer.init()
+
+bg_size = width, height = 480, 700
+screen = pygame.display.set_mode(bg_size)
+pygame.display.set_caption("Plane Fighting")
+key_pressed = pygame.key.get_pressed()
+background=pygame.image.load(abspath + "images/loading.png") #图片位置
+screen.blit(background,(0,0)) #对齐的坐标
+pygame.display.update() #显示内容
+pygame.mixer.music.load(abspath + "sound/game_music.ogg")
+pygame.mixer.music.set_volume(0.1)
+pygame.mixer.music.play(-1)
+time.sleep(7.5)
+background = pygame.image.load(abspath + "images/background.png").convert()
+BLACK = (0, 0, 0)
+WHITE = (255, 255, 255)
+GREEN = (0, 255, 0)
+RED = (255, 0, 0)
+
+# 载入游戏音乐
+bullet_sound = pygame.mixer.Sound(abspath + "sound/bullet.wav")
+bullet_sound.set_volume(0.2)
+bomb_sound = pygame.mixer.Sound(abspath + "sound/use_bomb.wav")
+bomb_sound.set_volume(0.2)
+supply_sound = pygame.mixer.Sound(abspath + "sound/supply.wav")
+supply_sound.set_volume(0.2)
+get_bomb_sound = pygame.mixer.Sound(abspath + "sound/get_bomb.wav")
+get_bomb_sound.set_volume(0.2)
+get_bullet_sound = pygame.mixer.Sound(abspath + "sound/get_bullet.wav")
+get_bullet_sound.set_volume(0.2)
+upgrade_sound = pygame.mixer.Sound(abspath + "sound/upgrade.wav")
+upgrade_sound.set_volume(0.2)
+enemy3_fly_sound = pygame.mixer.Sound(abspath + "sound/enemy3_flying.wav")
+enemy3_fly_sound.set_volume(0.2)
+enemy1_down_sound = pygame.mixer.Sound(abspath + "sound/enemy1_down.wav")
+enemy1_down_sound.set_volume(0.2)
+enemy2_down_sound = pygame.mixer.Sound(abspath + "sound/enemy2_down.wav")
+enemy2_down_sound.set_volume(0.2)
+enemy3_down_sound = pygame.mixer.Sound(abspath + "sound/enemy3_down.wav")
+enemy3_down_sound.set_volume(0.5)
+me_down_sound = pygame.mixer.Sound(abspath + "sound/me_down.wav")
+
+
+
+def add_small_enemies(group1, group2, num):
+ for i in range(num):
+ e1 = enemy.SmallEnemy(bg_size)
+ group1.add(e1)
+ group2.add(e1)
+
+def add_mid_enemies(group1, group2, num):
+ for i in range(num):
+ e2 = enemy.MidEnemy(bg_size)
+ group1.add(e2)
+ group2.add(e2)
+
+def add_big_enemies(group1, group2, num):
+ for i in range(num):
+ e3 = enemy.BigEnemy(bg_size)
+ group1.add(e3)
+ group2.add(e3)
+
+def inc_speed(target, inc):
+ for each in target:
+ each.speed += inc
+
+def main():
+ # Me
+ me = myplane.MyPlane(bg_size)
+
+ enemies = pygame.sprite.Group()
+
+
+ # Enemy Level 1
+ small_enemies = pygame.sprite.Group()
+ add_small_enemies(small_enemies, enemies, 15)
+
+ # Enemy Level 2
+ mid_enemies = pygame.sprite.Group()
+ add_mid_enemies(mid_enemies, enemies, 4)
+
+ # Enemy Level 3
+ big_enemies = pygame.sprite.Group()
+ add_big_enemies(big_enemies, enemies, 2)
+
+ # Common Bull
+ bullet1 = []
+ bullet1_index = 0
+ BULLET1_NUM = 4
+ for i in range(BULLET1_NUM):
+ bullet1.append(bullet.Bullet1((me.rect.centerx-3, me.rect.centery)))
+
+ # Super Bull
+ bullet2 = []
+ bullet2_index = 0
+ BULLET2_NUM = 8
+ for i in range(BULLET2_NUM//2):
+ bullet2.append(bullet.Bullet2((me.rect.centerx-33, me.rect.centery)))
+ bullet2.append(bullet.Bullet2((me.rect.centerx+30, me.rect.centery)))
+
+ clock = pygame.time.Clock()
+
+ # 中弹图片索引
+ e1_destroy_index = 0
+ e2_destroy_index = 0
+ e3_destroy_index = 0
+ me_destroy_index = 0
+
+ # 统计得分
+ score = 0
+ score_font = pygame.font.Font(abspath + "font/font.ttf", 36)
+
+ # 标志是否暂停游戏
+ paused = False
+ pause_nor_image = pygame.image.load(abspath + "images/pause_nor.png").convert_alpha()
+ pause_pressed_image = pygame.image.load(abspath + "images/pause_pressed.png").convert_alpha()
+ resume_nor_image = pygame.image.load(abspath + "images/resume_nor.png").convert_alpha()
+ resume_pressed_image = pygame.image.load(abspath + "images/resume_pressed.png").convert_alpha()
+ paused_rect = pause_nor_image.get_rect()
+ paused_rect.left, paused_rect.top = width - paused_rect.width - 10, 10
+ paused_image = pause_nor_image
+
+ # 设置难度级别
+ level = 1
+
+ # 全屏炸弹
+ bomb_image = pygame.image.load(abspath + "images/bomb.png").convert_alpha()
+ bomb_rect = bomb_image.get_rect()
+ bomb_font = pygame.font.Font(abspath + "font/font.ttf", 48)
+ bomb_num = 3
+
+ # 每30秒发放一个补给包
+ bullet_supply = supply.Bullet_Supply(bg_size)
+ bomb_supply = supply.Bomb_Supply(bg_size)
+ SUPPLY_TIME = USEREVENT
+ pygame.time.set_timer(SUPPLY_TIME, 30 * 1000)
+
+ # 超级子弹定时器
+ DOUBLE_BULLET_TIME = USEREVENT + 1
+
+ # 标志是否使用超级子弹
+ is_double_bullet = False
+
+ # 解除我方无敌状态定时器
+ INVINCIBLE_TIME = USEREVENT + 3
+
+
+ # 生命数量
+ life_num = 3
+ life_image = pygame.image.load(abspath + "images/life.png").convert_alpha()
+ life_rect = life_image.get_rect()
+
+ # 用于阻止重复打开记录文件
+ recorded = False
+
+ # 游戏结束画面
+ gameover_font = pygame.font.Font(abspath + "font/font.ttf", 48)
+ again_image = pygame.image.load(abspath + "images/again.png").convert_alpha()
+ again_rect = again_image.get_rect()
+ gameover_image = pygame.image.load(abspath + "images/gameover.png").convert_alpha()
+ gameover_rect = gameover_image.get_rect()
+
+ # 用于切换图片
+ switch_image = True
+
+ # 用于延迟
+ delay = 100
+
+ running = True
+
+ while running:
+ for event in pygame.event.get():
+ if event.type == QUIT:
+ pygame.quit()
+ sys.exit()
+
+ elif event.type == MOUSEBUTTONDOWN:
+ if event.button == 1 and paused_rect.collidepoint(event.pos):
+ paused = not paused
+ if paused:
+ pygame.time.set_timer(SUPPLY_TIME, 0)
+ pygame.mixer.music.pause()
+ pygame.mixer.pause()
+ else:
+ pygame.time.set_timer(SUPPLY_TIME, 30 * 1000)
+ pygame.mixer.music.unpause()
+ pygame.mixer.unpause()
+
+ elif event.type == MOUSEMOTION:
+ if paused_rect.collidepoint(event.pos):
+ if paused:
+ paused_image = resume_pressed_image
+ else:
+ paused_image = pause_pressed_image
+ else:
+ if paused:
+ paused_image = resume_nor_image
+ else:
+ paused_image = pause_nor_image
+
+ elif event.type == KEYDOWN:
+ if event.key == K_SPACE:
+ if bomb_num:
+ bomb_num -= 1
+ bomb_sound.play()
+ for each in enemies:
+ if each.rect.bottom > 0:
+ each.active = False
+
+ elif event.type == SUPPLY_TIME:
+ supply_sound.play()
+ if choice([True, False]):
+ bomb_supply.reset()
+ else:
+ bullet_supply.reset()
+
+ elif event.type == DOUBLE_BULLET_TIME:
+ is_double_bullet = False
+ pygame.time.set_timer(DOUBLE_BULLET_TIME, 0)
+
+ elif event.type == INVINCIBLE_TIME:
+ me.invincible = False
+ pygame.time.set_timer(INVINCIBLE_TIME, 0)
+
+
+ # 根据用户的得分增加难度
+ if level == 1 and score > 50000:
+ level = 2
+ upgrade_sound.play()
+ # 增加3架小型敌机、2架中型敌机和1架大型敌机
+ add_small_enemies(small_enemies, enemies, 3)
+ add_mid_enemies(mid_enemies, enemies, 2)
+ add_big_enemies(big_enemies, enemies, 1)
+ # 提升小型敌机的速度
+ inc_speed(small_enemies, 1)
+ elif level == 2 and score > 300000:
+ level = 3
+ upgrade_sound.play()
+ # 增加5架小型敌机、3架中型敌机和2架大型敌机
+ add_small_enemies(small_enemies, enemies, 5)
+ add_mid_enemies(mid_enemies, enemies, 3)
+ add_big_enemies(big_enemies, enemies, 2)
+ # 提升小型敌机的速度
+ inc_speed(small_enemies, 1)
+ inc_speed(mid_enemies, 1)
+ elif level == 3 and score > 600000:
+ level = 4
+ upgrade_sound.play()
+ # 增加5架小型敌机、3架中型敌机和2架大型敌机
+ add_small_enemies(small_enemies, enemies, 5)
+ add_mid_enemies(mid_enemies, enemies, 3)
+ add_big_enemies(big_enemies, enemies, 2)
+ # 提升小型敌机的速度
+ inc_speed(small_enemies, 1)
+ inc_speed(mid_enemies, 1)
+ elif level == 4 and score > 1000000:
+ level = 5
+ upgrade_sound.play()
+ # 增加5架小型敌机、3架中型敌机和2架大型敌机
+ add_small_enemies(small_enemies, enemies, 300)
+
+ # 提升小型敌机的速度
+ inc_speed(small_enemies, 1)
+ inc_speed(mid_enemies, 1)
+
+
+ screen.blit(background, (0, 0))
+
+ if life_num and not paused:
+ # 检测用户的键盘操作
+ key_pressed = pygame.key.get_pressed()
+
+ if key_pressed[K_w] or key_pressed[K_UP]:
+ me.moveUp()
+ elif key_pressed[K_s] or key_pressed[K_DOWN]:
+ me.moveDown()
+ elif key_pressed[K_a] or key_pressed[K_LEFT]:
+ me.moveLeft()
+ elif key_pressed[K_d] or key_pressed[K_RIGHT]:
+ me.moveRight()
+ elif key_pressed[K_F1]:#100核弹
+ bomb_num = 100
+ elif key_pressed[K_F2]:#不使用双子弹
+ is_double_bullet = True
+ elif key_pressed[K_F3]:#使用双子弹
+ is_double_bullet = False
+ elif key_pressed[K_F4]:#生命+1
+ life_num += 1
+ elif key_pressed[K_F5]:#小+1
+ add_small_enemies(small_enemies, enemies, 100)
+ elif key_pressed[K_F6]:#中+1
+ add_mid_enemies(mid_enemies, enemies, 100)
+ elif key_pressed[K_F7]:#大+1
+ add_big_enemies(big_enemies, enemies, 100)
+ elif key_pressed[K_F8]:
+ level = 4
+ score = 1000000
+
+
+
+
+ # 绘制全屏炸弹补给并检测是否获得
+ if bomb_supply.active:
+ bomb_supply.move()
+ screen.blit(bomb_supply.image, bomb_supply.rect)
+ if pygame.sprite.collide_mask(bomb_supply, me):
+ get_bomb_sound.play()
+ if bomb_num < 3:
+ bomb_num += 1
+ bomb_supply.active = False
+
+ # 绘制超级子弹补给并检测是否获得
+ if bullet_supply.active:
+ bullet_supply.move()
+ screen.blit(bullet_supply.image, bullet_supply.rect)
+ if pygame.sprite.collide_mask(bullet_supply, me):
+ get_bullet_sound.play()
+ is_double_bullet = True
+ pygame.time.set_timer(DOUBLE_BULLET_TIME, 18 * 1000)
+ bullet_supply.active = False
+
+ # 发射子弹
+ if not(delay % 10):
+ bullet_sound.play()
+ if is_double_bullet:
+ bullets = bullet2
+ bullets[bullet2_index].reset((me.rect.centerx-33, me.rect.centery))
+ bullets[bullet2_index+1].reset((me.rect.centerx+30, me.rect.centery))
+ bullet2_index = (bullet2_index + 2) % BULLET2_NUM
+ else:
+ bullets = bullet1
+ bullets[bullet1_index].reset(me.rect.midtop)
+ bullet1_index = (bullet1_index + 1) % BULLET1_NUM
+
+
+ # 检测子弹是否击中敌机
+ for b in bullets:
+ if b.active:
+ b.move()
+ screen.blit(b.image, b.rect)
+ enemy_hit = pygame.sprite.spritecollide(b, enemies, False, pygame.sprite.collide_mask)
+ if enemy_hit:
+ b.active = False
+ for e in enemy_hit:
+ if e in mid_enemies or e in big_enemies:
+ e.hit = True
+ e.energy -= 1
+ if e.energy == 0:
+ e.active = False
+ else:
+ e.active = False
+
+ # 绘制大型敌机
+ for each in big_enemies:
+ if each.active:
+ each.move()
+ if each.hit:
+ screen.blit(each.image_hit, each.rect)
+ each.hit = False
+ else:
+ if switch_image:
+ screen.blit(each.image1, each.rect)
+ else:
+ screen.blit(each.image2, each.rect)
+
+ # 绘制血槽
+ pygame.draw.line(screen, BLACK, \
+ (each.rect.left, each.rect.top - 5), \
+ (each.rect.right, each.rect.top - 5), \
+ 2)
+ # 当生命大于20%显示绿色,否则显示红色
+ energy_remain = each.energy / enemy.BigEnemy.energy
+ if energy_remain > 0.2:
+ energy_color = GREEN
+ else:
+ energy_color = RED
+ pygame.draw.line(screen, energy_color, \
+ (each.rect.left, each.rect.top - 5), \
+ (each.rect.left + each.rect.width * energy_remain, \
+ each.rect.top - 5), 2)
+
+ # 即将出现在画面中,播放音效
+ if each.rect.bottom == -50:
+ enemy3_fly_sound.play(-1)
+ else:
+ # 毁灭
+ if not(delay % 3):
+ if e3_destroy_index == 0:
+ enemy3_down_sound.play()
+ screen.blit(each.destroy_images[e3_destroy_index], each.rect)
+ e3_destroy_index = (e3_destroy_index + 1) % 6
+ if e3_destroy_index == 0:
+ enemy3_fly_sound.stop()
+ score += 10000
+ each.reset()
+
+ # 绘制中型敌机:
+ for each in mid_enemies:
+ if each.active:
+ each.move()
+
+ if each.hit:
+ screen.blit(each.image_hit, each.rect)
+ each.hit = False
+ else:
+ screen.blit(each.image, each.rect)
+
+ # 绘制血槽
+ pygame.draw.line(screen, BLACK, \
+ (each.rect.left, each.rect.top - 5), \
+ (each.rect.right, each.rect.top - 5), \
+ 2)
+ # 当生命大于20%显示绿色,否则显示红色
+ lu = (0, 230, 0)
+ qiancheng = (115, 165, 0)
+ shencheng = (165, 115, 0)
+ hong = (230, 0, 0)
+ energy_remain = each.energy / enemy.MidEnemy.energy
+ if energy_remain > 0.75:
+ energy_color = lu
+ elif energy_remain > 0.50:
+ energy_color = qiancheng
+ elif energy_remain > 0.25:
+ energy_color = shencheng
+ else:
+ energy_color = hong
+ pygame.draw.line(screen, energy_color, \
+ (each.rect.left, each.rect.top - 5), \
+ (each.rect.left + each.rect.width * energy_remain, \
+ each.rect.top - 5), 2)
+ else:
+ # 毁灭
+ if not(delay % 3):
+ if e2_destroy_index == 0:
+ enemy2_down_sound.play()
+ screen.blit(each.destroy_images[e2_destroy_index], each.rect)
+ e2_destroy_index = (e2_destroy_index + 1) % 4
+ if e2_destroy_index == 0:
+ score += 6000
+ each.reset()
+
+ # 绘制小型敌机:
+ for each in small_enemies:
+ if each.active:
+ each.move()
+ screen.blit(each.image, each.rect)
+ else:
+ # 毁灭
+ if not(delay % 3):
+ if e1_destroy_index == 0:
+ enemy1_down_sound.play()
+ score += 1000
+ each.reset()
+ screen.blit(each.destroy_images[e1_destroy_index], each.rect)
+ e1_destroy_index = (e1_destroy_index + 1) % 4
+
+ # 检测我方飞机是否被撞
+ enemies_down = pygame.sprite.spritecollide(me, enemies, False, pygame.sprite.collide_mask)
+ if enemies_down and not me.invincible:
+ me.active = False
+ for e in enemies_down:
+ e.active = False
+
+ # 绘制我方飞机
+ if me.active:
+ if switch_image:
+ screen.blit(me.image1, me.rect)
+ else:
+ screen.blit(me.image2, me.rect)
+ else:
+ # 毁灭
+ if not(delay % 3):
+ if me_destroy_index == 0:
+ me_down_sound.play()
+ screen.blit(me.destroy_images[me_destroy_index], me.rect)
+ me_destroy_index = (me_destroy_index + 1) % 4
+ if me_destroy_index == 0:
+ life_num -= 1
+ me.reset()
+ pygame.time.set_timer(INVINCIBLE_TIME, 3 * 1000)
+
+ # 绘制全屏炸弹数量
+ bomb_text = bomb_font.render("× %d" % bomb_num, True, WHITE)
+ text_rect = bomb_text.get_rect()
+ screen.blit(bomb_image, (10, height - 10 - bomb_rect.height))
+ screen.blit(bomb_text, (20 + bomb_rect.width, height - 5 - text_rect.height))
+
+ # 绘制剩余生命数量
+ if life_num:
+ for i in range(life_num):
+ screen.blit(life_image, \
+ (width-10-(i+1)*life_rect.width, \
+ height-10-life_rect.height))
+
+ # 绘制得分
+ score_text = score_font.render("Score : %s" % str(score), True, WHITE)
+ screen.blit(score_text, (10, 5))
+
+ # 绘制游戏结束画面
+ elif life_num == 0:
+ # 背景音乐停止
+ pygame.mixer.music.stop()
+
+ # 停止全部音效
+ pygame.mixer.stop()
+
+ # 停止发放补给
+ pygame.time.set_timer(SUPPLY_TIME, 0)
+
+ if not recorded:
+ recorded = True
+ # 读取历史最高得分
+ with open("record.dat", "r") as f:
+ record_score = int(f.read())
+
+ # 如果玩家得分高于历史最高得分,则存档
+ if score > record_score:
+ with open("record.dat", "w") as f:
+ f.write(str(score))
+
+ # 绘制结束画面
+ record_score_text = score_font.render("Best : %d" % record_score, True, (255, 255, 255))
+ screen.blit(record_score_text, (50, 50))
+
+ gameover_text1 = gameover_font.render("Your Score", True, (255, 255, 255))
+ gameover_text1_rect = gameover_text1.get_rect()
+ gameover_text1_rect.left, gameover_text1_rect.top = \
+ (width - gameover_text1_rect.width) // 2, height // 3
+ screen.blit(gameover_text1, gameover_text1_rect)
+
+ gameover_text2 = gameover_font.render(str(score), True, (255, 255, 255))
+ gameover_text2_rect = gameover_text2.get_rect()
+ gameover_text2_rect.left, gameover_text2_rect.top = \
+ (width - gameover_text2_rect.width) // 2, \
+ gameover_text1_rect.bottom + 10
+ screen.blit(gameover_text2, gameover_text2_rect)
+
+ again_rect.left, again_rect.top = \
+ (width - again_rect.width) // 2, \
+ gameover_text2_rect.bottom + 50
+ screen.blit(again_image, again_rect)
+
+ gameover_rect.left, gameover_rect.top = \
+ (width - again_rect.width) // 2, \
+ again_rect.bottom + 10
+ screen.blit(gameover_image, gameover_rect)
+
+ # 检测用户的鼠标操作
+ # 如果用户按下鼠标左键
+ if pygame.mouse.get_pressed()[0]:
+ # 获取鼠标坐标
+ pos = pygame.mouse.get_pos()
+ # 如果用户点击“重新开始”
+ if again_rect.left < pos[0] < again_rect.right and \
+ again_rect.top < pos[1] < again_rect.bottom:
+ # 调用main函数,重新开始游戏
+ main()
+ # 如果用户点击“结束游戏”
+ elif gameover_rect.left < pos[0] < gameover_rect.right and \
+ gameover_rect.top < pos[1] < gameover_rect.bottom:
+ # 退出游戏
+ pygame.quit()
+ sys.exit()
+
+ # 绘制暂停按钮
+ screen.blit(paused_image, paused_rect)
+
+ # 切换图片
+ if not(delay % 5):
+ switch_image = not switch_image
+
+ delay -= 1
+ if not delay:
+ delay = 100
+
+ pygame.display.flip()
+ clock.tick(60)
+
+if __name__ == "__main__":
+ try:
+ main()
+ except SystemExit:
+ pass
+ except:
+ traceback.print_exc()
+ pygame.quit()
+ input()
diff --git a/plane_fighting/myplane.py b/plane_fighting/myplane.py
new file mode 100644
index 0000000..f28bffc
--- /dev/null
+++ b/plane_fighting/myplane.py
@@ -0,0 +1,55 @@
+import pygame,os
+abspath = os.getcwd() + "/"
+class MyPlane(pygame.sprite.Sprite):
+ def __init__(self, bg_size):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image1 = pygame.image.load(abspath + "images/me1.png").convert_alpha()
+ self.image2 = pygame.image.load(abspath + "images/me2.png").convert_alpha()
+ self.destroy_images = []
+ self.destroy_images.extend([\
+ pygame.image.load(abspath + "images/me_destroy_1.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/me_destroy_2.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/me_destroy_3.png").convert_alpha(), \
+ pygame.image.load(abspath + "images/me_destroy_4.png").convert_alpha() \
+ ])
+ self.rect = self.image1.get_rect()
+ self.width, self.height = bg_size[0], bg_size[1]
+ self.rect.left, self.rect.top = \
+ (self.width - self.rect.width) // 2, \
+ self.height - self.rect.height - 60
+ self.speed = 10
+ self.active = True
+ self.invincible = False
+ self.mask = pygame.mask.from_surface(self.image1)
+
+ def moveUp(self):
+ if self.rect.top > 0:
+ self.rect.top -= self.speed
+ else:
+ self.rect.top = 0
+
+ def moveDown(self):
+ if self.rect.bottom < self.height - 60:
+ self.rect.top += self.speed
+ else:
+ self.rect.bottom = self.height - 60
+
+ def moveLeft(self):
+ if self.rect.left > 0:
+ self.rect.left -= self.speed
+ else:
+ self.rect.left = 0
+
+ def moveRight(self):
+ if self.rect.right < self.width:
+ self.rect.left += self.speed
+ else:
+ self.rect.right = self.width
+
+ def reset(self):
+ self.rect.left, self.rect.top = \
+ (self.width - self.rect.width) // 2, \
+ self.height - self.rect.height - 60
+ self.active = True
+ self.invincible = True
diff --git a/plane_fighting/old_images/again.png b/plane_fighting/old_images/again.png
new file mode 100644
index 0000000..627e7b3
Binary files /dev/null and b/plane_fighting/old_images/again.png differ
diff --git a/plane_fighting/old_images/background.png b/plane_fighting/old_images/background.png
new file mode 100644
index 0000000..01e4a5d
Binary files /dev/null and b/plane_fighting/old_images/background.png differ
diff --git a/plane_fighting/old_images/bomb.png b/plane_fighting/old_images/bomb.png
new file mode 100644
index 0000000..1b988d2
Binary files /dev/null and b/plane_fighting/old_images/bomb.png differ
diff --git a/plane_fighting/old_images/bomb_supply.png b/plane_fighting/old_images/bomb_supply.png
new file mode 100644
index 0000000..b2ef345
Binary files /dev/null and b/plane_fighting/old_images/bomb_supply.png differ
diff --git a/plane_fighting/old_images/bullet1.png b/plane_fighting/old_images/bullet1.png
new file mode 100644
index 0000000..6c4e3d6
Binary files /dev/null and b/plane_fighting/old_images/bullet1.png differ
diff --git a/plane_fighting/old_images/bullet2.png b/plane_fighting/old_images/bullet2.png
new file mode 100644
index 0000000..cc0258e
Binary files /dev/null and b/plane_fighting/old_images/bullet2.png differ
diff --git a/plane_fighting/old_images/bullet_supply.png b/plane_fighting/old_images/bullet_supply.png
new file mode 100644
index 0000000..9cf6fdd
Binary files /dev/null and b/plane_fighting/old_images/bullet_supply.png differ
diff --git a/plane_fighting/old_images/enemy1.png b/plane_fighting/old_images/enemy1.png
new file mode 100644
index 0000000..88774c7
Binary files /dev/null and b/plane_fighting/old_images/enemy1.png differ
diff --git a/plane_fighting/old_images/enemy1_down1.png b/plane_fighting/old_images/enemy1_down1.png
new file mode 100644
index 0000000..fd5af5d
Binary files /dev/null and b/plane_fighting/old_images/enemy1_down1.png differ
diff --git a/plane_fighting/old_images/enemy1_down2.png b/plane_fighting/old_images/enemy1_down2.png
new file mode 100644
index 0000000..69cf644
Binary files /dev/null and b/plane_fighting/old_images/enemy1_down2.png differ
diff --git a/plane_fighting/old_images/enemy1_down3.png b/plane_fighting/old_images/enemy1_down3.png
new file mode 100644
index 0000000..7a9a94c
Binary files /dev/null and b/plane_fighting/old_images/enemy1_down3.png differ
diff --git a/plane_fighting/old_images/enemy1_down4.png b/plane_fighting/old_images/enemy1_down4.png
new file mode 100644
index 0000000..a5d8a84
Binary files /dev/null and b/plane_fighting/old_images/enemy1_down4.png differ
diff --git a/plane_fighting/old_images/enemy2.png b/plane_fighting/old_images/enemy2.png
new file mode 100644
index 0000000..cd3f415
Binary files /dev/null and b/plane_fighting/old_images/enemy2.png differ
diff --git a/plane_fighting/old_images/enemy2_down1.png b/plane_fighting/old_images/enemy2_down1.png
new file mode 100644
index 0000000..93ec9d5
Binary files /dev/null and b/plane_fighting/old_images/enemy2_down1.png differ
diff --git a/plane_fighting/old_images/enemy2_down2.png b/plane_fighting/old_images/enemy2_down2.png
new file mode 100644
index 0000000..c234755
Binary files /dev/null and b/plane_fighting/old_images/enemy2_down2.png differ
diff --git a/plane_fighting/old_images/enemy2_down3.png b/plane_fighting/old_images/enemy2_down3.png
new file mode 100644
index 0000000..37d3d2c
Binary files /dev/null and b/plane_fighting/old_images/enemy2_down3.png differ
diff --git a/plane_fighting/old_images/enemy2_down4.png b/plane_fighting/old_images/enemy2_down4.png
new file mode 100644
index 0000000..1e10fc7
Binary files /dev/null and b/plane_fighting/old_images/enemy2_down4.png differ
diff --git a/plane_fighting/old_images/enemy2_hit.png b/plane_fighting/old_images/enemy2_hit.png
new file mode 100644
index 0000000..463ec69
Binary files /dev/null and b/plane_fighting/old_images/enemy2_hit.png differ
diff --git a/plane_fighting/old_images/enemy3_down1.png b/plane_fighting/old_images/enemy3_down1.png
new file mode 100644
index 0000000..2288724
Binary files /dev/null and b/plane_fighting/old_images/enemy3_down1.png differ
diff --git a/plane_fighting/old_images/enemy3_down2.png b/plane_fighting/old_images/enemy3_down2.png
new file mode 100644
index 0000000..6bd2bab
Binary files /dev/null and b/plane_fighting/old_images/enemy3_down2.png differ
diff --git a/plane_fighting/old_images/enemy3_down3.png b/plane_fighting/old_images/enemy3_down3.png
new file mode 100644
index 0000000..64a6154
Binary files /dev/null and b/plane_fighting/old_images/enemy3_down3.png differ
diff --git a/plane_fighting/old_images/enemy3_down4.png b/plane_fighting/old_images/enemy3_down4.png
new file mode 100644
index 0000000..1592446
Binary files /dev/null and b/plane_fighting/old_images/enemy3_down4.png differ
diff --git a/plane_fighting/old_images/enemy3_down5.png b/plane_fighting/old_images/enemy3_down5.png
new file mode 100644
index 0000000..04e53ba
Binary files /dev/null and b/plane_fighting/old_images/enemy3_down5.png differ
diff --git a/plane_fighting/old_images/enemy3_down6.png b/plane_fighting/old_images/enemy3_down6.png
new file mode 100644
index 0000000..5fc1c90
Binary files /dev/null and b/plane_fighting/old_images/enemy3_down6.png differ
diff --git a/plane_fighting/old_images/enemy3_hit.png b/plane_fighting/old_images/enemy3_hit.png
new file mode 100644
index 0000000..1373efc
Binary files /dev/null and b/plane_fighting/old_images/enemy3_hit.png differ
diff --git a/plane_fighting/old_images/enemy3_n1.png b/plane_fighting/old_images/enemy3_n1.png
new file mode 100644
index 0000000..813cf51
Binary files /dev/null and b/plane_fighting/old_images/enemy3_n1.png differ
diff --git a/plane_fighting/old_images/enemy3_n2.png b/plane_fighting/old_images/enemy3_n2.png
new file mode 100644
index 0000000..5853cf1
Binary files /dev/null and b/plane_fighting/old_images/enemy3_n2.png differ
diff --git a/plane_fighting/old_images/gameover.png b/plane_fighting/old_images/gameover.png
new file mode 100644
index 0000000..2349fb0
Binary files /dev/null and b/plane_fighting/old_images/gameover.png differ
diff --git a/plane_fighting/old_images/life.png b/plane_fighting/old_images/life.png
new file mode 100644
index 0000000..1c071b5
Binary files /dev/null and b/plane_fighting/old_images/life.png differ
diff --git a/plane_fighting/old_images/loading.png b/plane_fighting/old_images/loading.png
new file mode 100644
index 0000000..5968679
Binary files /dev/null and b/plane_fighting/old_images/loading.png differ
diff --git a/plane_fighting/old_images/me1.png b/plane_fighting/old_images/me1.png
new file mode 100644
index 0000000..9517f01
Binary files /dev/null and b/plane_fighting/old_images/me1.png differ
diff --git a/plane_fighting/old_images/me2.png b/plane_fighting/old_images/me2.png
new file mode 100644
index 0000000..18ea8e3
Binary files /dev/null and b/plane_fighting/old_images/me2.png differ
diff --git a/plane_fighting/old_images/me_destroy_1.png b/plane_fighting/old_images/me_destroy_1.png
new file mode 100644
index 0000000..a87e447
Binary files /dev/null and b/plane_fighting/old_images/me_destroy_1.png differ
diff --git a/plane_fighting/old_images/me_destroy_2.png b/plane_fighting/old_images/me_destroy_2.png
new file mode 100644
index 0000000..3429a30
Binary files /dev/null and b/plane_fighting/old_images/me_destroy_2.png differ
diff --git a/plane_fighting/old_images/me_destroy_3.png b/plane_fighting/old_images/me_destroy_3.png
new file mode 100644
index 0000000..215ffb4
Binary files /dev/null and b/plane_fighting/old_images/me_destroy_3.png differ
diff --git a/plane_fighting/old_images/me_destroy_4.png b/plane_fighting/old_images/me_destroy_4.png
new file mode 100644
index 0000000..1e713e9
Binary files /dev/null and b/plane_fighting/old_images/me_destroy_4.png differ
diff --git a/plane_fighting/old_images/pause_nor.png b/plane_fighting/old_images/pause_nor.png
new file mode 100644
index 0000000..f6ef291
Binary files /dev/null and b/plane_fighting/old_images/pause_nor.png differ
diff --git a/plane_fighting/old_images/pause_pressed.png b/plane_fighting/old_images/pause_pressed.png
new file mode 100644
index 0000000..f6ef291
Binary files /dev/null and b/plane_fighting/old_images/pause_pressed.png differ
diff --git a/plane_fighting/old_images/resume_nor.png b/plane_fighting/old_images/resume_nor.png
new file mode 100644
index 0000000..a4db815
Binary files /dev/null and b/plane_fighting/old_images/resume_nor.png differ
diff --git a/plane_fighting/old_images/resume_pressed.png b/plane_fighting/old_images/resume_pressed.png
new file mode 100644
index 0000000..a4db815
Binary files /dev/null and b/plane_fighting/old_images/resume_pressed.png differ
diff --git a/plane_fighting/pyinstaller.spec b/plane_fighting/pyinstaller.spec
new file mode 100644
index 0000000..2d2c17f
--- /dev/null
+++ b/plane_fighting/pyinstaller.spec
@@ -0,0 +1,40 @@
+# -*- mode: python ; coding: utf-8 -*-
+
+
+block_cipher = None
+
+
+a = Analysis(['main.py','bullet.py','enemy.py','myplane.py','supply.py'],
+ pathex=[],
+ binaries=[("font", "images", "sound")]
+ datas=["record.dat"],
+ hiddenimports=[],
+ hookspath=[],
+ hooksconfig={},
+ runtime_hooks=[],
+ excludes=[],
+ win_no_prefer_redirects=False,
+ win_private_assemblies=False,
+ cipher=block_cipher,
+ noarchive=False)
+pyz = PYZ(a.pure, a.zipped_data,
+ cipher=block_cipher)
+
+exe = EXE(pyz,
+ a.scripts,
+ a.binaries,
+ a.zipfiles,
+ a.datas,
+ [],
+ name='Plane Fighting',
+ debug=False,
+ bootloader_ignore_signals=False,
+ strip=False,
+ upx=True,
+ upx_exclude=[],
+ runtime_tmpdir=None,
+ console=False,
+ disable_windowed_traceback=False,
+ target_arch=None,
+ codesign_identity=None,
+ entitlements_file=None )
diff --git a/plane_fighting/record.dat b/plane_fighting/record.dat
new file mode 100644
index 0000000..573541a
--- /dev/null
+++ b/plane_fighting/record.dat
@@ -0,0 +1 @@
+0
diff --git a/plane_fighting/sound/bullet.wav b/plane_fighting/sound/bullet.wav
new file mode 100644
index 0000000..cb97090
Binary files /dev/null and b/plane_fighting/sound/bullet.wav differ
diff --git a/plane_fighting/sound/button.wav b/plane_fighting/sound/button.wav
new file mode 100644
index 0000000..f7b246f
Binary files /dev/null and b/plane_fighting/sound/button.wav differ
diff --git a/plane_fighting/sound/enemy1_down.wav b/plane_fighting/sound/enemy1_down.wav
new file mode 100644
index 0000000..2baa2d2
Binary files /dev/null and b/plane_fighting/sound/enemy1_down.wav differ
diff --git a/plane_fighting/sound/enemy2_down.wav b/plane_fighting/sound/enemy2_down.wav
new file mode 100644
index 0000000..b72fa43
Binary files /dev/null and b/plane_fighting/sound/enemy2_down.wav differ
diff --git a/plane_fighting/sound/enemy3_down.wav b/plane_fighting/sound/enemy3_down.wav
new file mode 100644
index 0000000..f7c59fb
Binary files /dev/null and b/plane_fighting/sound/enemy3_down.wav differ
diff --git a/plane_fighting/sound/enemy3_flying.wav b/plane_fighting/sound/enemy3_flying.wav
new file mode 100644
index 0000000..6c57d7d
Binary files /dev/null and b/plane_fighting/sound/enemy3_flying.wav differ
diff --git a/plane_fighting/sound/game_music.ogg b/plane_fighting/sound/game_music.ogg
new file mode 100644
index 0000000..97b59d2
Binary files /dev/null and b/plane_fighting/sound/game_music.ogg differ
diff --git a/plane_fighting/sound/get_bomb.wav b/plane_fighting/sound/get_bomb.wav
new file mode 100644
index 0000000..541933f
Binary files /dev/null and b/plane_fighting/sound/get_bomb.wav differ
diff --git a/plane_fighting/sound/get_bullet.wav b/plane_fighting/sound/get_bullet.wav
new file mode 100644
index 0000000..39e4844
Binary files /dev/null and b/plane_fighting/sound/get_bullet.wav differ
diff --git a/plane_fighting/sound/loading_game.ogg b/plane_fighting/sound/loading_game.ogg
new file mode 100644
index 0000000..97b59d2
Binary files /dev/null and b/plane_fighting/sound/loading_game.ogg differ
diff --git a/plane_fighting/sound/me_down.wav b/plane_fighting/sound/me_down.wav
new file mode 100644
index 0000000..8ecab0f
Binary files /dev/null and b/plane_fighting/sound/me_down.wav differ
diff --git a/plane_fighting/sound/supply.wav b/plane_fighting/sound/supply.wav
new file mode 100644
index 0000000..a184de9
Binary files /dev/null and b/plane_fighting/sound/supply.wav differ
diff --git a/plane_fighting/sound/upgrade.wav b/plane_fighting/sound/upgrade.wav
new file mode 100644
index 0000000..b856b32
Binary files /dev/null and b/plane_fighting/sound/upgrade.wav differ
diff --git a/plane_fighting/sound/use_bomb.wav b/plane_fighting/sound/use_bomb.wav
new file mode 100644
index 0000000..4c60777
Binary files /dev/null and b/plane_fighting/sound/use_bomb.wav differ
diff --git a/plane_fighting/supply.py b/plane_fighting/supply.py
new file mode 100644
index 0000000..70d7986
--- /dev/null
+++ b/plane_fighting/supply.py
@@ -0,0 +1,51 @@
+import pygame,os
+from random import *
+
+abspath = os.getcwd() + "/"
+class Bullet_Supply(pygame.sprite.Sprite):
+ def __init__(self, bg_size):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image = pygame.image.load(abspath + "images/bullet_supply.png").convert_alpha()
+ self.rect = self.image.get_rect()
+ self.width, self.height = bg_size[0], bg_size[1]
+ self.rect.left, self.rect.bottom = \
+ randint(0, self.width - self.rect.width), -100
+ self.speed = 5
+ self.active = False
+ self.mask = pygame.mask.from_surface(self.image)
+
+ def move(self):
+ if self.rect.top < self.height:
+ self.rect.top += self.speed
+ else:
+ self.active = False
+
+ def reset(self):
+ self.active = True
+ self.rect.left, self.rect.bottom = \
+ randint(0, self.width - self.rect.width), -100
+
+class Bomb_Supply(pygame.sprite.Sprite):
+ def __init__(self, bg_size):
+ pygame.sprite.Sprite.__init__(self)
+
+ self.image = pygame.image.load(abspath + "images/bomb_supply.png").convert_alpha()
+ self.rect = self.image.get_rect()
+ self.width, self.height = bg_size[0], bg_size[1]
+ self.rect.left, self.rect.bottom = \
+ randint(0, self.width - self.rect.width), -100
+ self.speed = 5
+ self.active = False
+ self.mask = pygame.mask.from_surface(self.image)
+
+ def move(self):
+ if self.rect.top < self.height:
+ self.rect.top += self.speed
+ else:
+ self.active = False
+
+ def reset(self):
+ self.active = True
+ self.rect.left, self.rect.bottom = \
+ randint(0, self.width - self.rect.width), -100
diff --git a/python_https_server/README.md b/python_https_server/README.md
new file mode 100644
index 0000000..809e9e9
--- /dev/null
+++ b/python_https_server/README.md
@@ -0,0 +1,8 @@
+# Python HTTPS Server (python_https_server)
+## 简介
+一个 HTTPS 网络服务器程序
+## 支持
+需要一个证书
+基于 Python 运行
+## 协议
+本目录中所有的源代码文件根据 MIT 协议开源
\ No newline at end of file
diff --git a/python_https_server/https_svr_key.pem b/python_https_server/https_svr_key.pem
new file mode 100644
index 0000000..e706fbb
--- /dev/null
+++ b/python_https_server/https_svr_key.pem
@@ -0,0 +1,49 @@
+-----BEGIN PRIVATE KEY-----
+MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQCe+wWQgjueNm66
+zGE85YViKACs3wL786toKY03mreqvQ6Ffz4tTfXtJdFuFem4n+FEUp9SKhpaGPxN
+mX7cRX/v+6jqkYDOMvyp9w2y/t0rTivSsJr8micFmmRN/gpJH8Ma9Zl28hjPYS8c
+8gCnIevk/we1vd/IZYCMnRQKuTHh1kUWgBLuRDEwsD2Ka7iVVvonDZMJye42IHoG
+PO+bif1SBDkW8NkX4TFg0iFKxeplLqAVVx5hgs8pMGjgvGp1HIRJdOcTurXWZIHM
+cr9nAALRriOA76BOOOYvuljPqf8oPAVqiP+bHHRWNGaeVwAZnGRB369SZbaO9CmZ
+rf4Xk2pXAgMBAAECggEACYTWLHTfxPVVY/Hg0Jidh+cFQ1SHBTbtyGrUfcPRw3NW
+bz/TJTtJwk1FYOYG/Hr2LfUUfQLwWPyt/qd2JRI0OtZCoujbYX1EC5kzRMhlzbX8
+gbz5Sq6gL4GzB8hyLTato+uYqLqOKbyT6ZPD3j31tdxfRc58m68YJ1MwZAP6rJ7j
+kUGmgg2OlQp7X0EJE5ivDHNYNlluAGD0uLZuyt5+3WnK/ms7sySVBg8BIipS/iQj
+vv01VlanQNZGYrZurJ8s1PjRyDR/1HI6HjJPCt7XD6LLKla7KV+IBI0tXbkZ7tAw
+UYQaKBB4R9elqhgxIAU5xbhqmqlXp/diucLb4S4awQKBgQDPQcfQq030JXvL6eWx
+veN34AWHyi88Ipi5ildJJr/bmIJH6/p8SqhrVHaEzjATDYNAfyRnxLcLgsEVMkl6
+njZKt4FKVXaCKHJfksnmHrrBnhSzpvL8OWL9rZDqBqLRjQ3FmwtF6uiPIbaoY33+
+X/MiYCC/Bdo+yQbvHUekoGb03wKBgQDEXq/sbPjOfSyWkeIfl2bPcnSPLsu7nR+O
+ywXHxh/ftUoSCOR6qCW2er3IxfMwTIE8agitgi3H29Tj7UlaohCqjjDB/lA0I8PG
+3LsI9fIk20ZE+wE9hJxoHJI2fXM8v1DAnNZ49bUMEUQ75epH6L3BjyPoh8kp7BbO
+X9obnaqBiQKBgECiTQQgSCE5h0/iU4WIqGV78X2VagGg8Gv8Xpgrg22iNA7l4qnc
+RoWiQ4vLGWb3sdTtUZci28q1Li3EDvI0YM4QSDu8R0b0AicYCeq/7pHvEJmuGNzb
+sKlX9XdmNmSPTpovbeaSCZCJfQMqc+JeXd58h/nKg3NNEeKECRGoDDOVAoGAVK9d
+AQHxvuMeooShVuxtKxN6DvGobO2S2XrWsFPSFSDSo7pwBjGTqgF+7SHpAbBMn6g+
+u80DP0ifo/gGBW8U7ujJQDATmJi/6nfwtSmT1q81u7Pf0g7pgMCpkZRCaTU8dwRs
+PdgAzwZ3PbmmcoJ9qwa2/qXobArjvvZ5UiWJjbkCgYBN0hspwEszCUmeGdRBgQGf
+yM9YHeqx+N1PeH2M64l7XcYN5fp/g//3CRDrOjuYtVEN/FImYPEVZ9ZgLY2DTSDT
+VDk6TGD7mkn6rGMq6z7ik7Zwp4oP4TIuIHogglpuKmFu3YO7DYfBBcL104vYcTEo
+unsnUGiTNNfxctLK/2yKcQ==
+-----END PRIVATE KEY-----
+-----BEGIN CERTIFICATE-----
+MIIDazCCAlOgAwIBAgIULxW2C/o4zLPTG+pNAzPBCFSEnAEwDQYJKoZIhvcNAQEL
+BQAwRTELMAkGA1UEBhMCQVUxEzARBgNVBAgMClNvbWUtU3RhdGUxITAfBgNVBAoM
+GEludGVybmV0IFdpZGdpdHMgUHR5IEx0ZDAeFw0yMjAzMDIxNTQ4MzVaFw0zMjAy
+MjgxNTQ4MzVaMEUxCzAJBgNVBAYTAkFVMRMwEQYDVQQIDApTb21lLVN0YXRlMSEw
+HwYDVQQKDBhJbnRlcm5ldCBXaWRnaXRzIFB0eSBMdGQwggEiMA0GCSqGSIb3DQEB
+AQUAA4IBDwAwggEKAoIBAQCe+wWQgjueNm66zGE85YViKACs3wL786toKY03mreq
+vQ6Ffz4tTfXtJdFuFem4n+FEUp9SKhpaGPxNmX7cRX/v+6jqkYDOMvyp9w2y/t0r
+TivSsJr8micFmmRN/gpJH8Ma9Zl28hjPYS8c8gCnIevk/we1vd/IZYCMnRQKuTHh
+1kUWgBLuRDEwsD2Ka7iVVvonDZMJye42IHoGPO+bif1SBDkW8NkX4TFg0iFKxepl
+LqAVVx5hgs8pMGjgvGp1HIRJdOcTurXWZIHMcr9nAALRriOA76BOOOYvuljPqf8o
+PAVqiP+bHHRWNGaeVwAZnGRB369SZbaO9CmZrf4Xk2pXAgMBAAGjUzBRMB0GA1Ud
+DgQWBBQw7XwOekH/mm4y2oSuQ4FFrfqPPjAfBgNVHSMEGDAWgBQw7XwOekH/mm4y
+2oSuQ4FFrfqPPjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBCwUAA4IBAQB/
++bSYD+p8vnxB5U5tjV+S7Sw1tXEPkwCNdX/fRXh0waFQ9WIkttbHXwPK2/DurgOE
+uG9fU3XMTWpOzSisDIRlySerxfunZM63nB/GnW7SnyqfcUBXZHU875Gsdvt3ZNIi
+RoH/Wvkc8S5taUMzg/gxaEe2Ss52cvR1TfqWz0WtkyVcaX8TF3q0niecznimiRMc
+ptUw19v0KM5JbPLdZYPXZehBFdy79wzlBvqScKglNguXF4Hfjqagox+PPzO1HEJk
+z8GSMfZSm7ayDIJk4bkGZ+KFJZil1wM3hf0QQlZVNZexv6Wv+vyXkpl8Ext5Jb0k
+1+KOgCJmsCXJZ+D0OeqQ
+-----END CERTIFICATE-----
diff --git a/python_https_server/main.py b/python_https_server/main.py
new file mode 100644
index 0000000..9985305
--- /dev/null
+++ b/python_https_server/main.py
@@ -0,0 +1,35 @@
+#!/usr/bin/env python
+
+# taken from https://gist.github.com/dergachev/7028596
+#
+# generate server.xml with the following command:
+# openssl req -new -x509 -keyout https_svr_key.pem -out https_svr_key.pem -days 3650 -nodes
+#
+# run as follows:
+# python https_svr.py
+#
+# then in your browser, visit:
+# https://localhost:4443
+#
+
+import BaseHTTPServer
+import SimpleHTTPServer
+import os
+import socket
+import ssl
+
+script_home = os.path.dirname(os.path.abspath(__file__))
+ip = [(s.connect(('1.1.1.1', 53)), s.getsockname()[0], s.close()) \
+ for s in [socket.socket(socket.AF_INET, socket.SOCK_DGRAM)]][0][1]
+port = 443
+
+def main():
+ print ("simple https server, address:%s:%d, document root:%s" % (ip, port, script_home))
+
+ httpd = BaseHTTPServer.HTTPServer(('0.0.0.0', port), SimpleHTTPServer.SimpleHTTPRequestHandler)
+ httpd.socket = ssl.wrap_socket(httpd.socket, certfile='./https_svr_key.pem', server_side=True)
+ httpd.serve_forever()
+
+if __name__ == '__main__':
+ os.chdir(script_home)
+ main()