mirror of
https://github.com/processing/processing4.git
synced 2026-02-02 21:29:17 +01:00
This commit is contained in:
149
java/examples/Topics/Motion/Reflection1/applet/Reflection1.java
Normal file
149
java/examples/Topics/Motion/Reflection1/applet/Reflection1.java
Normal file
@@ -0,0 +1,149 @@
|
||||
import processing.core.*;
|
||||
|
||||
import java.applet.*;
|
||||
import java.awt.*;
|
||||
import java.awt.image.*;
|
||||
import java.awt.event.*;
|
||||
import java.io.*;
|
||||
import java.net.*;
|
||||
import java.text.*;
|
||||
import java.util.*;
|
||||
import java.util.zip.*;
|
||||
import java.util.regex.*;
|
||||
|
||||
public class Reflection1 extends PApplet {
|
||||
|
||||
/**
|
||||
* Non-orthogonal Reflection
|
||||
* by Ira Greenberg.
|
||||
*
|
||||
* Based on the equation (R = 2N(N*L)-L) where R is the
|
||||
* reflection vector, N is the normal, and L is the incident
|
||||
* vector.
|
||||
*/
|
||||
|
||||
float baseX1, baseY1, baseX2, baseY2;
|
||||
float baseLength;
|
||||
float[] xCoords, yCoords;
|
||||
float ellipseX, ellipseY, ellipseRadius = 6;
|
||||
float directionX, directionY;
|
||||
float ellipseSpeed = 3.5f;
|
||||
float velocityX, velocityY;
|
||||
|
||||
public void setup(){
|
||||
size(640, 240);
|
||||
frameRate(30);
|
||||
fill(128);
|
||||
smooth();
|
||||
baseX1 = 0;
|
||||
baseY1 = height-150;
|
||||
baseX2 = width;
|
||||
baseY2 = height;
|
||||
|
||||
// start ellipse at middle top of screen
|
||||
ellipseX = width/2;
|
||||
|
||||
// calculate initial random direction
|
||||
directionX = random(0.1f, 0.99f);
|
||||
directionY = random(0.1f, 0.99f);
|
||||
|
||||
// normalize direction vector
|
||||
float directionVectLength = sqrt(directionX*directionX +
|
||||
directionY*directionY);
|
||||
directionX /= directionVectLength;
|
||||
directionY /= directionVectLength;
|
||||
}
|
||||
|
||||
public void draw(){
|
||||
// draw background
|
||||
fill(0, 12);
|
||||
noStroke();
|
||||
rect(0, 0, width, height);
|
||||
|
||||
// calculate length of base top
|
||||
baseLength = dist(baseX1, baseY1, baseX2, baseY2);
|
||||
xCoords = new float[ceil(baseLength)];
|
||||
yCoords = new float[ceil(baseLength)];
|
||||
|
||||
// fill base top coordinate array
|
||||
for (int i=0; i<xCoords.length; i++){
|
||||
xCoords[i] = baseX1 + ((baseX2-baseX1)/baseLength)*i;
|
||||
yCoords[i] = baseY1 + ((baseY2-baseY1)/baseLength)*i;
|
||||
}
|
||||
|
||||
// draw base
|
||||
fill(200);
|
||||
quad(baseX1, baseY1, baseX2, baseY2, baseX2, height, 0, height);
|
||||
|
||||
// calculate base top normal
|
||||
float baseDeltaX = (baseX2-baseX1)/baseLength;
|
||||
float baseDeltaY = (baseY2-baseY1)/baseLength;
|
||||
float normalX = -baseDeltaY;
|
||||
float normalY = baseDeltaX;
|
||||
|
||||
// draw ellipse
|
||||
noStroke();
|
||||
fill(255);
|
||||
ellipse(ellipseX, ellipseY, ellipseRadius*2, ellipseRadius*2);
|
||||
|
||||
// calculate ellipse velocity
|
||||
velocityX = directionX * ellipseSpeed;
|
||||
velocityY = directionY * ellipseSpeed;
|
||||
|
||||
// move elipse
|
||||
ellipseX += velocityX;
|
||||
ellipseY += velocityY;
|
||||
|
||||
// normalized incidence vector
|
||||
float incidenceVectorX = -directionX;
|
||||
float incidenceVectorY = -directionY;
|
||||
|
||||
// detect and handle collision
|
||||
for (int i=0; i<xCoords.length; i++){
|
||||
// check distance between ellipse and base top coordinates
|
||||
if (dist(ellipseX, ellipseY, xCoords[i], yCoords[i]) < ellipseRadius){
|
||||
|
||||
// calculate dot product of incident vector and base top normal
|
||||
float dot = incidenceVectorX*normalX + incidenceVectorY*normalY;
|
||||
|
||||
// calculate reflection vector
|
||||
float reflectionVectorX = 2*normalX*dot - incidenceVectorX;
|
||||
float reflectionVectorY = 2*normalY*dot - incidenceVectorY;
|
||||
|
||||
// assign reflection vector to direction vector
|
||||
directionX = reflectionVectorX;
|
||||
directionY = reflectionVectorY;
|
||||
|
||||
// draw base top normal at collision point
|
||||
stroke(255, 128, 0);
|
||||
line(ellipseX, ellipseY, ellipseX-normalX*100,
|
||||
ellipseY-normalY*100);
|
||||
}
|
||||
}
|
||||
|
||||
// detect boundary collision
|
||||
// right
|
||||
if (ellipseX > width-ellipseRadius){
|
||||
ellipseX = width-ellipseRadius;
|
||||
directionX *= -1;
|
||||
}
|
||||
// left
|
||||
if (ellipseX < ellipseRadius){
|
||||
ellipseX = ellipseRadius;
|
||||
directionX *= -1;
|
||||
}
|
||||
// top
|
||||
if (ellipseY < ellipseRadius){
|
||||
ellipseY = ellipseRadius;
|
||||
directionY *= -1;
|
||||
// randomize base top
|
||||
baseY1 = random(height-100, height);
|
||||
baseY2 = random(height-100, height);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static public void main(String args[]) {
|
||||
PApplet.main(new String[] { "Reflection1" });
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user