package level02
object Class14 {
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 = {
val dx = x - other.x
val dy = y - other.y
Math.sqrt(dx * dx + dy * dy)
}
override def equals(obj: Any): Boolean = obj match {
case that: Point => this.x == that.x && this.y == that.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='$label', x=$x, y=$y)"
}
object PointTest {
def main(args: Array[String]): Unit = {
val p1 = new Point(3, 4)
println(s"点 $p1 所在位置:${p1.whereAmI()}")
println(s"点 $p1 到原点的距离:${p1.getDist()}")
val p2 = new Point(-1, -2)
println(s"点 $p2 所在位置:${p2.whereAmI()}")
println(s"点 $p1 到点 $p2 的距离:${p1.fromPoint(p2)}")
val p3 = new Point(3, 4)
println(s"p1 和 p3 是否相等:${p1 == p3}")
val lp1 = new LabelPoint("起点", 0, 0)
println(s"带标签的点:$lp1")
println(s"点 $lp1 所在位置:${lp1.whereAmI()}")
}
}}