|
|
1.3.8.1 The Clock Variable: Key To It All
POV-Ray supports an automatically declared floating point variable identified as clock
(all lower case). This is the key to making image files that can be automated. In command line operations, the clock
variable is set using the +k switch. For example, +k3.4 from the command line would set the
value of clock to 3.4. The same could be accomplished from the INI file using Clock=3.4 in an INI file.
If we do not set clock for anything, and the animation loop is not used (as will be described a little later) the
clock variable is still there - it is just set for the default value of 0.0, so it is possible to set up some POV code
for the purpose of animation, and still render it as a still picture during the object/world creation stage of our
project.
The simplest example of using this to our advantage would be having an object which is travelling at a constant
rate, say, along the x-axis. We would have the statement
translate <clock, 0, 0>
in our object's declaration, and then have the animation loop assign progressively higher values to clock. And that
is fine, as long as only one element or aspect of our scene is changing, but what happens when we want to control
multiple changes in the same scene simultaneously?
The secret here is to use normalized clock values, and then make other variables in your scene proportional to
clock. That is, when we set up our clock, (we are getting to that, patience!) have it run from 0.0 to 1.0, and then
use that as a multiplier to some other values. That way, the other values can be whatever we need them to be, and
clock can be the same 0 to 1 value for every application. Let's look at a (relatively) simple example
#include "colors.inc"
camera {
location <0, 3, -6>
look_at <0, 0, 0>
}
light_source { <20, 20, -20> color White }
plane {
y, 0
pigment { checker color White color Black }
}
sphere {
<0, 0, 0> , 1
pigment {
gradient x
color_map {
[0.0 Blue ]
[0.5 Blue ]
[0.5 White ]
[1.0 White ]
}
scale .25
}
rotate <0, 0, -clock*360>
translate <-pi, 1, 0>
translate <2*pi*clock, 0, 0>
}
Assuming that a series of frames is run with the clock progressively going from 0.0 to 1.0, the above code will
produce a striped ball which rolls from left to right across the screen. We have two goals here:
-
Translate the ball from point A to point B, and,
-
Rotate the ball in exactly the right proportion to its linear movement to imply that it is rolling -- not gliding
-- to its final position.
Taking the second goal first, we start with the sphere at the origin, because anywhere else and rotation will cause
it to orbit the origin instead of rotating. Throughout the course of the animation, the ball will turn one complete
360 degree turn. Therefore, we used the formula, 360*clock to determine the rotation in each frame. Since
clock runs 0 to 1, the rotation of the sphere runs from 0 degrees through 360.
Then we used the first translation to put the sphere at its initial starting point. Remember, we could not have
just declared it there, or it would have orbited the origin, so before we can meet our other goal (translation), we
have to compensate by putting the sphere back where it would have been at the start. After that, we re-translate the
sphere by a clock relative distance, causing it to move relative to the starting point. We have chosen the formula of
2*pi* r*clock (the widest circumference of the sphere times current clock value) so that it will appear to move a
distance equal to the circumference of the sphere in the same time that it rotates a complete 360 degrees. In this
way, we have synchronized the rotation of the sphere to its translation, making it appear to be smoothly rolling along
the plane.
Besides allowing us to coordinate multiple aspects of change over time more cleanly, mathematically speaking, the
other good reason for using normalized clock values is that it will not matter whether we are doing a ten frame
animated GIF, or a three hundred frame AVI. Values of the clock are proportioned to the number of frames, so that same
POV code will work without regard to how long the frame sequence is. Our rolling ball will still travel the exact same
amount no matter how many frames our animation ends up with.
|
|