Я знаю, что вопросу два года, но я думаю, что стоит обновить с другим ответом. Вот мое решение:
import javax.swing.JPopupMenu
import scala.swing.{ Component, MenuItem }
import scala.swing.SequentialContainer.Wrapper
object PopupMenu {
private[PopupMenu] trait JPopupMenuMixin { def popupMenuWrapper: PopupMenu }
}
class PopupMenu extends Component with Wrapper {
override lazy val peer: JPopupMenu = new JPopupMenu with PopupMenu.JPopupMenuMixin with SuperMixin {
def popupMenuWrapper = PopupMenu.this
}
def show(invoker: Component, x: Int, y: Int): Unit = peer.show(invoker.peer, x, y)
/* Create any other peer methods here */
}
Вот пример кода использования:
val popupMenu = new PopupMenu {
contents += new Menu("menu 1") {
contents += new RadioMenuItem("radio 1.1")
contents += new RadioMenuItem("radio 1.2")
}
contents += new Menu("menu 2") {
contents += new RadioMenuItem("radio 2.1")
contents += new RadioMenuItem("radio 2.2")
}
}
val button = new Button("Show Popup Menu")
reactions += {
case e: ButtonClicked => popupMenu.show(button, 0, button.bounds.height)
}
listenTo(button)
Некоторые вещи на заметку:
- Использование класса SuperMixin в соответствии с рекомендациями scala-swing-design.pdf , в разделе «Рекомендации по написанию оболочек», подраздел «Использование кэша оболочек».
- Mixin scala.swing.SequentialContainer.Wrapper, чтобы я мог использовать конструкцию
contents +=
, чтобы мой код всплывающего меню был похож на другой код построения scala-swing Menu.
- Хотя в вопросе используется
JPopupMenu.setVisible
, я думаю, что вы захотите перенести и использовать метод JPopupMenu.show
, чтобы вы могли контролировать местоположение всплывающего меню. (Просто установив его на видное место, я помещу его в верхний левый угол экрана.)