Cocos2d-x移植到Android平台编译的两个文件Android.mk和Application.mk

Cocos2d-x移植到Android平台编译的两个文件Android.mk和Application.mk,第1张

概述转自:http://blog.csdn.net/wwj_748/article/details/30055915 本篇博客主要讲NDK编译Android项目的两个文件Android.mk和Application.mk,笔者在使用NDK编译Cocos2d-x生成的Android项目的时候遇到配置编译环境的问题,网上虽然有些配置教程,但并未把一些原理性的东西描述清楚,虽然有时候可以把编译环境配置成功了

转自:http://blog.csdn.net/wwj_748/article/details/30055915


本篇博客主要讲NDK编译AndroID项目的两个文件AndroID.mk和Application.mk,笔者在使用NDK编译Cocos2d-x生成的AndroID项目的时候遇到配置编译环境的问题,网上虽然有些配置教程,但并未把一些原理性的东西描述清楚,虽然有时候可以把编译环境配置成功了,但并不了解为什么要这么来配,有时候出现问题也无从下手去查。笔者是带着疑问去配置NDK的编译环境的,其中就遇到AndroID.mk和Application.mk这两个文件,笔者并不知道这两个文件是用来干嘛的,打开来看之后也有一堆自己不认识的语法,所以才想着写这篇博客来整理总结一下。

下面进入正题:

笔者下载的NDK版本是:androID-ndk-r9d

这两个文件相关的文档在androID-ndk-r9d/docs路径下,原汁原味,你值得拥有。

AndroID.mk文件的作用

AnAndroID.mkfile is written to describe your sources to the build system.

中文意思是:写一个AndroID.mk文件是为了向生成系统描述你的源代码。

Application.mk文件的作用:

The purpose of Application.mk is to describe which native 'modules' (i.e. static/shared librarIEs) are needed by your application. An Application.mk file is usually placed under $PROJECT/jni/Application.mk,where $PROJECT points to your application's project directory.

中文意思是:Application.mk用来描述你的工程下的native模块,一般放在$PROJECT/jni/Application.mk,其中$PROJECT表示你的工程目录,这样就可以被ndk-build脚本文件找到.(注:在这种方式下,进入jni目录,即$PROJECT/jni/,然后执行ndk-build,就可以直接编译jni生成.so文件了).


上面就简单的描述了AndroID.mk和Application.mk的文件的作用,下面拿Cocos2d-x中最简单的例子来简单介绍一下这两个文件。
笔者使用的是Cocos2d-x 2.2.3,创建一个Cocos2d-x项目这里请参考前面笔者发表的博客:http://www.jb51.cc/article/p-voalnesl-sn.html


笔者在cocos2d-x-2.2.3\projects下创建了一个Test项目,导入proj.androID到Eclipse中,会发现有如下的文件目录结构:


在jni文件夹下有这两个文件,我们打开可以看到以下代码,笔者加上对应的注释了:

/Test/jni/AndroID.mk

[plain] view plain copy #1.这个变量用于给出当前文件的路径,my-dir返回当前AndroID.mk所在目录的路径 LOCAL_PATH:=$(callmy-dir) #2.CLEAR_VARS:指向一个编译脚本。这个必须在开始一个新模块之前包含 include$(CLEAR_VARS) #3.这个模块的名字,它必须是唯一的,而且不能包含空格 LOCAL_MODulE:=cocos2dcpp_shared #4.设置你的模块的二进制文件的名称,独立于LOCAL_MODulE LOCAL_MODulE_filename:=libcocos2dcpp #5.这是要编译的源代码文件列表 LOCAL_SRC_fileS:=hellocpp/main.cpp\ ../../Classes/AppDelegate.cpp\ ../../Classes/HelloWorldScene.cpp #6.可选变量,表示头文件的搜索路径 LOCAL_C_INCLUDES:=$(LOCAL_PATH)/../../Classes #7.LOCAL_WHolE_STATIC_liBRARIES会加载整个静态库,LOCAL_STATIC_liBRARIES只是加载静态库中用到的函数。 LOCAL_WHolE_STATIC_liBRARIES+=cocos2dx_static LOCAL_WHolE_STATIC_liBRARIES+=cocosdenshion_static LOCAL_WHolE_STATIC_liBRARIES+=Box2d_static LOCAL_WHolE_STATIC_liBRARIES+=chipmunk_static LOCAL_WHolE_STATIC_liBRARIES+=cocos_extension_static #8.BUILD_SHARED_liBRARY:指向编译脚本,根据所有的在LOCAL_XXX变量把列出的源代码文件编译成一个共享库。 include$(BUILD_SHARED_liBRARY) #9.将一个新的路径加入NDK_MODulE_PATH变量。 $(callimport-add-path,$(LOCAL_PATH)/platform/third_party/androID/prebuilt) #10.在AndroID.mk中引用模块 $(callimport-module,CocosDenshion/androID) $(callimport-module,extensions)
以上代码笔者已经进行了具体的解释,每一行代码代表的作用可以从中得到。更多具体的语法,请读者参考ndk提供的文档。

/Test/jni/Application.mk

#1.指定application里要链接的标准c++库 APP_STL:=gnustl_static #2.编译选项 APP_CPPFLAGS:=-frtti-DCC_ENABLE_CHIPMUNK_INTEGRATION=1-DCOCOS2D_DEBUG=1 总结

以上是内存溢出为你收集整理的Cocos2d-x移植到Android平台编译的两个文件Android.mk和Application.mk全部内容,希望文章能够帮你解决Cocos2d-x移植到Android平台编译的两个文件Android.mk和Application.mk所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1016915.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存