Scala Swing等等

时间:2010-09-16 05:16:43

标签: scala scala-swing

//Main.scala
/* imports */

object Main extends SimpleSwingApplication {
  lazy val ui = new TabbedPane {
    /* contents */
  }

  def top = new MainFrame {
    /* contents */
  }

  override def startup(args: Array[String]) {
    val t = top

    val loginStatus = new Login(t).status

    if (loginStatus == true) {
      if (t.size == new Dimension(0, 0)) t.pack
      t.visible = true
    } else
      quit
  }
}

//Login.scala
class Login(owner: Window) extends Dialog(owner) {
  import Login._

  var status = true
  contents = ui

  listenTo(login) //login is a Button
  reactions += {
    case ButtonClicked(login) => {
      if (/* login field is empty */)
        status = false
      else if (/* login info is correct */)
        status = true
      else /*login info is wrong*/
        status = false
    }
  }
}

如何让'Main'在显示之前等待'Login'?

1 个答案:

答案 0 :(得分:4)

使用CountDownLatch

//Main.scala
/* imports */

object Main extends SimpleSwingApplication {
  private val latch = new CountDownLatch(1)

  lazy val ui = new TabbedPane {
    /* contents */
  }

  def top = new MainFrame {
    /* contents */
  }

  override def startup(args: Array[String]) {
    val t = top

    val loginDialog = new Login(t, latch)
    latch.await

    val loginStatus = loginWindow.status

    if (loginStatus == true) {
      if (t.size == new Dimension(0, 0)) { t.pack }
      t.visible = true
    } else
      quit
  }
}

//Login.scala
class Login(owner: Window, latch: CountDownLatch) extends Dialog(owner) {
  import Login._

  var status = true
  contents = ui

  listenTo(login) //login is a Button
  reactions += {
    case ButtonClicked(login) => {
      latch.countdown

      if (/* login field is empty */)
        status = false
      else if (/* login info is correct */)
        status = true
      else /*login info is wrong*/
        status = false
    }
  }
}