J2ME游戏开发学习之正确构造GameCanvas

作者:softowen  文章来源:J2ME开发网

最近接触MIDP 2的机会多了些,在游戏中当玩家死亡后,需要显示一个界面通知玩家死亡,并让用户按任意键继续

游戏的主逻辑run()有一个专门的轮循按键keyPolling()函数

/**

   * 按键轮询

   */

  private void keyPolling() {

    if( sprites[0].isEaten) {

      //如果被吃掉了无须进行移动

      return;

    }

    //连续两次getKeyStates()获取当前最新的按键信息

    int _keyState = getKeyStates();

    int keyState = getKeyStates();

    if ( (keyState & UP_PRESSED) != 0) {

      //UP

      sprites[0].move(0, -NORMAL_SPEED);

    }

    if ( (keyState & DOWN_PRESSED) != 0) {

      //Down

      sprites[0].move(0, NORMAL_SPEED);

    }

    if ( (keyState & LEFT_PRESSED) != 0) {

      //Left

      sprites[0].direction = -1;

      sprites[0].setTransform(Sprite.TRANS_NONE);

      sprites[0].move( -NORMAL_SPEED, 0);

    }

    if ( (keyState & RIGHT_PRESSED) != 0) {

      //Right

      sprites[0].direction = 1;

      sprites[0].move(NORMAL_SPEED, 0);

      sprites[0].setTransform(Sprite.TRANS_MIRROR);

    }

  }

 

在实现按任意键继续游戏方面采取keyPressed(int keyCode)里添加代码

if(sprites[0].isEaten) {

       sprites[0].isEaten = false;

}

,实际中当用户按方向键和2, 4, 6, 8, 5键时无效,而其它按键则可以跳过,不仅相当郁闷。

后来读了GameCanvas(boolean suppressKeyEvents)的说明才恍然大悟!

原来,如果初始化GameCanvas(boolean suppressKeyEvents)时参数选择true, 则会压制game keys(UP, DOWN, LEFT, RIGHT, FIRE) 的常规按键机制( keyPressed, keyRepeated, keyReleased), 从而导致了问题的发生。所以当采取GameCanvas(false)时程序就正常了。

 

那么为什么GameCanvas的构造函数会提供这样一个参数呢?文档里面说,If not needed by the application, the suppression of key events may improve performance by eliminating unnecessary system calls to keyPressed, keyRepeated and keyReleased methods.

improve performance 可以提高多少呢?好像缺乏一些量上的概念。希望大虾能用自己的开发体会指点之

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值