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


Java Point2D.distanceSq方法代碼示例

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


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

示例1: getControlPointHitAt

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Returns an index of a control point that is hit by the local location
 * @param localLocation the local location
 * @return the index; -1 if no control point was hit
 */
public final int getControlPointHitAt (Point localLocation) {
    int controlRadius = controlPointShape.getRadius ();
    controlRadius *= controlRadius;

    if (isFirstControlPointHitAt (localLocation))
        return 0;

    if (isLastControlPointHitAt (localLocation))
        return controlPoints.size () - 1;

    for (int i = 0; i < controlPoints.size (); i ++) {
        Point point = controlPoints.get (i);
        if (Point2D.distanceSq (point.x, point.y, localLocation.x, localLocation.y) <= controlRadius)
            return i;
    }

    return -1;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:24,代碼來源:ConnectionWidget.java

示例2: select

import java.awt.geom.Point2D; //導入方法依賴的package包/類
void select( MouseEvent e) {
	if( !map.isSelectable() ) return;
	double zoom = map.getZoom();
	double radius = 3./Math.pow(zoom, .75);
	double r2 = radius*radius;
	double wrap = map.getWrap();
	Point2D p = map.getScaledPoint(e.getPoint());
	if( !e.isShiftDown() ) table.clearSelection();
	int xyIndex = headings.size()+1;
	for( int k=0 ; k<currentRowsIndices.size() ; k++) {
		Vector row = getCurrentRow(k);
		float[] xy = (float[])row.get(xyIndex);
		double offset = 0.;
		while( xy[0]+offset<p.getX()-radius ) offset+=wrap;
		while( xy[0]+offset>p.getX()+radius ) offset-=wrap;
		if( xy[0]+offset<p.getX()-radius )continue;
		double r = p.distanceSq( offset+xy[0], (double)xy[1]);
		if( r < r2) {
			table.getSelectionModel().addSelectionInterval(k,k);
			table.ensureIndexIsVisible(k);
		}
	}
}
 
開發者ID:iedadata,項目名稱:geomapapp,代碼行數:24,代碼來源:GMATable.java

示例3: isFirstControlPointHitAt

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Returns whether the local location hits the first control point (also meant to be the source anchor).
 * @param localLocation the local location
 * @return true if it hits the first control point
 */
public final boolean isFirstControlPointHitAt (Point localLocation) {
    int endRadius = endPointShape.getRadius ();
    endRadius *= endRadius;
    Point firstPoint = getFirstControlPoint ();
    if (firstPoint != null)
        if (Point2D.distanceSq (firstPoint.x, firstPoint.y, localLocation.x, localLocation.y) <= endRadius)
            return true;
    return false;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:15,代碼來源:ConnectionWidget.java

示例4: isLastControlPointHitAt

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Returns whether the local location hits the last control point (also meant to be the target anchor).
 * @param localLocation the local location
 * @return true if it hits the last control point
 */
public final boolean isLastControlPointHitAt (Point localLocation) {
    int endRadius = endPointShape.getRadius ();
    endRadius *= endRadius;
    Point lastPoint = getLastControlPoint ();
    if (lastPoint != null)
        if (Point2D.distanceSq (lastPoint.x, lastPoint.y, localLocation.x, localLocation.y) <= endRadius)
            return true;
    return false;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:15,代碼來源:ConnectionWidget.java

示例5: getPixelsWithinRadius

import java.awt.geom.Point2D; //導入方法依賴的package包/類
/**
 * Returns a list of pixels within a certain radius from a point.
 * 
 * This method locates all the pixels within a circular area surrounding a
 * given two-dimensional point whose center lies at (x, y). The coordinate
 * of a pixel is assumed to lie at the pixel's center, and a pixel is within
 * a given radius of another if the pixel's center lies within this circle.
 * 
 * @param point
 * @param radius radius value [pixels]
 * @return list of Pixels with pre-calculated signatures
 */
public static final ArrayList<Pixel> getPixelsWithinRadius(Point2D point, double radius) {
    ArrayList<Pixel> result = new ArrayList<Pixel>();
    // If radius is less than one, return the pixel containing the point
    if (radius < 1)
    {   
        int x = (int) point.getX();
        int y = (int) point.getY();
        result.add(new Pixel(x,y,0));
        return result;
    }
                
    // Upper and lower bounds for the region.
    final int bot_x = (int) floor(point.getX() - radius);
    final int top_x = (int) ceil(point.getX() + radius);
    final int bot_y = (int) floor(point.getY() - radius);
    final int top_y = (int) ceil(point.getY() + radius);
    
    // Squared radius so we dont have to do the sqrt()
    final double radius2 = radius*radius;
    
    // Iterate over all pixels in the square defined by the bounds and
    // filter out those which are too far, otherwise generate signature and
    // add to list.
    for (int i = bot_x; i<=top_x; i++) {
        for (int j=bot_y; j<=top_y; j++) {
            if (point.distanceSq((double) i, (double) j) <= radius2) {
                result.add(new Pixel(i,j,0));
            }
        }
    }
    return result;
}
 
開發者ID:LEB-EPFL,項目名稱:SASS,代碼行數:45,代碼來源:Emitter.java

示例6: calculateRepulsion

import java.awt.geom.Point2D; //導入方法依賴的package包/類
protected void calculateRepulsion() {
    try {
        for (V v : getGraph().getVertices()) {
            if(!((MyVertex)v).isHidden()) {
                if (isLocked(v)) continue;

                MySpringLayout.SpringVertexData svd = springVertexData.getUnchecked(v);
                if(svd == null) continue;
                double dx = 0, dy = 0;

                for (V v2 : getGraph().getVertices()) {
                    if (v == v2) continue;
                    Point2D p = apply(v);
                    Point2D p2 = apply(v2);
                    if(p == null || p2 == null) continue;
                    double vx = p.getX() - p2.getX();
                    double vy = p.getY() - p2.getY();
                    double distanceSq = p.distanceSq(p2);
                    if (distanceSq == 0) {
                        dx += Math.random();
                        dy += Math.random();
                    } else if (distanceSq < repulsion_range_sq) {
                        double factor = 1;
                        dx += factor * vx / distanceSq;
                        dy += factor * vy / distanceSq;
                    }
                }
                double dlen = dx * dx + dy * dy;
                if (dlen > 0) {
                    dlen = Math.sqrt(dlen) / 2;
                    svd.repulsiondx += dx / dlen;
                    svd.repulsiondy += dy / dlen;
                }
            }

        }
    } catch(ConcurrentModificationException cme) {
        calculateRepulsion();
    }
}
 
開發者ID:jmueller95,項目名稱:CORNETTO,代碼行數:41,代碼來源:MySpringLayout.java

示例7: select

import java.awt.geom.Point2D; //導入方法依賴的package包/類
void select( MouseEvent e) {
		if( !map.isSelectable() ) return;
		double zoom = map.getZoom();
		double radius = 3./Math.pow(zoom, .75);
		double r2 = radius*radius;
		double wrap = map.getWrap();
		Point2D p = map.getScaledPoint(e.getPoint());
		if( !e.isShiftDown() ) table.clearSelection();
		int xyIndex = headings.size()+1;
		for( int k=0 ; k<currentRowsIndices.size() ; k++) {
			Vector row = getCurrentRow(k);
			float[] xy = (float[])row.get(xyIndex);
			double offset = 0.;
			
			
//			ERROR: THIS BLOCK OF CODE CAUSES SOUTH POLAR TO CRASH
//			TODO: Must find out what the effect of this code is and preferably run 
//			it when mercator is selected
/*			while( xy[0]+offset<p.getX()-radius ) offset+=wrap;
			while( xy[0]+offset>p.getX()+radius ) offset-=wrap;*/
//			***** TEST CODE *****
/*			while( xy[0]+offset<p.getX()-radius )	{
				System.out.println(xy[0]+offset);
				offset+=wrap;
			}
			while( xy[0]+offset>p.getX()+radius )	{
				offset-=wrap;
			}*/
//			***** TEST CODE *****
//			ERROR: THIS BLOCK OF CODE CAUSES SOUTH POLAR TO CRASH
			
			
			if( xy[0]+offset<p.getX()-radius )continue;
			double r = p.distanceSq( offset+xy[0], (double)xy[1]);
			if( r < r2) {
				table.getSelectionModel().addSelectionInterval(k,k);
				table.ensureIndexIsVisible(k);
			}
		}
	}
 
開發者ID:iedadata,項目名稱:geomapapp,代碼行數:41,代碼來源:GTable.java


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