本文整理匯總了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;
}
示例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);
}
}
}
示例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;
}
示例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;
}
示例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;
}
示例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();
}
}
示例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);
}
}
}