當前位置: 首頁>>代碼示例>>Java>>正文


Java Point2D.Double方法代碼示例

本文整理匯總了Java中java.awt.geom.Point2D.Double方法的典型用法代碼示例。如果您正苦於以下問題:Java Point2D.Double方法的具體用法?Java Point2D.Double怎麽用?Java Point2D.Double使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.awt.geom.Point2D的用法示例。


在下文中一共展示了Point2D.Double方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: version2LabelVector

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Creates an edge vector from a list of points. The edge vector is the
 * vector from the first to the last point, if they are distinct; otherwise,
 * it is the average of the edge points; if that yields <code>(0,0)</code>,
 * the edge vector is given by {@link #DEFAULT_EDGE_VECTOR}.
 *
 * @param points the list of points; should not be empty
 * @param isLoop flag indicating that the underlying edge is a loop
 * @see EdgeView#getLabelVector()
 */
private static Point2D version2LabelVector(List<Point2D> points, boolean isLoop) {
    Point2D result = null;
    // first try a vector from the first to the last point
    Point2D begin = points.get(0);
    Point2D end = points.get(points.size() - 1);
    if (!(isLoop || begin.equals(end))) {
        double dx = end.getX() - begin.getX();
        double dy = end.getY() - begin.getY();
        result = new Point2D.Double(dx, dy);
    } else if (points.size() > 0) {
        // the first and last point coincide; try taking the max of all
        // points
        double sumX = 0;
        double sumY = 0;
        for (Point2D point : points) {
            sumX += point.getX() - begin.getX();
            sumY += point.getY() - begin.getY();
        }
        // double the average (why? don't know; see
        // EdgeView#getLabelVector())
        int n = points.size() / 2;
        result = new Point2D.Double(sumX / n, sumY / n);
    }
    if (result == null || result.getX() == 0 && result.getY() == 0) {
        // nothing worked
        result = DEFAULT_EDGE_VECTOR;
    }
    return result;
}
 
開發者ID:meteoorkip,項目名稱:JavaGraph,代碼行數:40,代碼來源:LayoutIO.java

示例2: extractRotation

import java.awt.geom.Point2D; //導入方法依賴的package包/類
private static AffineTransform extractRotation(Point2D.Double pt,
    AffineTransform tx, boolean andTranslation) {

    tx.deltaTransform(pt, pt);
    AffineTransform rtx = AffineTransform.getRotateInstance(pt.x, pt.y);

    try {
        AffineTransform rtxi = rtx.createInverse();
        double dx = tx.getTranslateX();
        double dy = tx.getTranslateY();
        tx.preConcatenate(rtxi);
        if (andTranslation) {
            if (dx != 0 || dy != 0) {
                tx.setTransform(tx.getScaleX(), tx.getShearY(),
                                tx.getShearX(), tx.getScaleY(), 0, 0);
                rtx.setTransform(rtx.getScaleX(), rtx.getShearY(),
                                 rtx.getShearX(), rtx.getScaleY(), dx, dy);
            }
        }
    }
    catch (NoninvertibleTransformException e) {
        return null;
    }
    return rtx;
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:AttributeValues.java

示例3: handleMousePressed

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Handles a mouse pressed event by recording the initial mouse pointer
 * location.
 * 
 * @param canvas  the JavaFX canvas ({@code null} not permitted).
 * @param e  the mouse event ({@code null} not permitted).
 */
@Override
public void handleMousePressed(ChartCanvas canvas, MouseEvent e) {
    Plot plot = canvas.getChart().getPlot();
    if (!(plot instanceof Pannable)) {
        canvas.clearLiveHandler();
        return;
    }
    Pannable pannable = (Pannable) plot;
    if (pannable.isDomainPannable() || pannable.isRangePannable()) {
        Point2D point = new Point2D.Double(e.getX(), e.getY());
        Rectangle2D dataArea = canvas.findDataArea(point);
        if (dataArea != null && dataArea.contains(point)) {
            this.panW = dataArea.getWidth();
            this.panH = dataArea.getHeight();
            this.panLast = point;
            canvas.setCursor(javafx.scene.Cursor.MOVE);
        }
    }
    // the actual panning occurs later in the mouseDragged() method
}
 
開發者ID:jfree,項目名稱:jfreechart-fx,代碼行數:28,代碼來源:PanHandlerFX.java

示例4: _getPointForCandlestick

import java.awt.geom.Point2D; //導入方法依賴的package包/類
private Point2D.Double _getPointForCandlestick(int plotIndex, int seriesIndex, int dataIndex) {
    final ChartPanel chartPanel = this.chartJDialog.getChartPanel();
    final XYPlot plot = this.chartJDialog.getPlot(plotIndex);
    final ValueAxis domainAxis = plot.getDomainAxis();
    final RectangleEdge domainAxisEdge = plot.getDomainAxisEdge();
    final ValueAxis rangeAxis = plot.getRangeAxis();
    final RectangleEdge rangeAxisEdge = plot.getRangeAxisEdge();

    final org.jfree.data.xy.DefaultHighLowDataset defaultHighLowDataset = (org.jfree.data.xy.DefaultHighLowDataset)plot.getDataset(seriesIndex);

    if (dataIndex >= defaultHighLowDataset.getItemCount(0)) {
        /* Not ready yet. */
        return null;
    }

    final double xValue = defaultHighLowDataset.getXDate(0, dataIndex).getTime();
    final double yValue = defaultHighLowDataset.getCloseValue(0, dataIndex);
    final Rectangle2D plotArea = chartPanel.getChartRenderingInfo().getPlotInfo().getSubplotInfo(plotIndex).getDataArea();
    final double xJava2D = domainAxis.valueToJava2D(xValue, plotArea, domainAxisEdge);
    final double yJava2D = rangeAxis.valueToJava2D(yValue, plotArea, rangeAxisEdge);
    // Use Double version, to avoid from losing precision.
    return new Point2D.Double(xJava2D, yJava2D);
}
 
開發者ID:lead4good,項目名稱:open-java-trade-manager,代碼行數:24,代碼來源:ChartLayerUI.java

示例5: testGetPixelsWithinRadiusOfOrigin

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Test of getPixelsWithinRadius method, of class Camera.
 * 
 * Tests that all pixels within a certain radius of the origin are correctly
 * returned.
 */
@Test
public void testGetPixelsWithinRadiusOfOrigin() {
    // Test point at (0,0)
    Point2D point = new Point2D.Double();
    
    // Ground-truth array
    ArrayList<Pixel> groundTruth = new ArrayList();
    groundTruth.add(new Pixel(-1,  0, 0.0));
    groundTruth.add(new Pixel( 0, -1, 0.0));
    groundTruth.add(new Pixel( 0,  0, 0.0));
    groundTruth.add(new Pixel( 0,  1, 0.0));
    groundTruth.add(new Pixel( 1,  0, 0.0));
    
    double radius = 1.0;
    ArrayList<Pixel> pixels;
    pixels = Emitter.getPixelsWithinRadius(point, radius);
    assertEquals(5, pixels.size());
    
    // Verify that the positions in the pixel array match the ground truth
    for (int ctr = 0; ctr < pixels.size(); ctr++)
    {
        assertEquals(groundTruth.get(ctr).x, pixels.get(ctr).x);
        assertEquals(groundTruth.get(ctr).y, pixels.get(ctr).y);
    }
    
    // Verify that the method works with an even radius
    radius = 2.0;
    pixels = Emitter.getPixelsWithinRadius(point, radius);
    assertEquals(13, pixels.size());
    
    
}
 
開發者ID:LEB-EPFL,項目名稱:SASS,代碼行數:39,代碼來源:EmitterTest.java

示例6: goTo

import java.awt.geom.Point2D; //導入方法依賴的package包/類
void goTo(String cmd) {
	MapLocation loc = (MapLocation)locs.get(cmd);
	Point2D.Double p = (Point2D.Double)(map.getProjection().getMapXY( 
			new Point2D.Double( loc.lon, loc.lat )));
	double z = map.getZoom();
	p.x *= z;
	p.y *= z;
	Insets insets = map.getInsets();
	p.x += insets.left;
	p.y += insets.top;
	double factor = loc.zoom/z;
	map.doZoom( p, factor );
	if( loc.zoom>=2. )tools.focus.doClick();
}
 
開發者ID:iedadata,項目名稱:geomapapp,代碼行數:15,代碼來源:MapLocations.java

示例7: CalibrationAnimation

import java.awt.geom.Point2D; //導入方法依賴的package包/類
public CalibrationAnimation(CalibrationFrame parent, Point2D.Double[] calibrationPoints){
	this.parent = parent;
	setBackground(Color.lightGray);
	setVisible(true);
	Random rand = new Random();
	windowBounds = Toolkit.getDefaultToolkit().getScreenSize();
	
	this.calibrationPoints = new Point2D.Double[10];
	for(int i=0;i<10;i++){
		this.calibrationPoints[i] = 
			new Point2D.Double(
				calibrationPoints[i].x*windowBounds.getWidth(), 
				calibrationPoints[i].y*windowBounds.getHeight());
	}
	
	Point2D.Double tmp;
	for(int i=8;i>0;i--){
		int j = rand.nextInt(i);
		tmp = this.calibrationPoints[j];
		this.calibrationPoints[j] = this.calibrationPoints[i];
		this.calibrationPoints[i] = tmp;
	}

	timer = new Timer(20, this);
	
	originIndex = 9;
	destinationIndex = 0;
	
	diameter = 50;
	
	x = (int)(calibrationPoints[originIndex].x);
	y = (int)(calibrationPoints[originIndex].y);
}
 
開發者ID:SERESLab,項目名稱:iTrace-Archive,代碼行數:34,代碼來源:Calibrator.java

示例8: updatePoints

import java.awt.geom.Point2D; //導入方法依賴的package包/類
private void updatePoints(int x, int y) {
    Point2D inv = new Point2D.Double(x, y);

    try {
        inv = transform.inverseTransform(inv, null);
    } catch (NoninvertibleTransformException e) {
        e.printStackTrace();
    }

    x = (int)inv.getX();
    y = (int)inv.getY();

    switch (paintType) {
    default:
    case BASIC:
    case LINEAR:
        // pick the closest point to move
        if (inv.distance(startX, startY) < inv.distance(endX, endY)) {
            startX = x;
            startY = y;
        } else {
            endX = x;
            endY = y;
        }
        break;

    case RADIAL:
        // pick the closest point to move
        if (inv.distance(ctrX, ctrY) < inv.distance(focusX, focusY)) {
            ctrX = x;
            ctrY = y;
        } else {
            focusX = x;
            focusY = y;
        }
        break;
    }

    updatePaint();
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:41,代碼來源:MultiGradientTest.java

示例9: getReferencePoints

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * @return the corner points of the bounding rectangle of R, centered at the origin.
 */
public Point2D[] getReferencePoints() {
	double xmin = -xc;
	double xmax = -xc + wR - 1;
	double ymin = -yc;
	double ymax = -yc + hR - 1;
	Point2D[] pts = new Point2D[4];
	pts[0] = new Point2D.Double(xmin, ymin);
	pts[1] = new Point2D.Double(xmax, ymin);
	pts[2] = new Point2D.Double(xmax, ymax);
	pts[3] = new Point2D.Double(xmin, ymax);
	return pts;
}
 
開發者ID:imagingbook,項目名稱:imagingbook-common,代碼行數:16,代碼來源:LucasKanadeMatcher.java

示例10: getEditorLocation

import java.awt.geom.Point2D; //導入方法依賴的package包/類
@Override
protected Point2D getEditorLocation(Object cell, Dimension2D editorSize,
        Point2D pt) {
    double scale = getJGraph().getScale();
    // shift the location by the extra border space
    return super.getEditorLocation(cell, editorSize,
        new Point2D.Double(
            pt.getX() + scale * (EXTRA_BORDER_SPACE + 4) - 4, pt.getY()
                + scale * (EXTRA_BORDER_SPACE + 3) - 3));
}
 
開發者ID:meteoorkip,項目名稱:JavaGraph,代碼行數:11,代碼來源:JGraphUI.java

示例11: testGetSignatureInFocus

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Test of getSignature method, of class Gaussian2D.
 */
@Test
public void testGetSignatureInFocus() {
    PSF psf;
    
    // Test point at (0,0)
    Point2D point = new Point2D.Double();
    
    // Emitter is at z = 1.0
    double z = 1.0;
    
     // Ground-truth array
    ArrayList<Pixel> groundTruth = new ArrayList();
    groundTruth.add(new Pixel(-1,  0, 0.0591)); // (-1,  0)
    groundTruth.add(new Pixel( 0, -1, 0.0591)); // ( 0, -1)
    groundTruth.add(new Pixel( 0,  0, 0.0748)); // ( 0,  0)
    groundTruth.add(new Pixel( 0,  1, 0.0591)); // ( 0,  1)
    groundTruth.add(new Pixel( 1,  0, 0.0591)); // ( 1,  0)
    
    // Generate the test array whose signature values will be computed
    ArrayList<Pixel> pixels = new ArrayList();
    pixels.add(new Pixel(-1,  0, 0.0)); // (-1,  0)
    pixels.add(new Pixel( 0, -1, 0.0)); // ( 0, -1)
    pixels.add(new Pixel( 0,  0, 0.0)); // ( 0,  0)
    pixels.add(new Pixel( 0,  1, 0.0)); // ( 0,  1)
    pixels.add(new Pixel( 1,  0, 0.0)); // ( 1,  0)
    
    builder.eX(0).eY(0).eZ(z);
    psf = builder.build();
    
    // Critical test occurs here
    psf.generateSignature(pixels);
    
    // Verify that the signatures in the pixel array match the ground truth
    for (int ctr = 0; ctr < pixels.size(); ctr++)
    {
        assertEquals(groundTruth.get(ctr).getSignature(),
                pixels.get(ctr).getSignature(),
                0.0001);
    }
}
 
開發者ID:LEB-EPFL,項目名稱:SASS,代碼行數:44,代碼來源:Gaussian3DTest.java

示例12: getInitialLocation

import java.awt.geom.Point2D; //導入方法依賴的package包/類
public Point2D getInitialLocation() {
   return new Point2D.Double(x0, y0);
}
 
開發者ID:eric-roberts,項目名稱:JavaPPTX,代碼行數:4,代碼來源:MotionPathState.java

示例13: prepare

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Prepares the actual layout process by calculating the information from
 * the current <tt>jmodel</tt>. This implementation calculates the
 * <tt>toLayoutableMap</tt>, and sets the line style to that preferred by
 * the layouter.
 * @param recordImmovables if {@code true}, the shift in position of the immovables
 * is recorded
 */
protected void prepare(boolean recordImmovables) {
    this.jGraph.setLayouting(true);
    this.jGraph.setToolTipEnabled(false);
    // edge points are cleared when layout is stored back into view
    //        this.jGraph.clearAllEdgePoints();
    // copy the old layout map
    Map<JVertex<?>,LayoutNode> oldLayoutMap =
        new LinkedHashMap<>(this.layoutMap);
    // clear the transient information
    this.layoutMap.clear();
    this.immovableMap.clear();
    // iterate over the cell views
    CellView[] cellViews = this.jGraph.getGraphLayoutCache().getRoots();
    for (CellView cellView : cellViews) {
        if (!(cellView instanceof JVertexView)) {
            continue;
        }
        JVertexView vertexView = (JVertexView) cellView;
        JVertex<?> jVertex = vertexView.getCell();
        if (jVertex.isGrayedOut() || !jVertex.getVisuals().isVisible()) {
            continue;
        }
        LayoutNode layout = new LayoutNode(vertexView);
        if (!jVertex.isLayoutable()) {
            Point2D shift;
            if (recordImmovables) {
                shift = new Point2D.Double();
                LayoutNode oldLayout = oldLayoutMap.get(jVertex);
                if (oldLayout != null) {
                    double x = layout.getX() - oldLayout.getX();
                    double y = layout.getY() - oldLayout.getY();
                    shift = new Point2D.Double(x, y);
                }
            } else {
                shift = null;
            }
            this.immovableMap.put(jVertex, shift);
        }
        this.layoutMap.put(jVertex, layout);
    }
}
 
開發者ID:meteoorkip,項目名稱:JavaGraph,代碼行數:50,代碼來源:AbstractLayouter.java

示例14: getObstructedVisionArea

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Gets the obstructed vision area.
 *
 * @param mob
 *          the mob
 * @param center
 *          the center
 * @return the obstructed vision area
 */
private Area getObstructedVisionArea(final IEntity mob, final Point2D center) {
  final Polygon shadowPolygon = new Polygon();

  final Ellipse2D shadowEllipse = getShadowEllipse(mob);

  final Rectangle2D bounds = shadowEllipse.getBounds2D();

  // radius of Entity's bounding circle
  final float r = (float) bounds.getWidth() / 2f;
  final float ry = (float) bounds.getHeight() / 2f;

  // get relative center of entity
  final Point2D relativeCenter = Game.getCamera().getViewPortLocation(new Point((int) (bounds.getX() + r), (int) (bounds.getY() + ry)));
  final double cx = relativeCenter.getX();
  final double cy = relativeCenter.getY();

  // get direction from light to entity center
  final double dx = cx - center.getX();
  final double dy = cy - center.getY();

  // get euclidean distance from entity to center
  final double distSq = dx * dx + dy * dy; // avoid sqrt for performance

  // normalize the direction to a unit vector
  final float len = (float) Math.sqrt(distSq);
  double nx = dx;
  double ny = dy;
  if (len != 0) { // avoid division by 0
    nx /= len;
    ny /= len;
  }

  // get perpendicular of unit vector
  final double px = -ny;
  final double py = nx;

  // our perpendicular points in either direction from radius
  final Point2D.Double pointA = new Point2D.Double(cx - px * r, cy - py * ry);
  final Point2D.Double pointB = new Point2D.Double(cx + px * r, cy + py * ry);

  // project the points by our SHADOW_EXTRUDE amount
  final Point2D pointC = GeometricUtilities.project(center, pointA, OBSTRUCTED_VISION_RADIUS);
  final Point2D pointD = GeometricUtilities.project(center, pointB, OBSTRUCTED_VISION_RADIUS);

  // construct a polygon from our points
  shadowPolygon.reset();
  shadowPolygon.addPoint((int) pointA.getX(), (int) pointA.getY());
  shadowPolygon.addPoint((int) pointB.getX(), (int) pointB.getY());
  shadowPolygon.addPoint((int) pointD.getX(), (int) pointD.getY());
  shadowPolygon.addPoint((int) pointC.getX(), (int) pointC.getY());

  final Point2D shadowRenderLocation = Game.getCamera().getViewPortLocation(new Point2D.Double(shadowEllipse.getX(), shadowEllipse.getY()));
  final Ellipse2D relativeEllipse = new Ellipse2D.Double(shadowRenderLocation.getX(), shadowRenderLocation.getY(), shadowEllipse.getWidth(), shadowEllipse.getHeight());

  final Area ellipseArea = new Area(relativeEllipse);
  final Area shadowArea = new Area(shadowPolygon);
  shadowArea.add(ellipseArea);
  return shadowArea;
}
 
開發者ID:gurkenlabs,項目名稱:litiengine,代碼行數:69,代碼來源:LightSource.java

示例15: displayCalibrationStatus

import java.awt.geom.Point2D; //導入方法依賴的package包/類
protected void displayCalibrationStatus(JFrame frame) throws Exception {
	 double[] pointsNormalized = jniGetCalibration();
	 
	 if (pointsNormalized == null)
		 throw new IOException("Can't get calibration data!");
	 
	 int zeros = 0;
	 for( double ord: pointsNormalized){
		 if( ord <= 0 || ord > 1) zeros++;
	 }
	 ArrayList<Point2D.Double> points = new ArrayList<Point2D.Double>();
	 ArrayList<Point2D.Double> invalidpoints = new ArrayList<Point2D.Double>();
	//if( zeros > 0 ) throw new IOException("zeros in points: "+zeros+"/"+pointsNormalized.length);
	 
	 int itemCount = pointsNormalized.length/4;

	 for( int i=0; i < itemCount; i++ ){
		 
		points.add(new Point2D.Double(pointsNormalized[i],pointsNormalized[i+itemCount]));
		points.add(new Point2D.Double(pointsNormalized[(2*itemCount)+i],pointsNormalized[i+(itemCount*3)]));
	 }
	 
	 Rectangle2D.Double rect = new Rectangle2D.Double(0.0,0.0,1.0,1.0);
	 
	 for(Point2D.Double p: points){
		 if( !rect.contains(p) ) invalidpoints.add(p);
	 }
	 
	 for (int i = 0; i < pointsNormalized.length; i++) {
		 if (pointsNormalized[i] < 0.0001) {
			 pointsNormalized[i] = 0.0001;
		 } else if (pointsNormalized[i] > 0.9999) {
			 pointsNormalized[i] = 0.9999;
		 } else {
    		//do nothing
		 }
	 }
    
	 Point2D.Double[] calibrationData = new Point2D.Double[itemCount+1];
	 for (int j = 0; j < itemCount; j+=2) {
		 calibrationData[j] = (new Point2D.Double(pointsNormalized[j],pointsNormalized[itemCount+j]));
		 if(j != itemCount)
			 calibrationData[j+1] = (new Point2D.Double(pointsNormalized[2*itemCount+j],pointsNormalized[3*itemCount+j]));
	 }
	 JFrame calibFrame = frame;
	 CalibrationStatusDisplay calibDisplay = 
			 new CalibrationStatusDisplay(calibFrame,calibrationPoints,calibrationData);
	 
	 calibFrame.add(calibDisplay);
    calibFrame.setUndecorated(false);
    calibFrame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
    calibFrame.setExtendedState(JFrame.MAXIMIZED_BOTH);
    calibFrame.setMinimumSize(new Dimension(600,300));
    calibFrame.setTitle("Calibration: "+new Date());
    Insets insets = calibFrame.getInsets();
   	int width = calibFrame.getSize().width-(insets.left+insets.right);
   	int height = calibFrame.getSize().height-(insets.top+insets.bottom);
   	calibDisplay.windowDimension = new Dimension(width,height);
    calibFrame.setVisible(true);
    calibFrame.toFront();
    calibDisplay.repaint();
}
 
開發者ID:SERESLab,項目名稱:iTrace-Archive,代碼行數:63,代碼來源:EyeXTracker.java


注:本文中的java.awt.geom.Point2D.Double方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。