使用立方体的正弦波
wave.py
import math
# a sinus wave
class vrWave:
speed = math.pi / 10.0
pieces = 200
def __init__(self, id = 0, shift = 0.0):
self.shift = shift
self.nodes = self._queryNodes(id)
self.step()
def step(self):
piece = math.pi / len(self.nodes)
for i in range(len(self.nodes)):
node = self.nodes[i]
pos = self.shift + i * piece
z = math.fabs(math.sin(pos))
setTransformNodeScale(node, 1.0, 1.0, z)
self.shift += vrWave.speed
if self.shift > math.pi:
self.shift = 0.0
def _queryNodes(self, id):
nodes = []
for i in range(vrWave.pieces):
name = "wave {}/{}".format(id, i + 1)
node = findNode(name, False)
nodes.append(node)
return nodes;
# creation and animation of all waves
class vrWaveAnimation(vrTimer):
waveCount = 20
def __init__(self):
super(vrWaveAnimation, self).__init__()
self.waves = []
for i in range(vrWaveAnimation.waveCount):
shift = math.pi * i / vrWaveAnimation.waveCount
wave = vrWave(i + 1, shift)
self.waves.append(wave)
super(vrWaveAnimation, self).connect(self._step)
def run(self):
super(vrWaveAnimation, self).setActive(True)
def stop(self):
super(vrWaveAnimation, self).setActive(False)
def __del__(self):
self.stop()
def _step(self):
for wave in self.waves:
wave.step()
animation = vrWaveAnimation()
animation.run()