object Class18 {
class Point(var x: Double, var y: Double) {
def whereAMI(): String = {
if (x == 0 && y == 0) "原点"
else if (x == 0) "在y轴上"
else if (y == 0) "在x轴上"
else if (x > 0 && y > 0) "第一象限"
else if (x < 0 && y > 0) "第二象限"
else if (x < 0 && y < 0) "第三象限"
else "第四象限"
}
def getDist(): Double = {
Math.sqrt(x * x + y * y)
}
def fromPoint(other: Point): Double = {
val dx = other.x - x
val dy = other.y - y
Math.sqrt(dx * dx + dy * dy)
}
override def toString: String = s"Point(${x}, ${y})"
override def equals(obj: Any): Boolean = {
obj match {
case other: Point => this.x == other.x && this.y == other.y
case _ => false
}
}
}
class LabelPoint(label: String, x: Double, y: Double) extends Point(x, y) {
def getLabel: String = label
override def toString: String = s"LabelPoint('${label}', ${x}, ${y})"
override def equals(obj: Any): Boolean = {
obj match {
case other: LabelPoint =>
this.label == other.label && this.x == other.x && this.y == other.y
case _ => false
}
}
}
def main(args: Array[String]): Unit = {
val p1 = new Point(1.0, 1.0)
val p2 = new Point(1.0, 1.0)
val p3 = new Point(0.0, 0.0)
val p4 = new Point(-2.0, 3.0)
println(p1.whereAMI())
println(p1.getDist())
println(p1.fromPoint(p2))
println(p1 == p2)
println(p3.whereAMI())
println(p4.whereAMI())
val lp1 = new LabelPoint("起点", 0.0, 0.0)
val lp2 = new LabelPoint("起点", 0.0, 0.0)
val lp3 = new LabelPoint("终点", 0.0, 0.0)
println(lp1)
println(lp1.getLabel)
println(lp1.whereAMI())
println(lp1 == lp2)
println(lp1 == lp3)
}
}