com.mxgraph.util.mxLine Maven / Gradle / Ivy
/**
* $Id: mxLine.java,v 1.8 2011-01-25 13:13:34 david Exp $
* Copyright (c) 2007-2010, Gaudenz Alder, David Benson
*/
package com.mxgraph.util;
import java.awt.geom.Line2D;
/**
* Implements a line with double precision coordinates.
*/
public class mxLine extends mxPoint
{
/**
*
*/
private static final long serialVersionUID = -4730972599169158546L;
/**
* The end point of the line
*/
protected mxPoint endPoint;
/**
* Creates a new line
*/
public mxLine(mxPoint startPt, mxPoint endPt)
{
this.setX(startPt.getX());
this.setY(startPt.getY());
this.endPoint = endPt;
}
/**
* Creates a new line
*/
public mxLine(double startPtX, double startPtY, mxPoint endPt)
{
x = startPtX;
y = startPtY;
this.endPoint = endPt;
}
/**
* Returns the end point of the line.
*
* @return Returns the end point of the line.
*/
public mxPoint getEndPoint()
{
return this.endPoint;
}
/**
* Sets the end point of the rectangle.
*
* @param value The new end point of the line
*/
public void setEndPoint(mxPoint value)
{
this.endPoint = value;
}
/**
* Sets the start and end points.
*/
public void setPoints(mxPoint startPt, mxPoint endPt)
{
this.setX(startPt.getX());
this.setY(startPt.getY());
this.endPoint = endPt;
}
/**
* Returns the square of the shortest distance from a point to this line.
* The line is considered extrapolated infinitely in both directions for
* the purposes of the calculation.
*
* @param pt the point whose distance is being measured
* @return the square of the distance from the specified point to this line.
*/
public double ptLineDistSq(mxPoint pt)
{
return new Line2D.Double(getX(), getY(), endPoint.getX(), endPoint
.getY()).ptLineDistSq(pt.getX(), pt.getY());
}
/**
* Returns the square of the shortest distance from a point to this
* line segment.
*
* @param pt the point whose distance is being measured
* @return the square of the distance from the specified point to this segment.
*/
public double ptSegDistSq(mxPoint pt)
{
return new Line2D.Double(getX(), getY(), endPoint.getX(), endPoint
.getY()).ptSegDistSq(pt.getX(), pt.getY());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy