class Point(var x: Double, var y: Double) {
def whereAmI(): String = {
if (x > 0 && y > 0) "第一象限"
else if (x < 0 && y > 0) "第二象限"
else if (x < 0 && y < 0) "第三象限"
else if (x > 0 && y < 0) "第四象限"
else if (x == 0 && y == 0) "坐标原点"
else if (x == 0) "y轴上"
else "x轴上"
}
def getDist(): Double = {
math.sqrt(x * x + y * y)
}
def fromPoint(other: Point): Double = {
math.sqrt(math.pow(x - other.x, 2) + math.pow(y - other.y, 2))
}
override def equals(obj: Any): Boolean = {
obj match {
case p: Point => x == p.x && y == p.y
case _ => false
}
}
override def toString: String = {
s"Point($x, $y)"
}
}
class LabelPoint(val label: String, x: Double, y: Double) extends Point(x, y) {
override def toString: String = {
s"LabelPoint($label, $x, $y)"
}
}
object PointTest {
def main(args: Array[String]): Unit = {
val p1 = new Point(3, 4)
println(p1.whereAmI())
println(p1.getDist())
val p2 = new Point(5, 6)
println(p1.fromPoint(p2))
val p3 = new Point(3, 4)
println(p1 == p3)
println(p1)
val lp1 = new LabelPoint("black", 1, 2)
println(lp1.whereAmI())
println(lp1.getDist())
println(lp1)
}
}