案例坐标系中的点

38 阅读1分钟

1.案例背景

你正在设计一个二维游戏的界面,需要用很多的点来表示游戏中的角色。

设计一个Point类,其x和y可以通过构造器提供。

它有几个方法:

1. 方法1: 计算自己在哪个象限。 whereAmI():String

2. 方法2: 计算和坐标原点的距离。getDist():Double

3. 方法3: 计算与另一个点的距离。fromPoint(other:Point):Double

4. 方法4: 重写equals 判断是否是同一个点(x和y都相等就是同一个点)。

5. 方法5: 重写toString,更友好的输出点的信息。

再设计一个子类LabelPoint它来继承Point类,其构造器接收一个标签值和x,y坐标。

例如: New LabelPoint("black",1,2)

object class15 {
  class Point(var x: Double, var y: Double) {
    def whereAmI(): String = {
      val quadrant = 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) "Y轴上"
      else if (y == 0 && x != 0) "X轴上"
      else "原点"
      quadrant
    }

    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 p: Point => x == p.x && y == p.y
        case _ => false
      }
    }
  }

  // 作业
  class LabelPoint(var label:String, x:Double, y:Double) extends Point(x, y) {

    override def toString: String = s"LabelPoint($x, $y, label: $label)"
  }

  def main(args: Array[String]): Unit = {
    // 测试
    val p1 = new Point(1.0, 1.0)
    val p2 = new Point(1.0, 1.0)
    println(p1.whereAmI())
    println(p1.getDist())
    println(p1.fromPoint(p2))
    println(p1 == p2)


    val lp = new LabelPoint("原点附近", 0.5, 0.5)
    println(lp.whereAmI())
    println(lp.getDist())
  }
}

输出结果

image.png