类型不匹配组合框scala

时间:2013-10-29 03:36:30

标签: swing scala

我正在将旧的scala swing应用程序从scala 2.7.7升级到2.9.3和jdk 1.6升级到jdk 1.7 ..

我能够使用旧设置运行应用程序,并且我几乎成功升级了IntelliJ IDEA 12.1中的scala 2.9.3和jdk 1.7的应用程序。

但是我一直遇到ComboBox的问题。

麻烦制造者档案:

package gui

import gui.model.scenario._

import swing._

object ScenarioComboBox {
  private val model = new javax.swing.DefaultComboBoxModel
}
class ScenarioComboBox extends ComboBox[MutableScenario](Seq(new MutableScenario("", Map()))) {
  import ScenarioComboBox.model
  peer.setModel(model)
  private val dataModel = model.asInstanceOf[javax.swing.DefaultComboBoxModel]

  def contents = {
    var list: List[MutableScenario] = Nil
    val size = dataModel.getSize
    (0 to size - 1).foreach { index =>
      list = list ::: List(dataModel.getElementAt(index).asInstanceOf[MutableScenario])
    }
    list
  }
  def contents_=(v: List[MutableScenario]) {
    dataModel.removeAllElements
    v map dataModel.addElement
  }

  def selectedItem = dataModel.getSelectedItem.asInstanceOf[MutableScenario] match {
    case null => None
    case s    => Some(s)
  }

  def selectedItem_=(v: Option[MutableScenario]) {
    v match {
      case Some(s) => dataModel setSelectedItem s
      case None    => dataModel setSelectedItem null
    }
    selection.publish(swing.event.SelectionChanged(this))
  }

  listenTo(selection)
}

首先,使用jdk 1.7 IntelliJ会发出以下警告:

Type mismatch, expected: ComboBoxModel[E], actual: DefaultComboBoxModel[Nothing]

在这一行:

peer.setModel(model)

当我用这个文件原样编译源代码时,我得到了跟随错误,包括jdk 1.6和1.7:

something is wrong (wrong class file?): class JComboBox with type parameters [E] gets applied to arguments [], phase = typer
  peer.setModel(model)
       ^

无论我尝试修复组合框,我似乎都会遇到类型不匹配错误和/或无法编译这段代码。 (例如,我尝试了这个stackoverflow问题中提出的想法Editing Combobox Scala

我不是原始代码的作者,而且我在过去两周内才学会了scala和swing。

我觉得我用这个组合框尝试了一百万件没有运气的东西..

1 个答案:

答案 0 :(得分:0)

我终于从这个问题的灵感中解决了这个问题 Using ListView from Scala 2.9.2 with Java 7 gives compile error

代码现在看起来像这样:

...
object ScenarioComboBox {
  private val model = new javax.swing.DefaultComboBoxModel[MutableScenario]
}
class ScenarioComboBox extends ComboBox[MutableScenario](Seq(new MutableScenario("", Map()))) {
  import ScenarioComboBox.model
  lazy val typedPeer: JComboBox[MutableScenario] = peer.asInstanceOf[JComboBox[MutableScenario]]
  typedPeer.setModel(model)
...

我现在能够使用jdk 1.7成功编译并运行scala 2.9.3中的整个项目