象限

50 阅读1分钟
class Point(var x: Double, var y: Double) {
  // 方法1:判断所在象限
  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轴上"
  }

  // 方法2:计算到原点的距离
  def getDist(): Double = {
    math.sqrt(x * x + y * y)
  }

  // 方法3:计算到另一个点的距离
  def fromPoint(other: Point): Double = {
    math.sqrt(math.pow(x - other.x, 2) + math.pow(y - other.y, 2))
  }

  // 方法4:重写equals判断是否为同一个点
  override def equals(obj: Any): Boolean = {
    obj match {
      case p: Point => x == p.x && y == p.y
      case _ => false
    }
  }

  // 方法5:重写toString友好输出点信息
  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 = {
      // 测试Point类
      val p1 = new Point(3, 4)
      println(p1.whereAmI())       // 输出:第一象限
      println(p1.getDist())        // 输出:5.0
      val p2 = new Point(5, 6)
      println(p1.fromPoint(p2))    // 计算p1到p2的距离,输出:2.8284271247461903
      val p3 = new Point(3, 4)
      println(p1 == p3)            // 输出:true
      println(p1)                  // 输出:Point(3.0, 4.0)

      // 测试LabelPoint子类
      val lp1 = new LabelPoint("black", 1, 2)
      println(lp1.whereAmI())      // 输出:第一象限
      println(lp1.getDist())       // 输出:2.23606797749979
      println(lp1)                 // 输出:LabelPoint(black, 1.0, 2.0)
    }
}