Intro
Having multiple lights in PV3D is a desired effect. But after going through the lightmap classes, let me say that it’s impossible without an major rewrite. But with Pixel Bender all you do is add another term to your pbk filter…let’s do it!
Discussion
It’s an amazingly simple process. Just add another term to your pixel bender light equation as shown below:
The example above only shows two lights, but you can have as many lights as you want just by adding additional light terms:
The pixel bender code looks like this
float2 outcoord = outCoord();
float attn = (brightness1/((distance(outcoord, center1)+radius1)))+(brightness2/((distance(outcoord, center2)+radius2)));
dst = attn* sampleNearest(src, outcoord);
dst.a=1.0;
Wow, only five lines of code to have multiple light sources – get out of here!
Animating Your Sources
Once you’ve set your shader up then animating it is pretty easy. If you aren’t sure how to set up your shader for animation, check out Lee Brimlow’s video on animating shaders. I do it a little differently than Lee, but not by much. Here are the steps for animating the lights:
- Increment your oscillation parameter osc++
- Calculate sine and cosine based upon your incremented osc
- Update your light positions
- Apply the update to your image
The fully documented code is shown below:
private function loop(e:Event):void{
//Increment your oscillation parameter
osc++;
//Calculate sine and cosine
var cos:Number=150*Math.cos(osc/10);
var sin:Number=150*Math.sin(osc/10);
//Update your light positions
shader.data.center1.value = [sin+400, cos+180];
shader.data.center2.value = [cos+200, sin+180];
//Apply the update to your image
image.filters = [filter];
//Rotating your image holder
holder.rotationY+=.25;
}
If you are aware of how hard this is to do in PV3D, you’re going wow…tell me more…and we will…
For the entire source code download the source above, or check out the link below: