(NO.00001)iOS游戏SpeedBoy Lite成形记(十四)

简介:

下面要启用场景的触摸功能,在GameScene.m的didLoadFromCCB方法里添加下面一行:

    self.userInteractionEnabled = YES;

然后还需要给GameScene添加一个实例变量,用来存放玩家选择选手的编号:

    NSInteger _betPlayer;

下面添加触摸回调方法.因为这里只需要处理用户按下去的动作,所以很简单,不用管用户移动手指和触摸完成和取消的方法啦.

-(void)touchBegan:(CCTouch *)touch withEvent:(CCTouchEvent *)event{
    //CGPoint location = [touch locationInView:touch.view];
    //CGPoint pos = [[CCDirector sharedDirector] convertToGL:location];
    //以上2行代码用下面一行就可以搞定了,功能是相同的.
    CGPoint location = [[CCDirector sharedDirector] convertTouchToGL:touch];
    CCLOG(@"%@",NSStringFromCGPoint(location));

    for (int i = 0; i < PlayerCount; i++) {
        NSValue *value = _trackRects[i];
        CGRect rect = value.CGRectValue;
        BOOL inThisTrack = CGRectContainsPoint(rect, location);
        if (inThisTrack) {
            CCLOG(@"in track %d",PlayerCount - i);
            _betPlayer = PlayerCount - i;
            break;
        }
    }

    NSAssert(_betPlayer!=0, @"_betPlayer must not 0");
}

方法中用了一个for循环来一次判定用户屏幕点击位置是否在某条赛道中.前面说了Cocos2D中有现成的函数CGRectContainsPoint帮你搞定,所以不用费劲自己写啦.另外前面还说过初始化赛道Rect时和实际赛道是反的,所以这里用PlayerCount - i来修正,举个例子,如果选择的_trackRects[i]中的i是0,则8-0=8,所以玩家选中的是第8个选手.

这样我们就解决了第1个问题:如何确定玩家选择的选手.

相关文章
|
BI 开发工具 Android开发
和iPhone玩家对战吧,Google Play游戏服务将支持iOS平台
Google今天在游戏开发者大会上宣布了若干与Google Play游戏服务的相关更新,其中和游戏玩家关系最大的也许就是Google Play Game Services将支持iOS平台,这也就意味着回合制和实时多人游戏将同时支持Android和iOS,以后这两个平台的玩家也就可以互动了。显然,这对于游戏开放商也是个好消息——让原本被割裂的用户参与到同场竞技中来。
267 0
和iPhone玩家对战吧,Google Play游戏服务将支持iOS平台
|
算法 开发工具 git
iOS简易蓝牙对战五子棋游戏设计思路之二——核心棋盘逻辑与胜负判定算法(二)
iOS简易蓝牙对战五子棋游戏设计思路之二——核心棋盘逻辑与胜负判定算法
153 0
iOS简易蓝牙对战五子棋游戏设计思路之二——核心棋盘逻辑与胜负判定算法(二)
|
算法 iOS开发
iOS简易蓝牙对战五子棋游戏设计思路之二——核心棋盘逻辑与胜负判定算法(一)
iOS简易蓝牙对战五子棋游戏设计思路之二——核心棋盘逻辑与胜负判定算法
154 0
|
开发工具 git iOS开发
iOS简易蓝牙对战五子棋游戏设计思路之一——核心蓝牙通讯类的设计(二)
iOS简易蓝牙对战五子棋游戏设计思路之一——核心蓝牙通讯类的设计
197 0
|
算法 iOS开发
iOS简易蓝牙对战五子棋游戏设计思路之一——核心蓝牙通讯类的设计
iOS简易蓝牙对战五子棋游戏设计思路之一——核心蓝牙通讯类的设计
137 0
|
测试技术 Android开发 iOS开发
Unity3D-实现连续点击两次返回键退出游戏(安卓/IOS)
Unity3D-连续点击两次返回键退出游戏 本文提供全流程,中文翻译。Chinar坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例...
2812 0