我有一个Boot
类和一个Drawer
演员。因此,当我按下按钮时,我会使用参数调用Starter。在Drawer
演员中,我得到Starter
并说自己叫Fill
。我想填充矩形,但是当我调用Fill
时,出现错误:null
java.lang.NullPointerException
。如何解决这个问题?
启动类:
import akka.actor.{Actor, ActorSystem, Props}
import javafx.application.Platform
import scalafx.Includes._
import scalafx.application
import scalafx.application.JFXApp
import scalafx.scene.Scene
import scalafx.scene.canvas.Canvas
import scalafx.scene.control.Alert.AlertType
import scalafx.scene.control.{Alert, ButtonType}
object Boot extends JFXApp {
private val system = ActorSystem("MYsystem")
private val drawer = system.actorOf(Props(new Drawer(g)), "Drawer")
val wiDth = 500
val heiDth = 500
val canvas = new Canvas(wiDth, heiDth)
val g = canvas.graphicsContext2D
private val alert = new Alert(AlertType.Information) {
title = "Hello Player"
headerText = "Do you want to start game?"
contentText = null
buttonTypes = Seq(ButtonType.Cancel, ButtonType.OK)
}
private val result = alert.showAndWait()
result match {
case Some(ButtonType.OK) => drawer ! Drawer.Starter(50,50)
case Some(ButtonType.Cancel) => Platform.exit()
}
canvas.setFocusTraversable(true)
new application.JFXApp.PrimaryStage {
title = "Tanks"
scene = new Scene(wiDth, heiDth) {
content = canvas
}
}
}
抽屉演员
import akka.actor.{Actor, ActorLogging, ActorRef}
import javafx.scene.canvas.GraphicsContext
object Drawer{
case object DrawBullet
case class Starter(x:Int,y:Int)
case class Fill( x:Int, y:Int)
}
class Drawer(g:GraphicsContext) extends Actor with ActorLogging {
import Drawer._
override def receive: Receive = {
case Starter(newx,newy)=>
self ! Fill(newx,newy)
case Fill(newx,newy) =>
g.fillRect(newx,newy,50,50)
}
}
答案 0 :(得分:1)
您的问题称为“转发参考”-在初始化之前使用g
。
下面的代码复制了这一点。
import akka.actor.{Actor, ActorLogging, ActorRef}
import akka.actor.{Actor, ActorSystem, Props}
import stackoverflow.Drawer.{Fill, Starter}
object AcalaAkkaNPE_51853920 extends App {
def aFunctionThatCreatesG() = new G()
private val system = ActorSystem("MYsystem")
private val drawer = system.actorOf(Props(new Drawer(g)), "Drawer")
drawer ! Fill(5,2)
val g = aFunctionThatCreatesG()
}
object Drawer{
case object DrawBullet
case class Starter(x:Int,y:Int)
case class Fill( x:Int, y:Int)
}
class Drawer(g:G) extends Actor with ActorLogging {
override def receive: Receive = {
case Starter(newx,newy)=>
self ! Fill(newx,newy)
case Fill(newx,newy) =>
println(g)
}
}
class G {
override def toString: String = "I'm G"
}