• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            積木

            No sub title

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(1)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            轉載自:http://blog.linguofeng.com/archive/2012/09/12/cocos2d-x-touch.html

            一、兩種機制的四種不同的事件

            CCStandardTouchDelegate 默認事件
            virtual void ccTouchesBegan(CCSet *pTouches, CCEvent *pEvent); 處理按下事件
            virtual void ccTouchesMoved(CCSet *pTouches, CCEvent *pEvent); 處理按下并移動事件
            virtual void ccTouchesEnded(CCSet *pTouches, CCEvent *pEvent); 處理松開事件
            virtual void ccTouchesCancelled(CCSet *pTouches, CCEvent *pEvent); 處理打斷事件
            CCTargetedTouchDelegate
            virtual bool ccTouchBegan(CCTouch *pTouch, CCEvent *pEvent); 處理用戶按下事件,true表示繼續處理, 否則false.
            virtual void ccTouchMoved(CCTouch *pTouch, CCEvent *pEvent); 處理按下并移動事件
            virtual void ccTouchEnded(CCTouch *pTouch, CCEvent *pEvent); 處理松開事件
            virtual void ccTouchCancelled(CCTouch *pTouch, CCEvent *pEvent); 處理打斷事件

            兩者的區別: CCSetCCTouch ,一個事件集合一個單個事件。

            事件分發的順序: CCTargetedTouchDelegateCCStandardTouchDelegate

            默認情況下所有 CCLayer 都沒有啟用觸摸事件,需要 this->setIsTouchEnabled(true); 啟用。

            如需更改事件: void registerWithTouchDispatcher(void) {}

            class MyLayer: public cocos2d:CCLayer {
            public:
                virtual void registerWithTouchDispatcher(void);
            
                // addStandardDelegate()
                virtual void ccTouchesBegan(CCSet *pTouches, CCEvent *pEvent);
                virtual void ccTouchesMoved(CCSet *pTouches, CCEvent *pEvent);
                virtual void ccTouchesEnded(CCSet *pTouches, CCEvent *pEvent);
                virtual void ccTouchesCancelled(CCSet *pTouches, CCEvent *pEvent);
            
                // addTargetedDelegate()
                virtual bool ccTouchBegan(CCTouch *pTouch, CCEvent *pEvent);
                virtual void ccTouchMoved(CCTouch *pTouch, CCEvent *pEvent);
                virtual void ccTouchEnded(CCTouch *pTouch, CCEvent *pEvent);
                virtual void ccTouchCancelled(CCTouch *pTouch, CCEvent *pEvent);
            }
            
            void MyLayer::registerWithTouchDispatcher(void) {
                // 委托,優先級
                CCTouchDispatcher::sharedDispatcher()->addStandardDelegate(this, kCCMenuTouchPriority);
                // 委托,優先級,是否繼續處理
                CCTouchDispatcher::sharedDispatcher()->addTargetedDelegate(this, kCCMenuTouchPriority, true);
            
                // 2.0版本以后
                CCDirector::sharedDirector()->getTouchDispatcher()->addStandardDelegate(this, kCCMenuHandlerPriority);
                CCDirector::sharedDirector()->getTouchDispatcher()->addTargetedDelegate(this, kCCMenuHandlerPriority, true);
            }

            利用 ccTouchBeganccTouchesBegan 加以實現點擊的回調

            void MyLayer::ccTouchesBegan(CCSet *pTouches, CCEvent *pEvent) {
                // 單點
                CCTouch *pTouch = (CCTouch*)(pTouches->anyObject());
            
                // 所有點
                for(CCSetIterator iterTouch = pTouches->begin(); iterTouch != pTouches->end(); iterTouch++) {
                    CCTouch *pCurTouch =  (CCTouch*)(*iterTouch);
                }
            
                // 獲取點在視圖中的坐標(左上角為原點)
                CCPoint touchLocation = pTouch->getLocationInView();
                // 把點的坐標轉換成OpenGL坐標(左下角為原點)
                touchLocation = CCDirector::sharedDirector()->convertToGL(touchLocation);
                // 把OpenGL的坐標轉換成CCLayer的坐標
                CCPoint local = convertToNodeSpace(touchLocation)
                // 大小為100x100,坐標為(0, 0)的矩形
                CCRect * rect = CCRectMake(0, 0, 100, 100);
                // 判斷該坐標是否在rect矩形內
                bool flag = rect.containsPoint(local)
                if(flag) {
                    // 回調
                } else {
                    // 不執行
                }
            }


            posted on 2013-03-10 00:28 Jacc.Kim 閱讀(5896) 評論(0)  編輯 收藏 引用 所屬分類: cocos2d
            国产精品免费看久久久| 久久精品蜜芽亚洲国产AV| 欧洲性大片xxxxx久久久| 欧美国产成人久久精品| 久久免费的精品国产V∧| 国产69精品久久久久99| 久久天天躁狠狠躁夜夜2020一| 日韩精品无码久久久久久| 久久久精品久久久久特色影视| 久久99久国产麻精品66| 精品久久久久久无码中文野结衣| 久久亚洲AV无码精品色午夜麻豆| 国产亚洲精品自在久久| 无码任你躁久久久久久老妇App| 久久九九有精品国产23百花影院| 亚洲婷婷国产精品电影人久久 | 成人国内精品久久久久影院VR| 色婷婷久久久SWAG精品| 狠狠色丁香婷婷久久综合不卡| 午夜视频久久久久一区 | 久久中文骚妇内射| 亚洲人AV永久一区二区三区久久| 久久99久久99精品免视看动漫| 久久精品无码一区二区三区免费| 99国产欧美精品久久久蜜芽| 97久久国产露脸精品国产| 天天做夜夜做久久做狠狠| 国产亚洲色婷婷久久99精品91| .精品久久久麻豆国产精品| 欧美精品久久久久久久自慰| 伊人久久精品影院| 欧美精品丝袜久久久中文字幕| 日本免费一区二区久久人人澡| 久久av无码专区亚洲av桃花岛| 无码人妻少妇久久中文字幕蜜桃 | 99久久这里只精品国产免费| 久久天天躁狠狠躁夜夜av浪潮| 久久久久久久久久免免费精品 | 国产日产久久高清欧美一区| 久久夜色精品国产噜噜麻豆| 丁香狠狠色婷婷久久综合|