##版本
- Cocos2d-x: cocos2d-2.1beta3-x-2.1.1
- OS X: 10.8
- Android ADT Bundle: v21.1.0
- Android NDK: android-ndk-r8d
- Device: Android 4.2.1
这次我们测试的设备安装的是Android4.2.1, Cocos2d-x能支持Android2.2以上版本.
####文件路径:
- Cocos2d-x: /opt/cocos2d-2.1beta3-x-2.1.1
- Android ADT Bundle: /opt/adt-bundle-mac-x86_64
- Android NDK: /opt/android-ndk
下文中提及的这些路径, 请替换成您自己的路径
##下载最新版本Cocos2d-x
您可以在Cocos2d-x官网找到下载页面
解压后到您需要的位置, 本文假设解压到以下位置
1
| /opt/cocos2d-2.1beta3-x-2.1.1
|
##检查JDK
在终端中输入
如果您没有安装JDK, 系统会帮您自动安装JDK.
安装过后您会看到如下输出
1 2 3
| java version "1.6.0_37" Java(TM) SE Runtime Environment (build 1.6.0_37-b06-434-11M3909) Java HotSpot(TM) 64-Bit Server VM (build 20.12-b01-434, mixed mode)
|
##下载最新版本Android ADT Bundle
Google将Android SDK, Eclipse, ADT(Android Developer Tools)打包在一起,称作Android ADT Bundle, 简化了Android开发环境的搭建.
您可以在Android官网找到下载页面
解压到您需要的位置, 本文假设解压到以下位置
1
| /opt/adt-bundle-mac-x86_64
|
在终端中运行下面命令, 将ADT中的Eclipse放入您的程序文件夹, 方便启动
1
| ln -s /opt/adt-bundle-mac-x86_64/eclipse/Eclipse.app/ /Applications/Eclipse-ADT.app
|
在/Applications中或者Launchpad中找到并打开Eclipse-ADT
##Eclipse的Retina支持
如果您在使用带Retina的Mackbook Pro, Eclipse暂时还不支持Retina. 但有一个简单的解决方案
- 在 /opt/adt-bundle-mac-x86_64/eclipse 找到 Eclipse.app
- 编辑
Contents/Info.plist
- 找到
在其上面添加
1 2
| <key>NSHighResolutionCapable</key> <true/>
|
- 将Eclipse.app移动到新的文件夹, 然后再移动回来. (防止系统缓存了上面提及的Info.plist)
- OK啦.
##Android SDK Manager
Android ADT Bundle中是包含了Android SDK Manager的. 启动您的Eclipse-ADT. 可以在工具栏中或者菜单中找到Android SDK Manager.
##Android NDK
您可以在Android官网找到Android的下载页面
下载后解压到您需要的位置, 本文假设解压到以下位置
##设置环境变量
我们需要将SDK, NDK以及Cocos2d-x的路径中添加到环境变量中. 将以下内容添加到~/.bash_profile文件
1 2 3 4 5 6
| export COCOS2DX_ROOT=/opt/cocos2d-2.1beta3-x-2.1.1 export ANDROID_SDK_ROOT=/opt/adt-bundle-mac-x86_64/sdk export ANDROID_NDK_ROOT=/opt/android-ndk export NDK_ROOT=/opt/android-ndk export PATH=$PATH:$ANDROID_NDK_ROOT export PATH=$PATH:$ANDROID_SDK_ROOT
|
##HelloWorld
万事俱备, 我们现在就可以开始激动人心的Cocos2d-x之旅了.
打开终端, 进入cocos2d-x所在目录并执行 /opt/cocos2d-2.1beta3-x-2.1.1/create-android-project.sh
文件
根据提示输入对应信息.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
| Youngs-MacBook-Air:~ young40$ cd /opt/cocos2d-2.1beta3-x-2.1.1/ Youngs-MacBook-Air:cocos2d-2.1beta3-x-2.1.1 young40$ ./create-android-project.sh use global definition of NDK_ROOT: /opt/android-ndk use global definition of ANDROID_SDK_ROOT: /opt/adt-bundle-mac-x86_64/sdk Input package path. For example: org.cocos2dx.example com.young40.test //这里输入了包名 Now cocos2d-x supports Android 2.2 or upper version Available Android targets: id: 1 or "android-17" Name: Android 4.2 Type: Platform API level: 17 Revision: 1 Skins: HVGA, QVGA, WQVGA400, WQVGA432, WSVGA, WVGA800 (default), WVGA854, WXGA720, WXGA800, WXGA800-7in ABIs : armeabi-v7a input target id: 1 //选择您需要的平台id input your project name: HelloWorld //输入项目名称 Created project directory: /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android ..... Updated project.properties Updated local.properties Updated file /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android/proguard-project.txt Youngs-MacBook-Air:cocos2d-2.1beta3-x-2.1.1 young40$
|
从以上输出我们可以看到create-android-project.sh
这个脚本帮我们在 /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld 下建立了新项目.
然后我们可以先在终端中调用”build_native.sh”脚本编译该项目的C++部分.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| Youngs-MacBook-Air:~ young40$ cd /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android/ Youngs-MacBook-Air:proj.android young40$ ./build_native.sh NDK_ROOT = /opt/android-ndk COCOS2DX_ROOT = /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android/../.. APP_ROOT = /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android/.. APP_ANDROID_ROOT = /opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android Using prebuilt externals make: Entering directory `/opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android'
.....
StaticLibrary : libchipmunk.a StaticLibrary : libextension.a SharedLibrary : libgame.so Install : libgame.so => libs/armeabi/libgame.so make: Leaving directory `/opt/cocos2d-2.1beta3-x-2.1.1/HelloWorld/proj.android' Youngs-MacBook-Air:proj.android young40$
|
##导入Eclipse-ADT
打开Eclipse-ADT, 点击快捷键command+N
打开新建项目窗口并选择Android Project from Existing Code
这时您可能会在eclipse的Problems
窗口看到如下错误
1 2 3
| The import org.cocos2dx.lib cannot be resolved HelloWorld.java /HelloWorld/src/com/young40/test line 26 Java Problem Cocos2dxActivity cannot be resolved to a type HelloWorld.java /HelloWorld/src/com/young40/test line 30 Java Problem Cocos2dxActivity cannot be resolved to a type HelloWorld.java /HelloWorld/src/com/young40/test line 33 Java Problem
|
您需要将/opt/cocos2d-2.1beta3-x-2.1.1/cocos2dx/platform/android/java
如上面处理一样也作为一个项目导入eclipse中
然后在HelloWorld项目上点击右键选择刷新, 可以看到错误就消失了.
将您的手机设置成调试模式并用USB线连接到电脑, 在Eclipse中运行HelloWorld, 然后就能在手机上看到已经运行的HelloWorld了
好了, 享受您的奇妙的Cocos2d-x之旅吧!