最近在搞安卓下的音视频通讯聊天,模块工程均完成后,需要由cocos搭起可执行程序的框架,在使用cocos及第三方静态库的过程中遇到了一些问题,由于自己是首次接触COCOS,再加上COCOS自身的问题,搞了整整一天,也终于算是搞透了;
环境:eclipse+ADT、cocos2d-x-3.5
一、cocos新工程的生成:
进入E:\OpenSource\cocos2d-x-3.5\tools\cocos2d-console\bin
按住shift键,右键空白处,打开命令窗口
使用命令cocos new创建,如:
cocos new -p com.example.mediagame -l cpp -d E:/CodeSpace/AVMeidaGame ProjectName
注:如果提示cocos 命令不存在,请先运行根目录下的setup.py文件(首先需要先按住 python.exe)或者直接打开此文件,一次添加相应的环境变量,然后重启explorer进程使环境变量生效即可。
二、加载静态库
加载静态库(C++,接口类),该静态库也是基于cocos进行开发的,最终生成一个.a文件,过程不再累述,本人首先使用的如下参数(Android.mk):
LOCAL_SRC_FILES:= $(LOCAL_PATH)\libs\libClientPublic.a
LOCAL_STATIC_LIBRARIES := cocos2dx_static
LOCAL_WHOLE_STATIC_LIBRARIES := ClientPublic
在APP类代码中继承静态库中的一个父类,在ndk编译过程中报该父类的成员函数没有实现,问题很明显是该静态库没有正确加载成功所致,经查使用如下方式即可:
在include $(CLEAR_VARS)之前,加入如下命令,生成临时静态库
LOCAL_MODULE:= ClientPublic_static
LOCAL_MODULE_FILENAME := libClientPublic_static
LOCAL_SRC_FILES:=$(LOCAL_PATH)\libs\libClientPublic.a
include $(PREBUILT_STATIC_LIBRARY)
然后在下面适当位置加入加载此临时静态库即可
LOCAL_WHOLE_STATIC_LIBRARIES += ClientPublic_static
这时编译便OK了。
三、eclipse调试运行崩溃
在调试运行过程中出现莫名的崩溃问题,cocos的代码本人只是让APP类继承了静态库中的一个父类,完全没有理由会崩溃的呀,刚开始也是由于没有怀疑cocos自己生成的代码,所以也是浪费了大量的时间啊,最后通过adb抓取crash日志看到了程序崩溃点在Cocos生成的代码HelloWorldScene.cpp文件中使用了已经废弃的接口getContentSize(),调试发现该接口返回的值为无效值,导致在程序布局时为止无效,程序崩溃。
label->setPosition(Vec2(origin.x + visibleSize.width/2,
origin.y + visibleSize.height - label->getContentSize().height));
这里的代码大家自行修改掉即可。这个接口还真是坑人啊!
下面贴出adb抓入crash日志,并通过ndk-stack查看崩溃点的方法:
1,启动adb(D:\adt-bundle-windows\sdk\platform-tools),输入 adb logcat >d:\crash.log
2,启动通过eclipse启动apk,崩溃后在adb启动的cmd中按 ctrl+c,停止输出
3,启动ndk-stack (路径 D:\android-ndk-r9d)
命令格式为: ndk-stack -dmup d:\crash.log -sym obj文件路径
obj文件路径 为COCOS自建工程目录下的proj.android\obj\local\armeabi或者armeabi-v7a
ndk-stack输出建议输出至文本文件,这样看起来比在cmd中看起来方便
命令格式为: ndk-stack -dmup d:\crash.log -sym obj文件路径 >d:\crash_debug.log