/*
* @(#)RefractiveTransition2D.java
*
* $Date: 2014-06-06 20:04:49 +0200 (P, 06 jún. 2014) $
*
* Copyright (c) 2011 by Jeremy Wood.
* All rights reserved.
*
* The copyright of this software is owned by Jeremy Wood.
* You may not use, copy or modify this software, except in
* accordance with the license agreement you entered into with
* Jeremy Wood. For details see accompanying license terms.
*
* This software is probably, but not necessarily, discussed here:
* https://javagraphics.java.net/
*
* That site should also contain the most recent official version
* of this software. (See the SVN repository for more details.)
*/
package com.bric.image.transition;
import java.awt.Dimension;
import java.awt.geom.AffineTransform;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
import java.util.Vector;
/** This resembles a lens with several faces, showing several fractured
* copies of the same image. As the transition progresses the incoming image
* becomes more focused and opaque. Here is a playback sample:
* <p><img src="https://javagraphics.java.net/resources/transition/RefractiveTransition2D/Refractive.gif" alt="RefractiveTransition2D Demo">
*
*/
public class RefractiveTransition2D extends Transition2D {
@Override
public Transition2DInstruction[] getInstructions(float progress,
Dimension size) {
Vector<Rectangle2D> v1 = new Vector<Rectangle2D>();
Vector<Transition2DInstruction> v2 = new Vector<Transition2DInstruction>();
float factor = .05f;
float ySize = (size.height)*factor;
float xSize = (size.width)*factor;
for(float y = 0; y<size.height; y+=ySize) {
for(float x = 0; x<size.width; x+=xSize) {
v1.add(new Rectangle2D.Float(x,y,xSize,ySize));
}
}
Point2D p1, p2;
// 1 -> 0, 0 -> PI,
float angleProgress = (float)( (1-Math.pow(progress,.2)) );
v2.add( new ImageInstruction(true) );
for(int a = 0; a<v1.size(); a++) {
try {
Rectangle2D r = v1.get(a);
p1 = new Point2D.Double(r.getCenterX(),r.getCenterY());
AffineTransform transform = new AffineTransform();
transform.setToRotation(-2*Math.PI*angleProgress,size.width/2,size.height/2);
transform.translate(size.width/2, size.height/2);
transform.scale(progress,progress);
transform.translate(-size.width/2, -size.height/2);
p2 = new Point2D.Double();
transform.transform(p1,p2);
transform.setToTranslation(p2.getX()-p1.getX(),p2.getY()-p1.getY());
v2.add( new ImageInstruction(false,(float)(Math.pow(progress, .4)), transform.createInverse(), r) );
transform.setToRotation(2*Math.PI*angleProgress,size.width/2,size.height/2);
p2 = new Point2D.Double();
transform.transform(p1,p2);
transform.setToTranslation(p2.getX()-p1.getX(),p2.getY()-p1.getY());
v2.add( new ImageInstruction(false,progress*progress,transform.createInverse(),r) );
} catch(Exception e) {
}
}
return v2.toArray(new Transition2DInstruction[v2.size()]);
}
@Override
public String toString() {
return "Refractive";
}
}