Newer
Older
piccolo2d.java / extras / edu / umd / cs / piccolox / swt / SWTShapeManager.java
@Jesse Grosjean Jesse Grosjean on 5 Oct 2006 3 KB piccolo java
package edu.umd.cs.piccolox.swt;

import java.awt.Shape;
import java.awt.geom.AffineTransform;
import java.awt.geom.PathIterator;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
import java.util.ArrayList;

import org.eclipse.swt.graphics.Rectangle;

/**
 * @author Lance Good
 */
public class SWTShapeManager {

	static AffineTransform IDENTITY_XFORM = new AffineTransform();
	static Point2D aPoint = new Point2D.Double();
	static ArrayList segList = new ArrayList();
	static double[] pts = new double[8];


    /**
     * Apply the specified transform to the specified rectangle, modifying the rect.
     * @param rect The rectangle to be transformed
     * @param at The transform to use to transform the rectangle
     */
    public static void transform(Rectangle2D rect, AffineTransform at) {
                                // First, transform all 4 corners of the rectangle
        pts[0] = rect.getX();          // top left corner
        pts[1] = rect.getY();
        pts[2] = rect.getX() + rect.getWidth();  // top right corner
        pts[3] = rect.getY();
        pts[4] = rect.getX() + rect.getWidth();  // bottom right corner
        pts[5] = rect.getY() + rect.getHeight();
        pts[6] = rect.getX();          // bottom left corner
        pts[7] = rect.getY() + rect.getHeight();
        at.transform(pts, 0, pts, 0, 4);

                                // Then, find the bounds of those 4 transformed points.
        double minX = pts[0];
        double minY = pts[1];
        double maxX = pts[0];
        double maxY = pts[1];
        int i;
        for (i=1; i<4; i++) {
            if (pts[2*i] < minX) {
                minX = pts[2*i];
            }
            if (pts[2*i+1] < minY) {
                minY = pts[2*i+1];
            }
            if (pts[2*i] > maxX) {
                maxX = pts[2*i];
            }
            if (pts[2*i+1] > maxY) {
                maxY = pts[2*i+1];
            }
        }
        rect.setRect(minX, minY, maxX - minX, maxY - minY);
    }

	public static void awtToSWT(Rectangle2D aRect, Rectangle sRect) {
		sRect.x = (int)(aRect.getX()+0.5);
		sRect.y = (int)(aRect.getY()+0.5);
		sRect.width = (int)(aRect.getWidth()+0.5);
		sRect.height = (int)(aRect.getHeight()+0.5);
	}
	
	public static double[] shapeToPolyline(Shape s) {
		segList.clear();
		aPoint.setLocation(0,0);
		
		PathIterator pi = s.getPathIterator(IDENTITY_XFORM,0.000000001);
		while (!pi.isDone()) {
			int segType = pi.currentSegment(pts);
			switch (segType) {
				case PathIterator.SEG_MOVETO:
					aPoint.setLocation(pts[0],pts[1]);
					segList.add(new Point2D.Double(pts[0],pts[1]));
					break;
				case PathIterator.SEG_LINETO:
					segList.add(new Point2D.Double(pts[0],pts[1]));					
					break;
				case PathIterator.SEG_CLOSE:
					segList.add(new Point2D.Double(aPoint.getX(),aPoint.getY()));
					break;
			}
			pi.next();
		}
		
		double[] polyObj = new double[2*segList.size()];
		for(int i=0; i<segList.size(); i++) {
			Point2D p2 = (Point2D)segList.get(i);
			polyObj[2*i] = (int)(p2.getX()+0.5);
			polyObj[2*i+1] = (int)(p2.getY()+0.5);
		}
		
		return polyObj;
	}
	
	public static int[] transform(double[] pts, AffineTransform at) {
		int[] intPts = new int[pts.length];
		for(int i=0; i<pts.length/2; i++) {
			aPoint.setLocation(pts[2*i],pts[2*i+1]);
			at.transform(aPoint,aPoint);
			intPts[2*i] = (int)(aPoint.getX()+0.5);
			intPts[2*i+1] = (int)(aPoint.getY()+0.5);
		}
		return intPts;
	}	
}