• <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
            久久99国内精品自在现线| 91麻精品国产91久久久久| 一本色道久久88综合日韩精品 | 欧美激情精品久久久久久| 久久免费国产精品| 一级女性全黄久久生活片免费 | 亚洲国产精品成人久久蜜臀 | 综合网日日天干夜夜久久| 久久99国产乱子伦精品免费| 国内精品久久久久久久涩爱 | 久久综合狠狠综合久久97色| 亚洲精品乱码久久久久久蜜桃不卡 | 久久这里只有精品视频99| 日本强好片久久久久久AAA| 久久www免费人成看国产片| 久久丫精品国产亚洲av| 久久精品无码一区二区日韩AV| 99精品伊人久久久大香线蕉| 午夜不卡888久久| 久久99热这里只有精品66| 久久久久99精品成人片欧美 | 欧美牲交A欧牲交aⅴ久久| 999久久久国产精品| 久久99精品久久久久久久不卡 | 久久亚洲精品视频| 久久精品国产久精国产果冻传媒| 国产激情久久久久影院小草| 国产亚洲综合久久系列| 亚洲国产精品无码久久一线| 人妻少妇精品久久| 久久无码一区二区三区少妇| 精品久久久久中文字| 国产成人久久精品二区三区| 99久久精品国内| 国产精品久久影院| 国产成人久久精品区一区二区| 亚洲va久久久噜噜噜久久男同| 久久亚洲国产精品成人AV秋霞| 久久久午夜精品| 久久综合给久久狠狠97色| 久久99精品久久久久久久不卡 |