• <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 閱讀(5888) 評論(0)  編輯 收藏 引用 所屬分類: cocos2d
            国产69精品久久久久观看软件 | 2021国产成人精品久久| 亚洲精品乱码久久久久久| 久久婷婷人人澡人人爽人人爱| 中文字幕久久精品无码| 久久国产精品-国产精品| 久久久久国产精品三级网| 久久精品国产亚洲av麻豆图片| 国产精品99久久99久久久| 青青草原综合久久大伊人导航| 久久精品无码午夜福利理论片| 久久久无码精品午夜| 久久综合狠狠综合久久| 亚洲国产成人精品91久久久 | 日产精品久久久一区二区| 国产精品99久久久久久猫咪| 色综合久久久久无码专区| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 亚洲精品无码久久久影院相关影片| 久久亚洲国产中v天仙www| 97久久国产露脸精品国产| 精品久久久久久国产免费了| 国产三级久久久精品麻豆三级| 狠狠色丁香久久婷婷综合_中| 精品国产综合区久久久久久 | 久久丫忘忧草产品| 久久精品国产第一区二区| 国产精品视频久久久| 久久无码AV一区二区三区| 久久免费视频一区| 久久精品成人影院| 久久99久久成人免费播放| 久久99国产精品一区二区| 久久精品人人做人人爽电影蜜月| 久久精品人妻中文系列| 精品熟女少妇AV免费久久| 中文无码久久精品| 久久精品国产亚洲精品2020 | 久久精品国产亚洲欧美| 嫩草影院久久国产精品| 精品久久8x国产免费观看|