Javascript游戏项目Javascript /数据库


Javascript game project javascript/database

我正在尝试使用javascript和php制作一个小在线游戏。

关键是我不想刷新页面。我想让它成为一种"实时玩法",但我遇到了一个严重的问题。我成功地制作了一个数据库,但是我想在每次玩家在地图上移动时更新他的位置。

我只是想要某种AJAX/javascript,是改变球员的位置值从数据库与新的每次球员移动;我不想使用按钮、表单或其他页面;我只是想要某种帮助,使每30秒更新玩家位置到MySQL数据库的脚本。

这是带有玩家移动的javascript

//player movement here
    engine.player.move = function(direction)
    {
       var index, x, y;
       index = x = y = 0;
       engine.keyboard.canInput = false;
       switch(direction)
       {
          case 'up':    index = 0;  y =  1;     break;
          case 'right': index = 3;  x = -1;     break;
          case 'left':  index = 9;  x =  1;     break;
          case 'down':  index = 6;  y = -1;     break;
       }
       var toX = engine.viewport.x + (engine.screen.tilesX / 2 - 0.5) - x;
       var toY = engine.viewport.y + (engine.screen.tilesY / 2 - 0.5) - y;
       var toTile = engine.map.get(toX, toY);
       if(engine.tile.hasProperty(toTile, 'solid', 1) ||
          engine.npc.isNpcAt(toX, toY))
       {
          engine.keyboard.canInput = true;
       }else{
          engine.viewport.playerOffsetX = x * Math.ceil(5 / 16 * engine.tileSize);
          engine.viewport.playerOffsetY = y * Math.ceil(5 / 16 * engine.tileSize);
          setTimeout(engine.player.animate, engine.player.speed / 2);
          setTimeout(engine.player.reset, engine.player.speed);
       }
       engine.player.spriteIndex = index;
       engine.draw();
       engine.output('player  walks ' + toX + 'x' + toY + 'y');
    };

这是我想让mysql更新

   switch(direction)
       {
          case 'up':    index = 0;  y =  1; if(Y++){update player Y+1}      break;
          case 'right': index = 3;  x = -1;     break;
          case 'left':  index = 9;  x =  1;     break;
          case 'down':  index = 6;  y = -1;     break;
       }

好的,不要在没有jquery的情况下开始新的一天。试试post函数。我不能给你一个完整的解决方案,但这里有一个关键:

<script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>
<script>
  function userMove() {
     var data = {
         yourData1: value,
         ...
     }
     $.ajax({
        type: "POST",
        url: your_file.php,
        data: data,
        success: success,
        dataType: dataType
     });
  }
</script>
jquery $ . post

看一下这个例子。

不使用通用的SELECT/FROM/WHERE查询表单,您可以使用UPDATE/SET/WHERE。

我正在考虑在php中"获取"用户位置,但我不确定这是否可能以任何方式