欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS開發(fā)中使用cocos2d添加觸摸事件的方法

 更新時間:2015年10月12日 09:48:45   作者:xiangzilv1987  
這篇文章主要介紹了iOS開發(fā)中使用cocos2d添加觸摸事件的方法,cocos2d是制作iOS游戲的利器,需要的朋友可以參考下

CCLayer類是用來接收觸摸輸入的。不過你要首先啟用這個功能才可以使用它。你通過設(shè)置isTouchEnabled為YES來讓層接收觸摸事件:

復(fù)制代碼 代碼如下:
self.isTouchEnabled = YES;

此項設(shè)定最好在init方法中設(shè)置。你可以在任何時間將其設(shè)置為NO或者YES。

一旦啟用isTouchEnabled屬性,許多與接收觸摸輸入相關(guān)的方法將會開始被調(diào)用。這些事件包括:當(dāng)新的觸摸開始的時候,當(dāng)手指在觸摸屏上移動的時候,還有在用戶手指離開屏幕以后。很少會發(fā)生觸摸事件被取消的情況,所以你可以在大多數(shù)情況下忽略它,或者使用ccTouchesEnded方法來處理。

當(dāng)手指首次觸摸到屏幕時調(diào)用的方法:

復(fù)制代碼 代碼如下:

-(void) ccTouchesBegan:(NSSet *)touches withEvent:(UIEvent*)event

手指在屏幕上移動時調(diào)用的方法:

復(fù)制代碼 代碼如下:

-(void) ccTouchesMoved:(NSSet *)touches withEvent:(UIEvent*)event

當(dāng)手指從屏幕上提起時調(diào)用的方法:

復(fù)制代碼 代碼如下:

-(void) ccTouchesEnded:(NSSet *)touches withEvent:(UIEvent*)event

當(dāng)觸摸事件被取消時調(diào)用的方法:

復(fù)制代碼 代碼如下:

-(void) ccTouchesCancelled:(NSSet *)touches withEvent:(UIEvent*)event

取消事件的情況很少發(fā)生,所以在大多數(shù)情況下它的行為和觸摸結(jié)束時相同。

因為觸摸事件由Cocoa TouchAPI接收,所以觸摸的位置必須被轉(zhuǎn)換為OpenGL的坐標(biāo)。

以下是一個用來轉(zhuǎn)換坐標(biāo)的方法:

復(fù)制代碼 代碼如下:

-(CGPoint) locationFromTouches:(NSSet *)touches 

    UITouch *touch = [touches anyObject]; 
    CGPoint touchLocation = [touch locationInView: [touch view]]; 
    return [[CCDirector sharedDirector] convertToGL:touchLocation]; 

默認(rèn)情況下,層接收到的事件和蘋果UIResponder類接收到的是一樣的。cocos2d也支持有針對性的觸摸處理。和普通處理的區(qū)別是:它每次只接收一次觸摸,而UIResponder總是接收到一組觸摸。有針對性的觸摸事件處理只是簡單的把一組觸摸事件分離開來,這樣就可以根據(jù)游戲的需求提供所需的觸摸事件。更重要的是,有針對性的處理允許你把某些觸摸事件從隊列里移除。這樣的話,如果觸摸發(fā)生在屏幕某個指定的區(qū)域,你會比較容易識別出來;識別出來以后你就可以把觸摸標(biāo)記為已經(jīng)處理,并且其它所有的層都不再需要對這個區(qū)域再次做檢查。

在你的層中添加以下方法可以啟用有針對性的觸摸事件處理:

復(fù)制代碼 代碼如下:

-(void) registerWithTouchDispatcher 

    [[CCTouchDispatcher sharedDispatcher] addTargetedDelegate:self priority:kCCMenuTouchPriority swallowsTouches:YES]; 
}

注:如果你把registerWithTouchDispatcher方法留空,你將不會接收到任何觸摸事件!如果你想保留此方法,而且使用它的默認(rèn)處理方式,你必須調(diào)用[super registerWithTouchDispatcher]這個方法。


現(xiàn)在,你將使用一套有點不一樣的方法來代替默認(rèn)的觸摸輸入處理方法。它們幾乎完全一樣,除了一點:用 (UITouch *)touch 代替 (NSSet *)touches 作為方法的第一個參數(shù):

復(fù)制代碼 代碼如下:

-(BOOL) ccTouchBegan:(UITouch *)touch withEvent:(UIEvent *)event {}

-(void) ccTouchMoved:(UITouch *)touch withEvent:(UIEvent *)event {}

-(void) ccTouchEnded:(UITouch *)touch withEvent:(UIEvent *)event {}

-(void) ccTouchCancelled:(UITouch *)touch withEvent:(UIEvent *)event {}

這里很重要的一點是:ccTouchBegan返回的是一個布爾值(BOOL)。如果你返回了YES,那就意味著你不想讓當(dāng)前的觸摸事件傳導(dǎo)到其它觸摸事件處理器。你實際上是“吞下了”這個觸摸事件。

下面來看一個完整的例子:
在自己的layer里面,添加

復(fù)制代碼 代碼如下:

[self setIsTouchEnabled:YES];

以下方法是cocos2d類庫的方法:

復(fù)制代碼 代碼如下:

