Points along a displacement vector – Part 1
I thought it might be helpful to teach a bit about vectors.
In this example, you’ll see a starting point (the green sphere) and an ending point (the red sphere). The displacement vector between the sphere is going from the starting point to the ending point.
You find the displacement vector by subtracting the ending point’s x, y, and z from the starting point’s x, y, and z. Then you can easily add points along the vector in a loop as demonstrated in the code:
package { import org.papervision3d.core.math.Number3D; import org.papervision3d.materials.WireframeMaterial; import org.papervision3d.objects.primitives.Sphere; import org.papervision3d.view.BasicView; [SWF(width="640", height="480", backgroundColor="#000000", frameRate="60")] public class PointsAlongAVector extends BasicView { private const NUM_POINTS:int = 10; public function PointsAlongAVector() { var pointA:Sphere = new Sphere(new WireframeMaterial(0x00cc00), 500); pointA.x = -1000; pointA.y = -800; pointA.z = 500; var pointB:Sphere = new Sphere(new WireframeMaterial(0xcc0000), 500); pointB.x = 12000; pointB.y = 8000; pointB.z = 20000; scene.addChild(pointA); scene.addChild(pointB); //we're going from A to B //so subtract A from B var vector:Number3D = new Number3D ( pointB.x - pointA.x, pointB.y - pointA.y, pointB.z - pointA.z ); for(var i:int = 0; i < NUM_POINTS; i++) { var pointAlongVector:Sphere = new Sphere(null, 50, 4, 4); //take the starting point (pointA) //add the vector and multiply it by //the proportion of the current time through the loop (i) //over the total number of times through the loop (NUM_POINTS) pointAlongVector.x = pointA.x + (vector.x * i / NUM_POINTS); pointAlongVector.y = pointA.y + (vector.y * i / NUM_POINTS); pointAlongVector.z = pointA.z + (vector.z * i / NUM_POINTS); scene.addChild(pointAlongVector); } //nothing's moving, so we only render once singleRender(); } } }
-
Trevor
Search
Recommended Books
Speaking at FITC Toronto
Recent Posts
- Moving to johnlindquist.com
- AsyncCommand with Robotlegs, Signals, Flight, MinimalComps
- Search Widget – Robotlegs, Signals, Flight, Minimal Comps, Yahoo Astra
- FDT Super Awesome March Deal
- haXe Tutorial
- AS3 Signals Tutorial
- Preferred Video Tutorial Resolution?
- TweenMax – Tweening a timeline (Advanced Tweening)
- Robotlegs + Flight + Union Platform
- Back in the saddle
- Eclipse Theme Designer Preview
- RobotLegs Hello World Video Tutorial
- 10 Things Every Senior Flash Developer Should Know
- Efflex – 3D Effects for Flex
- MorphController – Mighty Morphing Papervision3D
Recent Comments
- reverse cell phone lookup on Augmented Reality – Recursive Webcam
- Register Domain Name on Augmented Reality – Recursive Webcam
- Katie on Augmented Reality – Recursive Webcam
- software akuntansi terbaik on Back in the saddle
- loan rates on Augmented Reality – Recursive Webcam
- loan rates on Looking around the inside of a Sphere
- reverse phone lookup on Looking around the inside of a Sphere
- Oidhreachta on The Spotlight Effect (Dimming the unselected)
- Hosting company on archive
- aanbae on Back in the saddle
Categories
Archives
Preferred Video Tutorial Resolution
- 1024x768 (53%, 85 Votes)
- 1280x1024 (15%, 24 Votes)
- 1920x1080 (15%, 24 Votes)
- 800x600 (13%, 20 Votes)
- 480x320 (4%, 6 Votes)
- 640x480 (0%, 2 Votes)
Total Voters: 160

