python实现雨滴下落到地面效果

时间:2022-06-22 15:11:36

本文实例为大家分享了python实现雨滴下落到地面效果的具体代码,供大家参考,具体内容如下

本程序在Windows 64位操作系统下,安装的是Anaconda3-4.2.0

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import animation
 
# New figure with white background
fig = plt.figure(figsize=(6,6), facecolor='white')
 
# New axis over the whole figure, no frame and a 1:1 aspect ratio
ax = fig.add_axes([0, 0, 1, 1], frameon=False, aspect=1)
 
# Number of ring
n = 50
size_min = 50
size_max = 50 ** 2
 
# Ring position
pos = np.random.uniform(0, 1, (n,2))
 
# Ring colors
color = np.ones((n,4)) * (0,0,0,1)
# Alpha color channel geos from 0(transparent) to 1(opaque)
color[:,3] = np.linspace(0, 1, n)
 
# Ring sizes
size = np.linspace(size_min, size_max, n)
 
# Scatter plot
scat = ax.scatter(pos[:,0], pos[:,1], s=size, lw=0.5, edgecolors=color, facecolors='None')
 
# Ensure limits are [0,1] and remove ticks
ax.set_xlim(0, 1), ax.set_xticks([])
ax.set_ylim(0, 1), ax.set_yticks([])
 
def update(frame):
  global pos, color, size
 
  # Every ring is made more transparnt
  color[:, 3] = np.maximum(0, color[:,3]-1.0/n)
 
  # Each ring is made larger
  size += (size_max - size_min) / n
 
  # Reset specific ring
  i = frame % 50
  pos[i] = np.random.uniform(0, 1, 2)
  size[i] = size_min
  color[i, 3] = 1
 
  # Update scatter object
  scat.set_edgecolors(color)
  scat.set_sizes(size)
  scat.set_offsets(pos)
 
  # Return the modified object
  return scat,
 
anim = animation.FuncAnimation(fig, update, interval=10, blit=True, frames=200)
plt.show()

效果图:

python实现雨滴下落到地面效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/baidu_36669549/article/details/79781944