模拟代码进入过程:

  • main.cpp

     #include <iostream>
    #include "AppDelegate.h"
    #include "CCApplication.h"
    #include "CCApplicationProtocol.h"
    using namespace std; int main()
    {
    AppDelegate app;

    return CCApplication::sharedApplication()->run();
    }
  • AppDelegate.h
     #pragma once
    #include "CCApplication.h"
    class AppDelegate :
    public CCApplication
    {
    public:
    AppDelegate();
    virtual ~AppDelegate(); virtual bool applicationDidFinishLaunching();//子类实现了接口
    };
  • AppDelegate.cpp
    #include "AppDelegate.h"
    #include <Windows.h> AppDelegate::AppDelegate()
    {
    } AppDelegate::~AppDelegate()
    {
    }
    //真正的入口
    bool AppDelegate::applicationDidFinishLaunching()
    {
    MessageBoxA(0, "游戏开始", "提示", 1);
    return false;
    }
  • CCApplication.h
     #pragma once
    #include "CCApplicationProtocol.h" class CCApplication :
    public CCApplicationProtocol
    {
    public:
    CCApplication();
    virtual ~CCApplication(); int run();

    static CCApplication *sharedApplication();
    static CCApplication *sm_pSharedApplication;
    };
  • CCApplication.cpp
     #include "CCApplication.h"
    #include "stddef.h" CCApplication * CCApplication::sm_pSharedApplication = NULL; CCApplication::CCApplication()
    {
    sm_pSharedApplication = this;//注意这个this是子类AppDelegate传过来的
    } CCApplication::~CCApplication()
    {
    }
    //run调用父类的applicationDidFinishLaunching()方法,父类的方法在子类中实现
    16 int CCApplication::run()
    17 {
    18 applicationDidFinishLaunching();
    19 return 0;
    20 }

    CCApplication * CCApplication::sharedApplication()
    {
    if(sm_pSharedApplication != NULL)
    return sm_pSharedApplication;
    }
  • CCApplicationProtocol.h
     #pragma once
    class CCApplicationProtocol
    {
    public:
    CCApplicationProtocol();
    virtual ~CCApplicationProtocol(); virtual bool applicationDidFinishLaunching() = ;
    };
  • CCApplicationProtocol.cpp
    #include "CCApplicationProtocol.h"
    
    CCApplicationProtocol::CCApplicationProtocol()
    {
    } CCApplicationProtocol::~CCApplicationProtocol()
    {
    }

运行截图:

3.cocos代码入口的更多相关文章

  1. Unity3D 代码入口

    最近有人提出一个unity一键导出html项目的设想,所以又回头看了一下unity 发现现在的untiy和我熟悉的有很大的不同了 在看unity的 entity 系统时,注意到,这个系统的入口比较特殊 ...

  2. cocos代码研究(5)Action学习笔记

    理论部分 Action类也是cocos核心基础类之一,在游戏中起着非常重要的作用,继承自Ref,被 FiniteTimeAction(有限时间动作), Follow , 以及 Speed 继承. 有限 ...

  3. cocos代码研究(1)Node学习笔记

    理论部分 Node类继承自Ref类,是cocos框架中基础底层的一个封装类,与画面渲染相关的类一般都是继承自该类,例如Scene,Layer,Sprite,Sprite3D,Label,SpriteB ...

  4. cocos代码研究(12)UI之Widget学习笔记

    理论基础 Widget类,所有UI控件的基类. 这类继承自ProtectedNode和LayoutParameterProtocol. 如果你想实现自己的UI控件,你应该继承这个类. 被 VideoP ...

  5. cocos代码研究(7)即时动作子类学习笔记

    理论部分 即时动作是会立即被执行的动作.他们没有持续时间动作(ActionInterval)的持续时间属性.继承自 FiniteTimeAction.被 CallFunc, FlipX, FlipY, ...

  6. cocos代码研究(6)有限时间动作类(FiniteTimeAction)学习笔记

    理论部分 有限时间动作类继承自Action类,被 ActionInstant(即时动作) , 以及 ActionInterval(持续动作) 继承. 即时动作是会立即被执行的动作,被 CallFunc ...

  7. cocos代码研究(2)Label学习笔记

    理论部分 Label类继承自Node类,中文翻译文字与字体,通常在应用开发中为模块作为提示和描述的作用,主要有3中不同的创建方式. 1.通过ttf字体包创建,通过指定本地已有的ttf格式的字体文件,创 ...

  8. cocos代码研究(17)Widget子类RadioButtonGroup学习笔记

    理论基础 RadioButtonGroup可以把指定的单选按钮组织起来, 形成一个组, 使它们彼此交互. 在一个RadioButtonGroup, 有且只有一个或者没有RadioButton可以处于被 ...

  9. cocos代码研究(16)Widget子类RadioButton学习笔记

    理论基础 RadioButton是一种特定类型的两状态按钮,它与复选框相似.它可以 和RadioButtonGroup一起使用,形成一个"组".继承自AbstractCheckBu ...

随机推荐

  1. C#篇(三)——函数传参之引用类型和值类型

    首先应该认清楚在C#中只有两种类型: 1.引用类型(任何称为"类"的类型) 2.值类型(结构或枚举) 先来认识一下引用类型和值类型的区别: 函数传参之引用类型: 1.先来一个简单的 ...

  2. stuff(param1, startIndex, length, param2)

    1.作用 stuff(param1, startIndex, length, param2)将param1中自startIndex(SQL中都是从1开始,而非0)起,删除length个字符,然后用pa ...

  3. GoldenGate 1403错误解决方法

    OGG  oracle goldengate 1403错误解决方法 1. 错误描述WARNING OGG-01154 Oracle GoldenGate Delivery for Oracle, re ...

  4. blongsTo 用法

    当存在这样两张表的时候: one{ , 'name':"name" 'sex':"sex" } two{ , 'type':json } 当我们需要在调用到 o ...

  5. Python对象的循环引用问题

    目录 Python对象循环引用 循环引用垃圾回收算法 容器对象 生成容器对象 追踪容器对象 结束追踪容器对象 分代容器对象链表 何时执行循环引用垃圾回收 循环引用的垃圾回收 循环引用中的终结器 pyt ...

  6. 洛谷 P1071 潜伏者

    P1071 潜伏者 题目描述 R 国和 S 国正陷入战火之中,双方都互派间谍,潜入对方内部,伺机行动.历尽艰险后,潜伏于 S 国的 R 国间谍小 C 终于摸清了 S 国军用密码的编码规则: 1. S ...

  7. typedef 与 set_new_handler的几种写法

    可以用Command模式.函数对象来代替函数指针,获得以下的好处: 1. 可以封装数据 2. 可以通过虚拟成员获得函数的多态性 3. 可以处理类层次结果,将Command与Prototype模式相结合 ...

  8. hdu 5380 Travel with candy(双端队列)

    pid=5380">题目链接:hdu 5380 Travel with candy 保持油箱一直处于满的状态,维护一个队列,记录当前C的油量中分别能够以多少价格退货,以及能够推货的量. ...

  9. Codeforces 11B Jumping Jack(数学)

    B. Jumping Jack time limit per test 1 second memory limit per test 64 megabytes input standard input ...

  10. 轻松学习之Linux教程四 神器vi程序编辑器攻略

    本系列文章由@超人爱因斯坦出品,转载请注明出处.           文章链接:          http://hpw123.net/a/Linux/Linuxjichu/2014/1026/93. ...