我想创建一个.io游戏。因此,pubnub的替代方法是在http://p2p-server-by-sentifico.herokuapp.com/中托管广播服务器。该服务器将socket.emit("msg")发送到连接到该服务器的所有客户端,但是...游戏进展非常糟糕。多维数据集没有出现,这给了我一个奇怪的错误,所以有我的代码:

<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.3.0/socket.io.js"></script>
<link rel="icon" type="image/png" href="https://i.ibb.co/sHNyD0b/tecnocomunist-star.png">
<script src="https://www.gstatic.com/firebasejs/4.9.0/firebase.js"></script>
<script src="https://apis.google.com/js/platform.js" async defer></script>
<meta name="google-signin-client_id" content="464161591015-669suu0sat7n9c1lq2g6b3mn174g5sej.apps.googleusercontent.com">
<div style="position: absolute; left: 0px; top: 0px"class="g-signin2" data-onsuccess="onSignIn"></div>
<script>
k=[]
obj={}
onkeydown=onkeyup=(e)=>{k[e.keyCode]=e.type=="keydown"}
socket=io("http://p2p-server-by-sentifico.herokuapp.com/")
onSignIn=(googleUser)=>{
 c=document.createElement("canvas")
 document.body.style.margin=0
 document.body.appendChild(c)
 ctx=c.getContext("2d")
 profile=googleUser.getBasicProfile()
 console.log('ID: ' + profile.getId()) // Do not send to your backend! Use an ID token instead.
 console.log('Name: ' + profile.getName())
 console.log('Image URL: ' + profile.getImageUrl())
 console.log('Email: ' + profile.getEmail()) // This is null if the 'email' scope is not present.
 emailID=profile.getId()
 username=profile.getName()
 imgURL=profile.getImageUrl()
 x=Math.floor(Math.random()*10-5)*128
 y=Math.floor(Math.random()*10-5)*128
 render=()=>{
  requestAnimationFrame(render)
  c.width=innerWidth
  c.height=innerHeight
  socket.emit("msg",{
   id:emailID,
   username:username,
   imgURL:imgURL,
   x:x,y:y
  })
  if(k[37]){x-=5}
  if(k[38]){y-=5}
  if(k[39]){x+=5}
  if(k[40]){y+=5}
  for(x2=Math.floor((x-32*40)/32)*32-x+innerWidth/2-16;x2<innerWidth;x2+=32){
   for(y2=Math.floor((y-32*40)/32)*32-y+innerHeight/2-16;y2<innerHeight;y2+=32){
    ctx.lineWidth=4
    ctx.strokeStyle="rgba(200,200,200,1)"
    ctx.strokeRect(x2,y2,32,32)
   }
  }
  for(i in obj){
   img=document.createElement("img")
   img.src=obj[i].imgURL
   ctx.drawImage(img,obj[i].x-x+innerWidth/2-64-16,obj[i].y-y+innerHeight/2-64-16,128,128)
   ctx.lineWidth=4
   ctx.strokeStyle="rgba(0,0,0,1)"
   ctx.strokeRect(obj[i].x-x+innerWidth/2-64-16,obj[i].y-y+innerHeight/2-64-16,128,128)
  }
 }

 render()

 socket.on("msg",(e)=>{
   obj[e.id]={
    username:e.username,
    imgURL:e.imgURL,
    x:e.x,y:e.y
   }
 })
}
</script>


这是错误:

undefined:1 GET http://drwerenverlivitz.atspace.cc/game.io/undefined 404 (Not Found)


所以...我该怎么办?

最佳答案

最后,我得到了解决方案;):

<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.3.0/socket.io.js"></script>
<link rel="icon" type="image/png" href="https://i.ibb.co/sHNyD0b/tecnocomunist-star.png">
<script src="https://www.gstatic.com/firebasejs/4.9.0/firebase.js"></script>
<script src="https://apis.google.com/js/platform.js" async defer></script>
<meta name="google-signin-client_id" content="464161591015-669suu0sat7n9c1lq2g6b3mn174g5sej.apps.googleusercontent.com">
<div style="position: absolute; left: 0px; top: 0px"class="g-signin2" data-onsuccess="onSignIn"></div>
<script>
k=[]
obj={}
onkeydown=onkeyup=(e)=>{k[e.keyCode]=e.type=="keydown"}
socket=io("http://p2p-server-by-sentifico.herokuapp.com/")
onSignIn=(googleUser)=>{
 c=document.createElement("canvas")
 document.body.style.margin=0
 document.body.appendChild(c)
 ctx=c.getContext("2d")
 profile=googleUser.getBasicProfile()
 console.log('ID: ' + profile.getId()) // Do not send to your backend! Use an ID token instead.
 console.log('Name: ' + profile.getName())
 console.log('Image URL: ' + profile.getImageUrl())
 console.log('Email: ' + profile.getEmail()) // This is null if the 'email' scope is not present.
 emailID=profile.getId()
 username=profile.getName()
 imgURL=profile.getImageUrl()
 x=Math.floor(Math.random()*10-5)*128
 y=Math.floor(Math.random()*10-5)*128
 render=()=>{
  requestAnimationFrame(render)
  c.width=innerWidth
  c.height=innerHeight
  socket.emit("msg",{
   data:{
    id:emailID,
    username:username,
    imgURL:imgURL,
    x:x,y:y
   }
  })
  if(k[37]){x-=5}
  if(k[38]){y-=5}
  if(k[39]){x+=5}
  if(k[40]){y+=5}
  for(x2=Math.floor((x-32*40)/32)*32-x+innerWidth/2-16;x2<innerWidth;x2+=32){
   for(y2=Math.floor((y-32*40)/32)*32-y+innerHeight/2-16;y2<innerHeight;y2+=32){
    ctx.lineWidth=4
    ctx.strokeStyle="rgba(200,200,200,1)"
    ctx.strokeRect(x2,y2,32,32)
   }
  }
  for(i in obj){
   img=document.createElement("img")
   img.src=obj[i].imgURL
   ctx.drawImage(img,obj[i].x-x+innerWidth/2-64-16,obj[i].y-y+innerHeight/2-64-16,128,128)
   ctx.lineWidth=4
   ctx.strokeStyle="rgba(0,0,0,1)"
   ctx.strokeRect(obj[i].x-x+innerWidth/2-64-16,obj[i].y-y+innerHeight/2-64-16,128,128)
  }
 }

 render()

 socket.on("msg",(e)=>{
   obj[e.data.id]={
    username:e.data.username,
    imgURL:e.data.imgURL,
    x:e.data.x,y:e.data.y
   }
 })
}
</script>

09-10 05:32