• <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 閱讀(5907) 評論(0)  編輯 收藏 引用 所屬分類: cocos2d
            99热成人精品免费久久| 久久av免费天堂小草播放| 久久亚洲av无码精品浪潮| 精品午夜久久福利大片| 国内精品久久久久久久97牛牛| 久久人人爽人人爽人人片AV东京热| 久久国产免费| 欧美一级久久久久久久大| 伊人色综合久久天天人守人婷| 欧美大战日韩91综合一区婷婷久久青草| 94久久国产乱子伦精品免费| 超级碰久久免费公开视频| 久久av高潮av无码av喷吹| 国产免费久久精品99re丫y| 久久狠狠爱亚洲综合影院| 久久精品人人槡人妻人人玩AV| 精品久久久久久久无码| 久久综合九色综合精品| 国内精品久久久久久久亚洲| 久久夜色撩人精品国产| 国内精品人妻无码久久久影院导航| 色88久久久久高潮综合影院| 久久99精品久久久久久| 久久久久综合中文字幕| 久久久久亚洲AV无码专区首JN| 久久Av无码精品人妻系列| 国产精品gz久久久| 亚洲欧美日韩久久精品第一区| 国产精品久久久久久福利漫画| 久久亚洲天堂| 久久久久久免费一区二区三区| 亚洲精品成人网久久久久久| 久久99精品久久久久久久不卡| 午夜视频久久久久一区 | 国产高潮国产高潮久久久91| 日韩中文久久| 久久综合欧美成人| 久久影院综合精品| 亚洲精品综合久久| 国产高清国内精品福利99久久| 99久久国产精品免费一区二区 |