package info.istlab.Zemi01.imgview;
import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Stroke;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
import org.piccolo2d.PCamera;
import org.piccolo2d.PCanvas;
import org.piccolo2d.event.PDragSequenceEventHandler;
import org.piccolo2d.event.PInputEvent;
import org.piccolo2d.util.PAffineTransform;
import org.piccolo2d.util.PBounds;
/**
* ATNWindowで右ドラッグしながら青色のズーム範囲矩形を表示し,ズームする機能を実現するクラス
* @author miuramo
*
*/
public class ImageViewer_ZoomRegionHandler extends PDragSequenceEventHandler {
PCanvas viewer;
PPPath selection;
private Stroke[] strokes = null;
private float strokeNum = 0;
final static int NUM_STROKES = 10;
final static int DASH_WIDTH = 15;
Point2D cmp; // ドラッグ開始座標
Point2D cp; //ドラッグ中の座標
Point2D max_ext_cp; // 左上方向(通常とは逆方向)一番遠くにドラッグしたときの座標
// double dist_max_ext_cp; //そのときの距離
PBounds initialBounds; //ドラッグ開始時の視野
public ImageViewer_ZoomRegionHandler(PCanvas _viewer) {
this.viewer = _viewer;
float[] dash = { DASH_WIDTH, DASH_WIDTH };
strokes = new Stroke[NUM_STROKES];
for (int i = 0; i < NUM_STROKES; i++) {
strokes[i] = new BasicStroke(2, BasicStroke.CAP_BUTT,
BasicStroke.JOIN_MITER, 1, dash, i);
}
}
public void startDrag(PInputEvent e) {
super.startDrag(e);
cmp = e.getPositionRelativeTo(viewer.getCamera());
max_ext_cp = cmp; // 初期化
selection = new PPPath();
selection.setPathToRectangle((float) cmp.getX(), (float) cmp.getY(), 0,
0);
selection.setStrokePaint(Color.blue);//青色
selection.setPaint(null);
selection.setStroke(strokes[0]);
viewer.getCamera().addChild(selection);
initialBounds = viewer.getCamera().getViewBounds();
}
public void drag(PInputEvent e) {
super.drag(e);
cp = e.getPositionRelativeTo(viewer.getCamera());
float cp_cmp_x = (float)(cp.getX() - cmp.getX());
float cp_cmp_y = (float)(cp.getY() - cmp.getY());
selection.setPathToRectangle((float) cmp.getX(), (float) cmp.getY(),
cp_cmp_x, cp_cmp_y);
// 右下にドラッグしているときの,青い点線矩形の点線パターンを変化させる
float origStrokeNum = strokeNum;
strokeNum = (strokeNum + 0.3f) % NUM_STROKES;
if ((int) strokeNum != (int) origStrokeNum) {
selection.setStroke(strokes[(int) strokeNum]);
}
// 左上方向(通常とは逆方向)一番遠くにドラッグしたときの処理
if (cp_cmp_x < 0 || cp_cmp_y < 0){
PCamera pc = viewer.getCamera();
float f;
if (cp_cmp_x < 0) f = Math.abs((float)(viewer.getWidth()/(viewer.getWidth() - cp.distance(cmp))));
else f = Math.abs((float)((viewer.getWidth() - cp.distance(cmp))/viewer.getWidth()));
// System.out.println("f "+f);
PBounds pb = BUtil.zoomBounds(initialBounds, f);
pc.animateViewToCenterBounds(pb, true, 0);
}
}
public void endDrag(PInputEvent e) {
super.endDrag(e);
cp = e.getPositionRelativeTo(viewer.getCamera());
selection.removeFromParent();
if (cmp.getX() < cp.getX() && cmp.getY() < cp.getY()) {
// カメラ座標から,グローバル(パネル)座標への変換
PAffineTransform at = viewer.getCamera().getViewTransform();
Rectangle2D globalb = selection.getGlobalBounds();
Rectangle2D layerb = new Rectangle2D.Double();
at.inverseTransform(globalb, layerb);
viewer.getCamera().animateViewToCenterBounds(layerb, true, 1000);
}
}
}