关闭

【cocos2d-x入门之四】cocos2d-x怎么实现跨平台

标签: cocos2d-x跨平台
4182人阅读 评论(0) 收藏 举报
分类:

原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/12610287


cocos2d-x到底是这样实现跨平台的呢?这里以Win32和Android为例。


1.跨平台项目目录结构

先看一下一个项目创建后的目录结构吧!这还是以HelloCpp为例。


 


从左边目录可以看到,Classes和Resource已经平台无关了,而Classes中包含了AppDelegate类,因此我们可以认为AppDelegate是与平台最接近的类,在它以上就要区分平台了。


2.Win32下的实现

在前一篇就介绍了Win32怎么开始cocos2dx,Win32平台下main.cpp就是程序入口:

  1. int APIENTRY _tWinMain(HINSTANCE hInstance,  
  2.                        HINSTANCE hPrevInstance,  
  3.                        LPTSTR    lpCmdLine,  
  4.                        int       nCmdShow)  
  5. {  
  6.     UNREFERENCED_PARAMETER(hPrevInstance);  
  7.     UNREFERENCED_PARAMETER(lpCmdLine);  
  8.   
  9.     // create the application instance  
  10.     AppDelegate app;//创建应用实例  
  11.     CCEGLView* eglView = CCEGLView::sharedOpenGLView();  
  12.     eglView->setViewName("HelloCpp");  
  13.     eglView->setFrameSize(2048, 1536);  
  14.     eglView->setFrameZoomFactor(0.4f);  
  15.     return CCApplication::sharedApplication()->run();//运行程序  
  16. }  
Win32下的实现比较简单,就是正常的创建实例,运行就可以了。


3.Android下的实现


3.1.cocos2d-x程序入口

我们先看一下Android下cocos2d-x程序入口点在哪,我们知道Android是采用Java编写的,而cocos2d-x是c++编写的,所以如果要在Java中调用c++代码,那就需要采用JNI技术,看起来好像高端大气上档次,其实程序就是函数调用,也就是输入→处理→输出,所以JNI实际上简单抽象出来就这么回事:

  1. java输入→Jni→c++输入→c++处理(API实现)→c++输出→Jni→java输出  
\proj.android\jni\hellocpp文件夹下可以找到main.cpp,这就是cocos2d-x的入口:

  1. jint JNI_OnLoad(JavaVM *vm, void *reserved)  
  2. {  
  3.     JniHelper::setJavaVM(vm);  
  4.   
  5.     return JNI_VERSION_1_4;  
  6. }  
  7.   
  8. void Java_org_cocos2dx_lib_Cocos2dxRenderer_nativeInit(JNIEnv*  env, jobject thiz, jint w, jint h)  
  9. {  
  10.     if (!CCDirector::sharedDirector()->getOpenGLView())  
  11.     {  
  12.         CCEGLView *view = CCEGLView::sharedOpenGLView();  
  13.         view->setFrameSize(w, h);  
  14.   
  15.         AppDelegate *pAppDelegate = new AppDelegate();  
  16.         CCApplication::sharedApplication()->run();  
  17.     }  
  18.     else  
  19.     {  
  20.         ccGLInvalidateStateCache();  
  21.         CCShaderCache::sharedShaderCache()->reloadDefaultShaders();  
  22.         ccDrawInit();  
  23.         CCTextureCache::reloadAllTextures();  
  24.         CCNotificationCenter::sharedNotificationCenter()->postNotification(EVENT_COME_TO_FOREGROUND, NULL);  
  25.         CCDirector::sharedDirector()->setGLDefaultValues();   
  26.     }  
  27. }  

里面包含了2个函数,JNI_OnLoad和Java_org_cocos2dx_lib_Cocos2dxRenderer_nativeInit。我们看一下功能而先不管它在哪里被调用。

(1)JNI_OnLoad,这个函数主要是用来高速Android VM当前使用的是什么版本是Jni,如果不提供此函数,则默认使用Jni1.1版本。

