目录

14天学习训练营导师课程:
李宁《Python Pygame游戏开发入门与实战》
李宁《计算机视觉OpenCV Python项目实战》1
李宁《计算机视觉OpenCV Python项目实战》2
李宁《计算机视觉OpenCV Python项目实战》3
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pygame
from pygame.locals import * from sys import exit background_image = 'image/sushiplate.jpg' mouse_image = 'image/fugu.png' # 初始化pygame,为使用硬件做准备
pygame.init() # 创建了一个窗口
screen = pygame.display.set_mode((640, 480), 0, 32) # 设置窗口标题 pygame.display.set_caption("hello world") # 加载并转换图像
background = pygame.image.load(background_image).convert()
mouse_cursor = pygame.image.load(mouse_image).convert_alpha() while True: for event in pygame.event.get(): if event.type == QUIT:
# 接收到退出事件后退出程序 exit()
screen.blit(background, (0, 0)) # 画上背景图
x, y = pygame.mouse.get_pos() # 获得鼠标位置
-= mouse_cursor.get_width()/2 y -= mouse_cursor.get_height()/2 # 计算光标左上角位置x
screen.blit(mouse_cursor, (x, y)) # 画上光标
pygame.display.update() # 刷新画面
set_mode: 返回一个 Surface 对象,代表了桌面上出现的窗口。第一个参数代表分辨率;第二个参数是标志位,如果不需要使用热河特性,则指定为 0;第三个为色深。
| 标志位 | 功能 |
|---|---|
| FULLSCREEN | 创建一个全屏窗口 (create a fullscreen display) |
| DOUBLEBUF | 创建一个 “双缓冲” 窗口,建议在 HWSURFACE 或者 OPENGL 时使用( recommended for HWSURFACE or OPENGL) |
| HWSURFACE | 创建一个硬件加速的窗口,必须和 FULLSCREEN 同时使用( hardware accelerated, only in FULLSCREEN) |
| OPENGL | 创建一个 OPENGL 渲染的窗口 (create an OpenGL-renderable display) |
| RESIZABLE | 创建一个可以改变大小的窗口 (display window should be sizeable) |
| NOFRAME | 创建一个没有边框的窗口 (display window will have no border or controls) |
convert_alpha: 相比 convert,保留了 Alpha 通道信息(可以简单理解为透明的部分),这样我们的光标才可以是不规则的形状。可以试试不用 convert_alpha () 生成的效果。
blit: 第一个参数为一个 Surface 对象,第二个为左上角位置。画完以后得用 update 更新,否则画面一片漆黑。
我们上一个程序,一直运行直到关闭窗口而产生了一个 QUIT 事件,Pygame 会接受用户的各种操作(比如按键盘,移动鼠标等)产生事件。事件随时可能发生,而且量也可能会很大,Pygame 的做法是把一系列的事件存放一个队列里,逐个的处理。
上个程序中,使用了 pygame.event.get() 来处理所有的事件;也可以使用 pygame.event.wait(),pygame 会等到发生一个时间才继续下去;另外一个方法 pygame.event.poll(),一旦调用,它会根据现在的情形返回一个真实的事件,或者一个 “什么都没有”。下表是一个常用事件集:
| 事件 | 产生途径 | 参数 |
|---|---|---|
| QUIT | 用户按下关闭按钮 | none |
| ATIVEEVENT | Pygame 被激活或者隐藏 | gain, state |
| KEYDOWN | 键盘被按下 | unicode, key, mod |
| KEYUP | 键盘被放开 | key, mod |
| MOUSEMOTION | 鼠标移动 | pos, rel, buttons |
| MOUSEBUTTONDOWN | 鼠标按下 | pos, button |
| MOUSEBUTTONUP | 鼠标放开 | pos, button |
| JOYAXISMOTION | 游戏手柄 (Joystick or pad) 移动 | joy, axis, value |
| JOYBALLMOTION | 游戏球 (Joy ball)? 移动 | joy, axis, value |
| JOYHATMOTION | 游戏手柄 (Joystick)? 移动 | joy, axis, value |
| JOYBUTTONDOWN | 游戏手柄按下 | joy, button |
| JOYBUTTONUP | 游戏手柄放开 | joy, button |
| VIDEORESIZE | Pygame 窗口缩放 | size, w, h |
| VIDEOEXPOSE | Pygame 窗口部分公开 (expose)? | none |
| USEREVENT | 触发了一个用户事件 | code |
MOUSEMOTION 事件会在鼠标动作的时候发生,它有三个参数:
和 MOUSEMOTION 类似的,我们还有 MOUSEBUTTONDOWN 和 MOUSEBUTTONUP 两个事件。它们的参数为:
button – 这个值代表了哪个按键被操作
pos – 位置
键盘的事件为 KEYDOWN 和 KEYUP。
KEYDOWN 和 KEYUP 的参数描述如下:http://www.pygame.org/docs/ref/key.html
并不是所有的事件都需要处理。我们使用 pygame.event.set_blocked(type) 来完成。如果有好多事件需要过滤,可以传递一个列表,比如 pygame.event.set_blocked ([KEYDOWN, KEYUP]),如果你设置参数 None,那么所有的事件有被打开了。与之相对的,我们使用 pygame.event.set_allowed() 来设定允许的事件。
通常玩家做什么,Pygame 就产生对应的事件就可以了,不过有的时候我们需要模拟出一些事件来,比如录像回放的时候,我们就要把用户的操作再现一遍。
为了产生事件,必须先造一个出来,然后再传递它:
my_event = pygame.event.Event(KEYDOWN, key=K_SPACE, mod=0, unicode=' ')
# 你也可以像下面这样写
my_event = pygame.event.Event(KEYDOWN, {"key":K_SPACE, "mod":0, "unicode":' '}) pygame.event.post(my_event)
Event():Event (type, dict) 或者 Event (type, **attributes),
post(): 把新的事件放在事件队列的最后。
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pygame
from pygame.locals import * from sys import exit pygame.init() SCREEN_SIZE = (640, 480) screen = pygame.display.set_mode(SCREEN_SIZE, 0, 32)
font = pygame.font.SysFont("MicrosoftYaHei", 16)
font_height = font.get_linesize()
event_text = []
while True: event = pygame.event.wait()
event_text.append(str(event)) # 保证event_text里面只保留一个屏幕的文字
event_text = event_text[-SCREEN_SIZE[1]//font_height:]
if event.type == QUIT: exit() screen.fill((255, 255, 255)) # 寻找一个合适的起笔位置,最下面开始,留一行的空
y = SCREEN_SIZE[1] - font_height for text in reversed(event_text): screen.blit(font.render(text, True, (0, 0, 0)), (0, y)) y -= font_height pygame.display.update()
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pygame from pygame.locals
import * from sys
import exit
background_image = '../image/sushiplate.jpg'
screen = pygame.display.set_mode((640, 480), 0, 32)
background = pygame.image.load(background_image).convert()
x, y = 0, 0
move_x, move_y = 0, 0
while True:
for event in pygame.event.get():
if event.type == QUIT: exit()
if event.type == KEYDOWN:
if event.key == K_LEFT:
move_x = -1
elif
event.key == K_RIGHT: move_x = 1
elif
event.key == K_UP: move_y = -1
elif
event.key == K_DOWN: move_y = 1
elif
event.type == KEYUP: move_x = 0
move_y = 0
x += move_x
y += move_y
screen.fill((0, 0, 0))
screen.blit(background, (x,y))
pygame.display.update()
import pygame from pygame.locals
import * from sys
pygame.init()
my_event = pygame.event.Event(KEYDOWN, key=K_SPACE, mod=0, unicode=' ')
# my_event = pygame.event.Event(KEYDOWN,{"key":K_SPACE, "mod":0, "unicode":' '}) pygame.event.post(my_event) # 产生一个自定义的全新事件
CATONKEYBOARD = USEREVENT + 1
my_event = pygame.event.Event(CATONKEYBOARD, message="bad act!") pygame.event.post(my_event) # 获得这个事件
for event in pygame.event.get():
if event.type == CATONKEYBOARD: print( event.message)
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pygame from pygame.locals
import * from sys
import exit
background_image = '../image/sushiplate.jpg' sprite_image = '../image/fugu.png' pygame.init()
screen = pygame.display.set_mode((640, 480), 0, 32)
background = pygame.image.load(background_image).convert()
sprite = pygame.image.load(sprite_image) # sprite的起始坐标
x = 0
while True:
for event in pygame.event.get():
if event.type == QUIT: exit()
screen.blit(background, (0, 0))
screen.blit(sprite, (x, 100))
x += 1
if x>640:
x = 0
pygame.display.update()
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pygame from pygame.locals
import * from sys
import exit
background_image = '../image/sushiplate.jpg'
sprite_image = '../image/fugu.png'
pygame.init()
screen = pygame.display.set_mode((640, 480), 0, 32)
background = pygame.image.load(background_image).convert()
sprite = pygame.image.load(sprite_image)
clock = pygame.time.Clock()
x, y = 100, 100
speed_x, speed_y = 133, 170
while True:
for event in pygame.event.get(): if event.type == QUIT: exit()
screen.blit(background, (0, 0))
screen.blit(sprite, (x, y))
time_passed = clock.tick(30)
time_passed_seconds = time_passed/1000
x += speed_x * time_passed_seconds
y += speed_y * time_passed_seconds
# 到达边界后速度反向:
if x > 640 - sprite.get_width(): speed_x = -speed_x
x = 640 - sprite.get_width()
elif
x < 0: speed_x = -speed_x
x = 0
if y > 480 - sprite.get_height(): speed_y = -speed_y
y = 480 - sprite.get_height()
elif
y < 0: speed_y = -speed_y y = 0 pygame.display.update()
pygame 使用 pygame.draw 来绘制图形。其包含以下几种函数:
| 函数 | 作用 | 用法 |
|---|---|---|
| rect | 绘制矩形 | rect(Surface, color, Rect, width=0) |
| polygon | 绘制多边形 | polygon(Surface, color, pointlist, width=0) |
| circle | 绘制圆 | circle(Surface, color, pos, radius, width=0) |
| ellipse | 绘制椭圆 | ellipse(Surface, color, Rect, width=0) |
| arc | 绘制圆弧 | arc(Surface, color, Rect, start_angle, stop_angle, width=1) |
| line | 绘制线 | line(Surface, color, start_pos, end_pos, width=1) |
| lines | 绘制一系列的线 | lines(Surface, color, closed, pointlist, width=1) |
| aaline | 绘制一根平滑的线 | aaline(Surface, color, startpos, endpos, blend=1) |
| aalines | 绘制一系列平滑的线 | aalines(Surface, color, closed, pointlist, blend=1) |
width 参数:width 参数为 0 或省略,则填充。
画填充的矩形,有另一个方法 Surface.fill (),事实上,这种方法速度更快。
pygame.mouse 的函数:
pygame.mouse.get_pressed —— 返回按键按下情况,返回的是一元组,分别为 (左键,中键,右键),如按下则为 True
pygame.mouse.get_rel —— 返回相对偏移量,(x 方向,y 方向) 的一元组
pygame.mouse.get_pos —— 返回当前鼠标位置 (x, y)
pygame.mouse.set_pos —— 设置鼠标位置
pygame.mouse.set_visible —— 设置鼠标光标是否可见
pygame.mouse.get_focused —— 检查窗口是否接受鼠标事件,即鼠标是否 focus 到窗口
pygame.mouse.set_cursor —— 设置鼠标光标式样
pyGame.mouse.get_cursor —— 得到鼠标图片
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
最近在学习CAN,记录一下,也供大家参考交流。推荐几个我觉得很好的CAN学习,本文也是在看了他们的好文之后做的笔记首先是瑞萨的CAN入门,真的通透;秀!靠这篇我竟然2天理解了CAN协议!实战STM32F4CAN!原文链接:https://blog.csdn.net/XiaoXiaoPengBo/article/details/116206252CAN详解(小白教程)原文链接:https://blog.csdn.net/xwwwj/article/details/105372234一篇易懂的CAN通讯协议指南1一篇易懂的CAN通讯协议指南1-知乎(zhihu.com)视频推荐CAN总线个人知识总
深度学习部署:Windows安装pycocotools报错解决方法1.pycocotools库的简介2.pycocotools安装的坑3.解决办法更多Ai资讯:公主号AiCharm本系列是作者在跑一些深度学习实例时,遇到的各种各样的问题及解决办法,希望能够帮助到大家。ERROR:Commanderroredoutwithexitstatus1:'D:\Anaconda3\python.exe'-u-c'importsys,setuptools,tokenize;sys.argv[0]='"'"'C:\\Users\\46653\\AppData\\Local\\Temp\\pip-instal
@作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors 1、什么是behaviors 2、behaviors的工作方式 3、创建behavior 4、导入并使用behavior 5、behavior中所有可用的节点 6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors 1、什么是behaviorsbehaviors是小程序中,用于实现
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
ES一、简介1、ElasticStackES技术栈:ElasticSearch:存数据+搜索;QL;Kibana:Web可视化平台,分析。LogStash:日志收集,Log4j:产生日志;log.info(xxx)。。。。使用场景:metrics:指标监控…2、基本概念Index(索引)动词:保存(插入)名词:类似MySQL数据库,给数据Type(类型)已废弃,以前类似MySQL的表现在用索引对数据分类Document(文档)真正要保存的一个JSON数据{name:"tcx"}二、入门实战{"name":"DESKTOP-1TSVGKG","cluster_name":"elasticsear
我完全不是程序员,正在学习使用Ruby和Rails框架进行编程。我目前正在使用Ruby1.8.7和Rails3.0.3,但我想知道我是否应该升级到Ruby1.9,因为我真的没有任何升级的“遗留”成本。缺点是什么?我是否会遇到与普通gem的兼容性问题,或者甚至其他我不太了解甚至无法预料的问题? 最佳答案 你应该升级。不要坚持从1.8.7开始。如果您发现不支持1.9.2的gem,请避免使用它们(因为它们很可能不被维护)。如果您对gem是否兼容1.9.2有任何疑问,您可以在以下位置查看:http://www.railsplugins.or
我看到其他人也遇到过类似的问题,但没有一个解决方案对我有用。0.3.14gem与其他gem文件一起存在。我已经完全按照此处指示完成了所有操作:https://github.com/brianmario/mysql2.我仍然得到以下信息。我不知道为什么安装程序指示它找不到include目录,因为我已经检查过它存在。thread.h文件存在,但不在ruby目录中。相反,它在这里:C:\RailsInstaller\DevKit\lib\perl5\5.8\msys\CORE\我正在运行Windows7并尝试在Aptana3中构建我的Rails项目。我的Ruby是1.9.3。$gemin
我试图在Ubuntu14.04中使用Curl安装RVM。我运行了以下命令:\curl-sSLhttps://get.rvm.io|bash-sstable出现如下错误:curl:(7)Failedtoconnecttoget.rvm.ioport80:Networkisunreachable非常感谢解决此问题的任何帮助。谢谢 最佳答案 在执行curl之前尝试这个:echoipv4>>~/.curlrc 关于ruby-在Ubuntu14.04中使用Curl安装RVM时出错,我们在Stack
如何学习ruby的正则表达式?(对于假人) 最佳答案 http://www.rubular.com/在Ruby中使用正则表达式时是一个很棒的工具,因为它可以立即将结果可视化。 关于ruby-我如何学习ruby的正则表达式?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1881231/