`
nbtlxx
  • 浏览: 255124 次
  • 性别: Icon_minigender_1
  • 来自: 宁波
社区版块
存档分类
最新评论

cocos2dx斗地主产品错误修复过程

阅读更多
一个多星期没有写新的东西了。下面内容是最近修复的一个bug的过程记录。

问题描述:
1. 产品需要进行修改密码的动作。点击提交后,界面死去响应。

解决问题过程纪录:
    1. 修改密码没有收到回复,同时正在加载窗口没有销掉;
    2. 抓包查看是否有包发出去;或者跟服务器端确认;
      http://www.tastycocoabytes.com/cpa/
      cocoa packet analyzer
       这个工具没有深入使用。貌似pc也有类似的比较不错的产品叫debugview. 我的同事使用比较多。可以比较方便的查找tcp数据包的通信;对于未加密数据的跟踪一个很好的选择。
    3. 尝试错误重现:点击后,界面仍然失去响应,但是重新登陆时提示密码错误。看来密码已经被修改;
    4. 使用filediffer比较文件差异。这是mac环境不错的工具,方便比较代码的差异,不错的工具。但是没有发现有用的信息。几个有怀疑的地方,和旧版本是代码一致的。奇怪的事情就是旧版本功能测试正常。
    5. 继续跟踪,打开产品的log开关,发现一个意义的信息。就是发送消息后,服务器端的回包成功返回,并且加入到消息队列等待使用。
       相关代码没有能够将message pop出来,导致界面上没有任何提示。
       void BaseLayer::dohandle(float dt)
{
   //此处出错, mController空指针,无法继续执行。
    if (mController == NULL) {
        return;
    }
    while(MyQueue::sharedInstance()->count() >0 && MyQueue::sharedInstance()->isPopUnlock()==false)
    {
        Message *message = (Message*)MyQueue::sharedInstance()->pop();
        if(message)
        {
            m_currentMillisecondTime = TimeUtil::millisecondNow();
            retryTimes = 0;
            mController->handleLogic(message);
            MyQueue::sharedInstance()->removeObject(message);
        }else
        {
            //CCLog("BaseLayer::dohandle message or controller is null");
            LoggerUtil::getLogger()->logInfo("BaseLayer::dohandle message or controller is null");
        }
    }
}

    6. 解决办法,按照现有的客户端框架,增加专门layer来包装一个view,controllor
    
bool ProfileLayer::init()
{
    LoggerUtil::getLogger()->logInfo(__FUNCTION__);

    bool bRet = false;
    
    do {
        CC_BREAK_IF(! BaseLayer::init() );
        
        ModuleTabView* node = ModuleTabView::create();
        mController =  new ProfileController();
        node->setTouchDelegate(mController);
        mController->setNode(node);
        this->addChild(mController->getNode());
        bRet = true;
    } while (0);
    return bRet;
}     


     7. 继续解决,增加ProfileController, 负责处理两个界面的网络回包和touch事件
      提前释放
      解决办法:  
      mController = ProfileController:new();
      修改为:
      mController = new ProfileController();
      profileLayer.cpp
    9. 将原先的handleLogic(inputMessage)相关代码复制
       ios运行正常
    10. 修改jni/Android.mk
      将新增的cpp文件添加到脚本
      ./build_native.sh
      编译通过,测试通过
    终于解决上述问题。修改别人的代码,确实感觉象捅马蜂窝,但是我们没的选择。无法改变的,就要去接受。
0
1
分享到:
评论

相关推荐

    cpp-一款基于cocos2dx引擎33版本开发的单机斗地主手机游戏

    《基于Cocos2d-x 3.3版的单机斗地主手机游戏开发详解》 在游戏开发领域,Cocos2d-x是一款备受推崇的跨平台2D游戏引擎,尤其适用于开发移动设备上的游戏。本篇将深入探讨如何利用Cocos2d-x 3.3版本开发一款单机...

    android斗地主

    总的来说,"android斗地主"项目不仅涵盖了Cocos2d-android-1引擎的使用,还涉及到了Android游戏开发的全貌,包括UI设计、游戏逻辑、网络同步、性能优化等多个方面。开发者通过这个项目可以深入理解游戏开发的各个...

    《QQ欢乐斗地主》山寨版_

    Cocos2d-x提供了一套完整的调试工具和性能分析器,帮助开发者找出并修复问题。 总的来说,制作《QQ欢乐斗地主》的山寨版涉及了游戏开发的多个层面,包括图形界面设计、游戏逻辑实现、AI系统设计、音效处理以及跨...

    cocos2dx 斗地主,这个是客户端,服务器端请进入我的资源列表查看

    5. **错误处理和调试**:在开发过程中,客户端需要有完善的错误处理机制,以便在出现异常时能及时反馈给用户。Cocos2dx提供了日志和断言工具,帮助开发者定位和修复问题。 6. **适配多平台**:由于使用Cocos2dx,...

    小游戏欢乐斗地主

    开发者可能使用Unity3D、Cocos2d-x等游戏引擎,通过编程语言如C#或JavaScript实现。动画的流畅性、牌的物理运动效果,以及用户点击反馈等都是提高游戏沉浸感的关键。 3. **牌型逻辑**:斗地主的规则复杂,包括单张...

    D:\TDDownload\开心斗地主.rar

    1. **游戏开发**:开发一款斗地主游戏涉及编程语言(如C++、Java、Python或Unity脚本),以及游戏引擎的选择,如Unity、Unreal Engine或Cocos2d-x。游戏逻辑需要实现牌的发牌规则、出牌规则、胜利条件判断等功能。 ...

Global site tag (gtag.js) - Google Analytics