(2)Java_org_cocos2dx_lib_Cocos2dxRenderer_nativeInit,这个函数很明显就是运行一个cocos2d-x的应用实例了,这和Win32是一样的,当然它多了一个openGlView的检测。一旦调用了它那么cocos2d-x游戏启动。

接下来再看看它们是在哪里被调用的。


3.2.JNI_OnLoad的调用

在proj.android\src\org\cocos2dx\hellocpp目录下,可以看到Android的入口Activity,也就是HelloCpp,它继承自Cocos2dxActivity。

[java] view plaincopy
  1. public class HelloCpp extends Cocos2dxActivity{  
  2.   
  3.     protected void onCreate(Bundle savedInstanceState){  
  4.         super.onCreate(savedInstanceState);  
  5.     }  
  6.       
  7.     static {  
  8.          System.loadLibrary("hellocpp");  
  9.     }  
  10. }  
很简单的代码,因为功能都被封装到Cocos2dxActivity中了,所以OnCreate中调用了父类的OnCreate就把功能都实现了,而system.LoadLibrary就是载入编译出来的.so文件,此时就会执行JNI_OnLoad。


3.3.Java_org_cocos2dx_lib_Cocos2dxRenderer_nativeInit的调用

那最重要的Java_org_cocos2dx_lib_Cocos2dxRenderer_nativeInit是在哪调用呢?这就比较麻烦了,先大致了解一下Cocos2dxActivity做了一些什么事。

直接进入Cocos2dxActivity的OnCreate函数,它调用了一个init初始化函数:

[java] view plaincopy
  1. public void init() {  
  2.           
  3.         // 设置布局,是一个FrameLayout  
  4.         ViewGroup.LayoutParams framelayout_params =  
  5.         new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT,  
  6.                                        ViewGroup.LayoutParams.FILL_PARENT);  
  7.         FrameLayout framelayout = new FrameLayout(this);  
  8.         framelayout.setLayoutParams(framelayout_params);  
  9.   
  10.         // 设置Cocos2dxEditText布局,这一个跟GLSurfaceView兼容的edittext  
  11.         ViewGroup.LayoutParams edittext_layout_params =  
  12.         new ViewGroup.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT,  
  13.                                    ViewGroup.LayoutParams.WRAP_CONTENT);  
  14.         Cocos2dxEditText edittext = new Cocos2dxEditText(this);  
  15.         edittext.setLayoutParams(edittext_layout_params);  
  16.   
  17.         // 添加到framelaout  
  18.         framelayout.addView(edittext);  
  19.   
  20.         // 创建Cocos2dxGLSurfaceView  
  21.         this.mGLSurfaceView = this.onCreateView();  
  22.   
  23.         // 添加到framelaout  
  24.         framelayout.addView(this.mGLSurfaceView);  
  25.   
  26.         // Switch to supported OpenGL (ARGB888) mode on emulator  
  27.         if (isAndroidEmulator())  
  28.            this.mGLSurfaceView.setEGLConfigChooser(8 , 888160);  
  29.   
  30.         //设置Cocos2dxRenderer和Cocos2dxEditText  
  31.         this.mGLSurfaceView.setCocos2dxRenderer(new Cocos2dxRenderer());  
  32.         this.mGLSurfaceView.setCocos2dxEditText(edittext);  
  33.   
  34.         // 设置framelayout作为内容视图  
  35.     setContentView(framelayout);  
  36.     }  

在这里Cocos2dxActivity做的就是创建Cocos2dxGLSurfaceView,并设置了Cocos2dxRenderer和Cocos2dxEditText,然后添加到FramLayout。具体的各部分实现这里就不贴代码了,画了个图:


好了,就这样吧。因为我对Android界面开发,特别是OpenGLView这块也不熟,所以只能大概推出是这样子了,有什么错误,还请指出。
1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:440488次
    • 积分:4982
    • 等级:
    • 排名:第6000名
    • 原创:65篇
    • 转载:118篇
    • 译文:0篇
    • 评论:51条
    最新评论