-(void) setIsTouchEnabled:(BOOL)enabled

{

if( isTouchEnabled_ != enabled ) {

isTouchEnabled_ = enabled;

if( isRunning_ ) {

if( enabled )

[self registerWithTouchDispatcher];

else {

CCDirector *director = [CCDirector sharedDirector];

[[director touchDispatcher] removeDelegate:self];

}

}

}

}

//這句是關(guān)鍵

-(void) registerWithTouchDispatcher

{

CCDirector *director = [CCDirector sharedDirector];

[[director touchDispatcher] addStandardDelegate:self priority:0];

}

接下來就實現(xiàn)方法:

復(fù)制代碼 代碼如下:

- (void)ccTouchesMoved:(NSSet *)touches withEvent:(UIEvent *)event

{

//    for( UITouch *touch in touches ) {

// CGPoint location = [touch locationInView: [touch view]];

//       

// location = [[CCDirector sharedDirector] convertToGL: location];

// CGPoint touchPos = location;

//       

//        NSLog(@"point==%@",NSStringFromCGPoint(touchPos));

// }

   

   

    UITouch* touch = [touches anyObject];

    CGPoint location = [touch locationInView: [touch view]];

    location = [[CCDirector sharedDirector] convertToGL: location];

    //self.position = location;

     NSLog(@"point==%@",NSStringFromCGPoint(location));

}

- (void)ccTouchEnded:(UITouch *)touch withEvent:(UIEvent *)event {

    self.isMoving = FALSE;

}

- (BOOL)ccTouchBegan:(UITouch *)touch withEvent:(UIEvent *)event {

   

    // you can set up a check here if you're not interested in handling every touch.

    // For example if your player is already moving, return no...

   

    BOOL handleTouch = FALSE;

    if (!self.isMoving) {

        handleTouch = TRUE;

        self.isMoving = TRUE;

    }

    return handleTouch;

   

}

相關(guān)文章

  • IOS 實現(xiàn)微信自動搶紅包(非越獄IPhone)

    IOS 實現(xiàn)微信自動搶紅包(非越獄IPhone)

    這篇文章主要介紹了IOS 實現(xiàn)微信自動搶紅包(非越獄IPhone)的相關(guān)資料,這里對實現(xiàn)自動搶紅包做一個詳細(xì)的實現(xiàn)步驟,需要的朋友可以參考下
    2016-11-11
  • iOS UIAlertController中UITextField添加晃動效果與邊框顏色詳解

    iOS UIAlertController中UITextField添加晃動效果與邊框顏色詳解

    這篇文章主要給大家介紹了關(guān)于iOS UIAlertController中UITextField添加晃動效果與邊框顏色的相關(guān)資料,實現(xiàn)后的效果非常適合在開發(fā)中使用,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面隨著小編來一起看看吧。
    2017-10-10
  • iOS如何獲取手機(jī)的Mac地址

    iOS如何獲取手機(jī)的Mac地址

    這篇文章主要為大家詳細(xì)介紹了iOS獲取手機(jī)的Mac地址的多種方法,感興趣的小伙伴們可以參考一下
    2016-04-04
  • Apple?Watch?App?Lifecycle應(yīng)用開發(fā)

    Apple?Watch?App?Lifecycle應(yīng)用開發(fā)

    這篇文章主要為大家介紹了Apple?Watch?App?Lifecycle應(yīng)用開發(fā)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • iOS開發(fā)中使用Picker View實現(xiàn)一個點菜應(yīng)用的UI示例

    iOS開發(fā)中使用Picker View實現(xiàn)一個點菜應(yīng)用的UI示例

    這篇文章主要介紹了iOS開發(fā)中使用Picker View實現(xiàn)一個點菜應(yīng)用的UI示例,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2016-01-01
  • IOS setOnclick點擊事件分析

    IOS setOnclick點擊事件分析

    本篇文章給大家整理了IOS setOnclick點擊事件完美擴(kuò)展的相關(guān)知識點以及代碼實例,有需要的朋友可以跟著測試學(xué)習(xí)下。
    2018-05-05
  • IOS 開發(fā)之Object-C中的對象詳解

    IOS 開發(fā)之Object-C中的對象詳解

    這篇文章主要介紹了IOS 開發(fā)之Object-C中的對象詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • iOS 在線視頻生成GIF圖功能的方法

    iOS 在線視頻生成GIF圖功能的方法

    本篇文章主要介紹了iOS 在線視頻生成GIF圖功能的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • IOS 開發(fā)之xcode對比兩個分支中同一個文件

    IOS 開發(fā)之xcode對比兩個分支中同一個文件

    這篇文章主要介紹了IOS 開發(fā)之xcode對比兩個分支中同一個文件的相關(guān)資料,希望通過本文能幫助到大家實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-08-08
  • iOS中tableview實現(xiàn)編輯、全選及刪除等功能的方法示例

    iOS中tableview實現(xiàn)編輯、全選及刪除等功能的方法示例

    這篇文章主要給大家介紹了關(guān)于iOS中tableview實現(xiàn)編輯、全選及刪除等功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),不僅是介紹實現(xiàn)的方法,將實現(xiàn)過程中遇到的問題也都分享出來了,需要的朋友們下面來一起看看吧。
    2017-07-07

最新評論