Python Code for Camera Animation¶
Here are two python scripts to do camera animation: animation.py, and CameraMotion_rotate.py.
animations.py:
import visit, sys
import CameraMotion_rotate
def camera_orbit_z(focus, parallelScale):
# rotation views:
nrotviews = 5
#view normal and up vector list:
rotviews = []
rotviews += [(0.0, 1.0, 0.0)]
rotviews += [(1.0, 0.0, 0.0)]
rotviews += [(1, 0, 0)]
rotviews += [(0, -1, 0)]
rotviews += [(0, -1, 0)]
rotviews += [(-1, 0, 0)]
rotviews += [(-1, 0, 0)]
rotviews += [(0, 1, 0)]
rotviews += [(0.0, 1.0, 0.0)]
rotviews += [(1.0, 0.0, 0.0)]
CameraMotion_rotate.rotate(focus, parallelScale, nrotviews, rotviews, 1)
CameraMotion_rotate.py:
# in rotation, assume focus and parallelScale don't change
def rotate(focus, parallelScale, nviews, views, direction):
#
# Create the control points for the views.
cpts=[]
for i in range(nviews):
v=View3DAttributes()
# print i, "of", nviews
# print v
if direction>0:
v.viewNormal = views[i*2]
v.viewUp = views[i*2+1]
else:
v.viewNormal = views[(nviews-1-i)*2]
v.viewUp = views[(nviews-1-i)*2+1]
v.focus = focus #(450, 575, 850)
v.viewAngle = 30
v.parallelScale = parallelScale #1120.55
v.nearPlane = -2 * parallelScale #-2241.09
v.farPlane = 2*parallelScale #2241.09
v.imageZoom = 1.0
v.imagePan = (0, 0)
v.perspective = 1
cpts = cpts + [v]
# Create a tuple of camera values and x values. The x values are weights
# that help to determine where in [0,1] the control points occur.
# cpts = (c0, c1, c2, c3, c4, c5, c6)
x=[]
for i in range(nviews):
x = x + [float(i) / float(nviews-1)]
# Animate the camera. Note that we use the new built-in EvalCubicSpline
# function which takes a t value from [0,1] a tuple of t values and a tuple
# of control points. In this case, the control points are View3DAttributes
# objects that we are using to animate the camera but they can be any object
# that supports +, * operators.
nsteps = 100
for i in range(nsteps):
print i
t = float(i) / float(nsteps - 1)
c = EvalCubicSpline(t, x, cpts)
c.focus = focus
c.viewAngle = 30
c.parallelScale = parallelScale #1120.55
c.nearPlane = -2*parallelScale #-2241.09
c.farPlane = 2*parallelScale #2241.09
c.imageZoom = 1
c.perspective = 1
SetView3D(c)
# print c
DrawPlots()
SaveWindow()
In main python code, two necessary things to add.
In the beginning, add this line:
import animations
At the end, before delete all plots and close the database, add this line:
animations.camera_orbit_z(focus, parallelScale)
focus and parallelScale are attributes of a visit View. For example:
c = View3DAttributes()
c.focus = (0, 0.75, 0)
c.parallelScale = 5.0