Javascript游戏项目javascript /数据库

时间:2013-04-29 23:44:35

标签: php javascript mysql ajax 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;

       }

3 个答案:

答案 0 :(得分:0)

好的,永远不要在没有jquery的情况下开始新的一天。尝试发布功能。我无法给你完整的解决方案,但这是一个关键:

<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

答案 1 :(得分:0)

看看this example

您可以使用UPDATE/SET/WHERE

,而不是使用通用的SELECT/FROM/WHERE查询表单

答案 2 :(得分:0)

我正在考虑在php中创建一个GET位置变量,从javascript“获取”用户位置,但我不确定这是否可行。