processing-python-泡泡龙

Posted szh1213

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了processing-python-泡泡龙相关的知识,希望对你有一定的参考价值。

挂一个无耻搬运工:码农教程。
真的打心底里瞧不起为了蹭热度全网照抄代码的某些人。
再次此声明:代码不是python语言,求某些搬运工不要到处搬运害人。

 

 1 def setup():
 2     size(600,600)
 3     global x, y, vx, vy, bx, by, curBall, aliveBall
 4     global COLOR, c, bc
 5     #球需要有速度,位置,颜色三个属性
 6     #对应x,y坐标、x,y速度、c
 7     
 8     #上方球由于固定,可以只有位置和颜色属性
 9     #对应bx,by和bc
10 
11     x, y = width/2, height-15
12     #初始化球在中下位置,速度为0,颜色随机给一个
13     vx, vy = 0, 0
14     bx, by = [], []
15     curBall = []
16     aliveBall = []
17     COLOR = [color(227,41,54),color(41,188,227),color(41,227,48),color(250,239,13)]
18     #COLOR颜色列表,c和bc表示列表中的第几个颜色,而不是直接表示颜色
19     c = int(random(len(COLOR)))
20     bc = []
21     for i in range(20):
22         for j in range(10):
23             bx.append(i*30)
24             by.append( j*30)
25             curBall.append(len(curBall))#显示的球
26             aliveBall.append(len(aliveBall))#活着的球
27             bc.append(int(random(len(COLOR))))#死了的球
28             
29 def draw():
30     global x, y, vx, vy, bx, by, curBall, aliveBall
31     global COLOR, c, bc
32     
33     background(255)
34     def findDead(i):
35         d = [i]#打中了第i号球,d[]记录接下来找到的应该死掉的球
36         def tmp(i):
37             for j in curBall:
38             #找和i相邻且同色的球,
39             #首先排除掉已经找到的球,然后需要颜色编号相同,其次需要距离小于两球半径之和
40                 if j not in d and bc[j]==bc[i] and dist(bx[i],by[i],bx[j],by[j])<31:
41                     d.append(j)#确认过眼神,找到对的球j,用小本本记下来
42                     #接下来再找刚刚找到的球的下一个应该死掉的球
43                     tmp(j)
44         tmp(i)
45         #这样一直找下一个该死的泡泡龙
46         #就得到了所有该死的球 (逃
47         return d
48     
49     #画会动的球
50     fill(COLOR[c])
51     ellipse(x,y,30,30)
52     
53     for i in curBall:
54         #画每个还没死的球
55         fill(COLOR[bc[i]])
56         ellipse(bx[i], by[i], 30, 30)
57         #检查有没有被撞到
58         if dist(bx[i], by[i], x, y)<30:
59             if bc[i] == c:
60                 #某个同色球被撞到
61                 #找它旁边该死的球,以及旁边该死的球的旁边的该死的球,以及*******
62                 tmp = findDead(i)
63                 #找到了这一次所有该死的球
64                 #把他们从生死簿上重新做标记
65                 #地狱+1
66                 #人间-1
67                 for t in tmp:
68                     aliveBall.remove(t)
69             #不管有没有撞到该死的球,都应该飞回原点 (逃
70             x, y  = width/2, height-15
71             vx, vy = 0, 0
72             #顺便换个马甲再来
73             c = int(random(len(COLOR)))
74     curBall = aliveBall[:]
75     #更新一下,现在显示的球全是没死的球
76     x += vx
77     y += vy
78     #左右碰壁就反弹
79     if x>width-15 or x<15:
80         vx = -vx
81     # 上面碰壁也反弹
82     if y<15:
83         vy = -vy
84     #下面碰壁就还原
85     if y>height-15:
86         x, y = width/2, height-15
87         vx, vy = 0, 0
88         #换个马甲
89         c = int(random(len(COLOR)))
90  
91 def mousePressed():
92     global vx, vy
93     #按下鼠标就发射,给个速度就可
94     vx = (mouseX-width/2)/100.0
95     vy = (mouseY-height+15)/100.0

以上是关于processing-python-泡泡龙的主要内容,如果未能解决你的问题,请参考以下文章

一个90年代吐泡泡的游戏

之前java上有个游戏

WPF特效-粒子动画

ShaderLab学习小结(十六)泡泡

软件工程学习报告

CSS 3.0实现泡泡特效