`
houyingsoft
  • 浏览: 87294 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

cocos2d-x使用Ant实现批量打包

阅读更多
参考文献:http://blog.csdn.net/junfeng120125/article/details/9234651

开发环境:win764位,android-ndk-r9,cocos2d-x-3.2,contrib-1.0b3,android-4.4

直接上代码
<?xml version="1.0" encoding="UTF-8"?>
<project name="Test" default="deploy">
	<!-- ANT环境变量 -->
	<property environment="env" />
	<!-- 使用第三方的ant包,使ant支持for循环-->
         <!-- 将ant-contrib-1.0b3.jar放到ant的lib目录下即可-->
	<taskdef resource="net/sf/antcontrib/antcontrib.properties">
		<classpath>
			<pathelement location="${env.ANT_ROOT}/lib/ant-contrib-1.0b3.jar" />
		</classpath>
	</taskdef>
	<property file="local.properties" />
	<!-- 应用名称 -->
	<property name="appName" value="${ant.project.name}" />
	<!-- SDK目录(获取操作系统环境变量ANDROID_SDK_HOME的值) -->
	<property name="sdk-folder" value="${env.ANDROID_SDK_ROOT}" />
	<!-- SDK指定平台目录 -->
	<property name="sdk-platform-folder" value="${sdk-folder}/platforms/android-19" />
	<!-- SDK中tools目录 -->
	<property name="sdk-tools" value="${sdk-folder}/tools" />
	<!-- SDK指定平台中tools目录 -->
	<property name="sdk-build-tools" value="${sdk-folder}/build-tools/android-4.4" />

	<!-- 使用到的命令(当前系统为windows,如果系统为linux,可将.bat文件替换成相对应的命令) -->
	<property name="aapt" value="${sdk-build-tools}/aapt" />
	<property name="aidl" value="${sdk-build-tools}/aidl" />
	<property name="dx" value="${sdk-build-tools}/dx.bat" />
	<!-- 在android3.0这个apkbuilder被废弃了,可以copy一个放在如下目录下-->
	<property name="apkbuilder" value="${sdk-tools}/apkbuilder.bat" />
	<property name="jarsigner" value="${env.JAVA_HOME}/bin/jarsigner" />
	<property name="zipalign" value="${sdk-tools}/zipalign" />

	<!-- 编译需要的jar; 如果项目使用到地图服务则需要maps.jar -->
	<property name="android-jar" value="${sdk-platform-folder}/android.jar" />
	<property name="proguard-home" value="${sdk-tools}/proguard/lib" />
	<!--
	<property name="android-maps-jar" value="${sdk-folder}/add-ons/addon_google_apis_google_inc_8/libs/maps.jar" />
	-->
	<!--
	 -->
	
	<!-- 编译aidl文件所需的预处理框架文件framework.aidl -->
	<property name="framework-aidl" value="${sdk-platform-folder}/framework.aidl" />
	<!-- 清单文件 -->
	<property name="manifest-xml" value="AndroidManifest.xml" />
	<!-- 源文件目录 -->
	<property name="resource-dir" value="res" />
	<property name="asset-dir" value="assets" />
	<!-- java源文件目录 -->
	<property name="srcdir" value="src" />
	<property name="srcdir-ospath" value="${basedir}/${srcdir}" />
	<!-- 外部类库所在目录 -->
	<property name="external-lib" value="libs" />
	<property name="external-lib-ospath" value="${basedir}/${external-lib}" />
	<property name="ndk.dir" value="${evn.NDK_ROOT}" />
	<!-- 版本 -->
	<property name="version" value="3.0" />
	<property name="channelname" value="" />
	<property name="channelkey" value="" />
	<property name="key" value="${channels}" />
	
	<!--循环打包 -->
		<target name="deploy">
		<!---->
			<antcall target="native" />
		
			<foreach target="modify_manifest" list="${key}" param="nameandchannel" delimiter=",">
			</foreach>
		</target>
		<target name="modify_manifest">
			<echo>----------------------------------------------------</echo>
			<!-- 获取渠道名字 -->
			<!--
			<propertyregex override="true" property="channelname" input="${nameandchannel}" regexp="(.*):" select="\1" />
			-->
			<!-- 获取渠道号码 -->
			<propertyregex override="true" property="channelkey" input="${nameandchannel}" regexp="(.*)" select="\1" />
			<!-- 正则匹配替换渠道号 -->
			
			<replaceregexp flags="g" byline="false" encoding="UTF-8">
				<regexp pattern='meta-data android:name="UMENG_CHANNEL" android:value="(.*)"' />
				<substitution expression='meta-data android:name="UMENG_CHANNEL" android:value="${channelkey}"' />
				<fileset dir="" includes="AndroidManifest.xml" />
			</replaceregexp>
			<antcall target="zipalign" />
		</target>
	
	<!-- 初始化工作 -->
	<target name="init">
		<echo>目录初始化....</echo>
		<!-- 生成R文件的相对目录 -->
		<var name="outdir-gen" value="gen" />
		<!-- 编译后的文件放置目录 -->
		<var name="outdir-bin" value="publish/${channelkey}" />
		<!-- 生成class目录 -->
		<var name="outdir-classes" value="${outdir-bin}/otherfile" />
		<var name="outdir-classes-ospath" value="${basedir}/${outdir-classes}" />

		<!-- classes.dex相关变量 -->
		<var name="dex-file" value="classes.dex" />
		<var name="dex-path" value="${outdir-bin}/${dex-file}" />
		<var name="dex-ospath" value="${basedir}/${dex-path}" />

		<!-- 经过aapt生成的资源包文件 -->
		<var name="resources-package" value="${outdir-bin}/resources.ap_" />
		<var name="resources-package-ospath" value="${basedir}/${resources-package}" />

		<!-- 未认证apk包 -->
		<var name="out-unsigned-package" value="${outdir-bin}/${appName}-unsigned.apk" />
		<var name="out-unsigned-package-ospath" value="${basedir}/${out-unsigned-package}" />

		<!-- 证书文件 -->
		<var name="keystore-file" value="${basedir}/testant.keystore" />

		<!-- 已认证apk包 -->
		<var name="out-signed-package" value="${outdir-bin}/${appName}_${channelkey}_${version}.apk" />
		<var name="out-signed-package-ospath" value="${basedir}/${out-signed-package}" />
		<delete dir="${outdir-bin}" />
		<mkdir dir="${outdir-bin}" />
		<mkdir dir="${outdir-classes}" />
	</target>

	<!-- 根据工程中的资源文件生成R.java文件  -->
	<target name="gen-R" depends="init">
		<echo>生成R.java文件....</echo>
		<exec executable="${aapt}" failonerror="true">
			<arg value="package" />
			<arg value="-f" />
			<arg value="-m" />
			<arg value="-J" />
			<arg value="${outdir-gen}" />
			<arg value="-S" />
			<arg value="${resource-dir}" />
			<arg value="-M" />
			<arg value="${manifest-xml}" />
			<arg value="-I" />
			<arg value="${android-jar}" />
		</exec>
	</target>

	<!-- 编译aidl文件 -->
	<target name="aidl" depends="gen-R">
		<echo>编译aidl文件....</echo>
		<apply executable="${aidl}" failonerror="true">
			<!-- 指定预处理文件 -->
			<arg value="-p${framework-aidl}" />
			<!-- aidl声明的目录 -->
			<arg value="-I${srcdir}" />
			<!-- 目标文件目录 -->
			<arg value="-o${outdir-gen}" />
			<!-- 指定哪些文件需要编译 -->
			<fileset dir="${srcdir}">
				<include name="**/*.aidl" />
			</fileset>
		</apply>
	</target>

	<!-- 将工程中的java源文件编译成class文件 -->
	<target name="compile" depends="aidl">
		<echo>java源文件编译成class文件....</echo>
		<javac encoding="utf-8" target="1.5" srcdir="." destdir="${outdir-classes}" bootclasspath="${android-jar}" verbose="false">
			<compilerarg line="-encoding GBK " />
			<classpath>
				<fileset dir="${external-lib}" includes="*.jar" />
			</classpath>
		</javac>
	</target>


	<!-- 将.class文件转化成.dex文件 -->
	<target name="dex" depends="compile">
		<echo>将.class文件转化成.dex文件....</echo>
		<exec executable="${dx}" failonerror="true">
			<arg value="--dex" />
			<!-- 输出文件 -->
			<arg value="--output=${dex-ospath}" />
			<!-- 要生成.dex文件的源classes和libraries -->
			<arg value="${outdir-classes-ospath}" />
			<arg value="${external-lib-ospath}" />
		</exec>
	</target>

	<!-- 将资源文件放进输出目录 -->
	<target name="package-res-and-assets">
		<echo>将资源文件放进输出目录....</echo>
		<exec executable="${aapt}" failonerror="true">
			<arg value="package" />
			<arg value="-f" />
			<arg value="-M" />
			<arg value="${manifest-xml}" />
			<arg value="-S" />
			<arg value="${resource-dir}" />
			<arg value="-A" />
			<arg value="${asset-dir}" />
			<arg value="-I" />
			<arg value="${android-jar}" />
			<arg value="-F" />
			<arg value="${resources-package}" />
		</exec>
	</target>
	
	<!---->
	<target name="native">
        <echo>编译native包......</echo>
		<!--<exec executable="${ndk.dir}/ndk-build.cmd" failonerror="true" />-->
		<!--<exec executable="D:\devtools\android-ndk-r10\ndk-build.cmd" failonerror="true" />-->
        <exec executable="${env.NDK_ROOT}/ndk-build.cmd" failonerror="true">
			<arg value="-D" />
		</exec>
        <echo message="DONE (Building native libraries)" />
    </target>
	

	<!-- 打包成未签证的apk -->
	<target name="package" depends="dex, package-res-and-assets">
		<echo>打包成未签证的apk....</echo>
		<exec executable="${apkbuilder}" failonerror="true">
			<arg value="${out-unsigned-package-ospath}" />
			<arg value="-u" />
			<arg value="-z" />
			<arg value="${resources-package-ospath}" />
			<arg value="-f" />
			<arg value="${dex-ospath}" />
			<arg value="-rf" />
			<arg value="${srcdir-ospath}" />
			<arg value="-nf"/>
			<arg value="${external-lib-ospath}" />
		</exec>
	</target>

	<!-- 对apk进行签证 -->
	<target name="jarsigner" depends="package">
		<echo>Packaging signed apk for release...</echo>
		<exec executable="${jarsigner}" failonerror="true">
			<arg value="-keystore" />
			<arg value="${keystore-file}" />
			<arg value="-storepass" />
			<arg value="111111" />
			<arg value="-keypass" />
			<arg value="111111" />
			<arg value="-signedjar" />
			<arg value="${out-signed-package-ospath}" />
			<arg value="${out-unsigned-package-ospath}" />
			<!-- 不要忘了证书的别名 -->
			<arg value="testant" />
		</exec>
	</target>

	<!-- 发布 -->
	<target name="release" depends="jarsigner">
		<!-- 删除未签证apk -->
		<delete file="${out-unsigned-package-ospath}" />
		<echo>APK is released. path:${out-signed-package-ospath}</echo>
		<delete dir="${outdir-classes}"/>  
        <delete file="${dex-ospath}" />  
        <delete file="${resources-package-ospath}" />
	</target>
	<!-- 打包的应用程序进行优化 -->
	
	<target name="zipalign" depends="release">
		<exec executable="${zipalign}" failonerror="true">
			<arg value="-v" />
			<arg value="4" />
			<arg value="${out-signed-package-ospath}" />
			<arg value="${out-signed-package-ospath}-zipaligned.apk" />
		</exec>
	</target>
	
	<target name="install" depends="deploy"
		description="install debug.apk">  
		<!-- target:debug调用过后,out.filal.file才会作为常量被初始化。所以单独调用install是无效的 -->  
		<echo message="adb install -r  ${out.absolute.dir}/${ant.project.name}-debug.apk"/>  
		  
		<apply executable="${sdk-folder}/platform-tools/adb.exe" failonerror="true">  
			<arg value="install" />
			<arg value="-r" />  
				<file file="${outdir-bin}/${appName}_${channelkey}_${version}.apk"/>  
		</apply>
	</target>
	
	<target name="startActivity" depends="install"
		description="Start Activity: app_package/app_launch_activity">
		<echo>安装apk</echo>
		<echo message="adb shell am start -n ${app_package}/${app_launch_activity}"/>  
			   <exec executable="adb">  
					<arg value="shell"/>  
					<arg value="am"/>  
					<arg value="start"/>  
					<arg value="-n"/>  
					<arg value="${app_package}/${app_launch_activity}"/>  
			  </exec>  
	</target>  
</project>


local.properties文件
sdk.dir=D:\\devtools\\adt-bundle-windows-x86_64-20131030\\sdk
### 定义apk的包名  
app_package=cn.hy.test
### 定义apk的启动入口Activity  
app_launch_activity=org.cocos2dx.cpp.AppActivity
channels=11,22,33,44,55,66,77,88,99


在AndroidManifest.xml中加入
<meta-data android:name="UMENG_CHANNEL" android:value="99"></meta-data>


如果出现如下错误: *** Android NDK: Aborting    .  Stop. 
将Application.mk中
APP_STL := c++_static
NDK_TOOLCHAIN_VERSION=clang

APP_CPPFLAGS := -frtti -DCC_ENABLE_CHIPMUNK_INTEGRATION=1 -std=c++11 -fsigned-char
APP_LDFLAGS := -latomic

替换为:
APP_STL := gnustl_static
APP_CPPFLAGS := -frtti -DCOCOS2D_DEBUG=1 -std=c++11 -Wno-literal-suffix -fsigned-char


如项目中使用到了cocostudio的导出文件,需要在Android.mk文件中的LOCAL_C_INCLUDES后面追加:
$(LOCAL_PATH)/../../cocos2d/cocos/editor-support/cocostudio \
$(LOCAL_PATH)/../../cocos2d/cocos/editor-support \
$(LOCAL_PATH)/../../cocos2d/extensions \
$(LOCAL_PATH)/../../cocos2d/cocos/ui \
$(LOCAL_PATH)/../../cocos2d/cocos


如果遇到下面的错误:
fatal error: json/document.h:
需要在Android.mk文件中的LOCAL_C_INCLUDES后面追加:
$(LOCAL_PATH)/../../cocos2d/external


如果遇到下面的错误:
ndk error: 'override' does not name a type
满屏都是这样的错误,'override'是c++11的新特性,可以判断gcc版本不支持c++11引起的问题,在build_native.py文件中有如下这段话:
 '''Because ndk-r8e uses gcc4.6 as default. gcc4.6 doesn't support c++11. So we should select gcc4.7 when
    using ndk-r8e. But gcc4.7 is removed in ndk-r9, so we should determine whether gcc4.7 exist.
    Conclution:
    ndk-r8e  -> use gcc4.7
    ndk-r9   -> use gcc4.8
    '''

因此要使用gcc4.8,需要在Application.mk(jni目录下)文件的最后加上:
NDK_TOOLCHAIN_VERSION = 4.8


如果在编译过程中遇到如下错误:
error: undefined reference to 'cocostudio
需要将Android.mk中注释掉的部分代码打开
# LOCAL_WHOLE_STATIC_LIBRARIES += box2d_static
 LOCAL_WHOLE_STATIC_LIBRARIES += cocosbuilder_static     #打开注释
# LOCAL_WHOLE_STATIC_LIBRARIES += spine_static
 LOCAL_WHOLE_STATIC_LIBRARIES += cocostudio_static       #打开注释

# LOCAL_WHOLE_STATIC_LIBRARIES += cocos_network_static
 LOCAL_WHOLE_STATIC_LIBRARIES += cocos_extension_static  #打开注释


...

# $(call import-module,Box2D)
 $(call import-module,editor-support/cocosbuilder)       #打开注释

# $(call import-module,editor-support/spine)
 $(call import-module,editor-support/cocostudio)         #打开注释

# $(call import-module,network)
 $(call import-module,extensions)                        #打开注释



最终的Android.mk文件如下:
LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

$(call import-add-path,$(LOCAL_PATH)/../../cocos2d)
$(call import-add-path,$(LOCAL_PATH)/../../cocos2d/external)
$(call import-add-path,$(LOCAL_PATH)/../../cocos2d/cocos)

LOCAL_MODULE := cocos2dcpp_shared

LOCAL_MODULE_FILENAME := libcocos2dcpp

LOCAL_SRC_FILES := hellocpp/main.cpp \
                   ../../Classes/AppDelegate.cpp \
                   ../../Classes/HelloWorldScene.cpp

LOCAL_C_INCLUDES := $(LOCAL_PATH)/../../Classes \
					$(LOCAL_PATH)/../../cocos2d/cocos/editor-support/cocostudio \
                    $(LOCAL_PATH)/../../cocos2d/cocos/editor-support \
                    $(LOCAL_PATH)/../../cocos2d/extensions \
                    $(LOCAL_PATH)/../../cocos2d/cocos/ui \
                    $(LOCAL_PATH)/../../cocos2d/cocos \
					$(LOCAL_PATH)/../../cocos2d/external

LOCAL_WHOLE_STATIC_LIBRARIES := cocos2dx_static
LOCAL_WHOLE_STATIC_LIBRARIES += cocosdenshion_static

# LOCAL_WHOLE_STATIC_LIBRARIES += box2d_static
 LOCAL_WHOLE_STATIC_LIBRARIES += cocosbuilder_static
# LOCAL_WHOLE_STATIC_LIBRARIES += spine_static
 LOCAL_WHOLE_STATIC_LIBRARIES += cocostudio_static
# LOCAL_WHOLE_STATIC_LIBRARIES += cocos_network_static
 LOCAL_WHOLE_STATIC_LIBRARIES += cocos_extension_static


include $(BUILD_SHARED_LIBRARY)

$(call import-module,.)
$(call import-module,audio/android)

# $(call import-module,Box2D)
 $(call import-module,editor-support/cocosbuilder)
# $(call import-module,editor-support/spine)
 $(call import-module,editor-support/cocostudio)
# $(call import-module,network)
 $(call import-module,extensions)



为了将apk安装到genymotion上,需要在Application.mk文件中最后一行追加
APP_ABI := armeabi armeabi-v7a x86

这句话的意思是打成x86架构的apk包,因为genymotion使用virtualbox模拟android设备。

最终的Application.mk文件内容如下:
APP_STL := gnustl_static
APP_CPPFLAGS := -frtti -DCOCOS2D_DEBUG=1 -std=c++11 -Wno-literal-suffix -fsigned-char


APP_DEBUG := $(strip $(NDK_DEBUG))
ifeq ($(APP_DEBUG),1)
  APP_CPPFLAGS += -DCOCOS2D_DEBUG=1
  APP_OPTIM := debug
else
  APP_CPPFLAGS += -DNDEBUG
  APP_OPTIM := release
endif
NDK_TOOLCHAIN_VERSION = 4.8
APP_ABI := armeabi armeabi-v7a x86


另外,在使用Genymotion的时候,如果出现“INSTALL_FAILED_CPU_ABI_INCOMPATIBLE”错误,下载Genymotion-ARM-Translation.zip,直接拖到模拟器界面安装即可。
分享到:
评论

相关推荐

    Cocos2d-x实战:JS卷——Cocos2d-JS开发

    资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...

    Cocos2d-x 3.x游戏开发实战pdf含目录

    《Cocos2d-x 3.x游戏开发实战》是一本深度探讨Cocos2d-x 3.x框架的游戏开发书籍,适合对游戏编程有兴趣的开发者学习。Cocos2d-x 是一个开源的、跨平台的2D游戏开发框架,广泛应用于iOS、Android、Windows等多平台的...

    Cocos2d-x实战:C++卷(2版)源代码

    1. **场景(Scene)与层(Layer)管理**:Cocos2d-x使用场景和层的概念组织游戏画面。场景是一个完整的屏幕视图,而层则是场景中的一个可独立管理的部分,多个层可以组合成一个场景。 2. **精灵(Sprite)与动画**...

    cocos2d-x windows vs2010配置

    本文将详细介绍如何在 Windows 环境下使用 Visual Studio 2010 配置 Cocos2d-x 游戏引擎。Cocos2d-x 是一个跨平台的游戏引擎,可以在多种平台上运行,包括 Windows、Mac OS X、iOS、Android 等。 一、下载和安装 ...

    cocos2d-x-cocos2d-x-2.2.2.zip

    总的来说,cocos2d-x 2.2.2是一个功能完备、易于学习和使用的2D游戏开发框架。通过深入理解并掌握这个版本,开发者可以创建出运行在多种平台上的高质量游戏,享受到cocos2d-x带来的强大开发体验。无论是初学者还是...

    cocos2d-x-3.13.1 spine3.6.zip

    Cocos2d-x是一个广泛使用的开源游戏开发框架,它基于C++,同时支持Lua和JavaScript等多种脚本语言,为开发者提供了高效、跨平台的游戏开发解决方案。在3.13.1版本中,Cocos2d-x对Spine动画引擎的集成进行了更新,这...

    经典版本 方便下载 源码 旧版本 3.8 官网找不到了 cocos2d-x-3.8.zip

    2. **C++核心**:3.8版本的cocos2d-x使用C++作为主要开发语言,保证了性能和灵活性,同时也通过tolua++和jsb提供Lua和JavaScript接口。 3. **强大的渲染引擎**:支持精灵、批处理、骨骼动画、物理引擎等多种图形...

    cocos2d-x_v3.16安装及环境变量配置文档

    cocos2d-x 是一个开源的游戏开发框架,使用 C++ 语言编写,支持多平台发布,包括 iOS、Android、Windows、macOS、Linux 和 Web。cocos2d-x v3.16 是该框架的一个版本号,本文档主要介绍了该版本的安装流程以及环境...

    Cocos2d-x实战C++卷关东升著完整版pdf

    最后,还会涉及到Cocos2d-x的构建系统和发布流程,包括多平台支持、资源打包、调试技巧等,帮助开发者将游戏顺利部署到不同的设备上。 总之,《Cocos2d-x实战C++卷》全面覆盖了Cocos2d-x游戏开发的各个环节,从基础...

    cocos2d-x 动画工具 Flash2Cocos2d-x 1.3

    在移动游戏开发领域,cocos2d-x是一款广泛使用的开源游戏引擎,以其高效、跨平台的特性深受开发者喜爱。而Flash2Cocos2d-x则是一个专为cocos2d-x设计的动画工具,它使得开发者能够将Flash内容轻松地转换为可以在...

    cocos2d-x-3.1.zip

    Cocos2d-x是一个开源的游戏开发框架,广泛用于2D游戏、实时渲染应用程序和其他互动内容的制作。这个压缩包“cocos2d-x-3.1.zip”包含了Cocos2d-x框架的3.1版本,这是一个经典且相对旧的版本,可能对于那些寻找历史...

    cocos2d-x 3.0

    在游戏开发领域,cocos2d-x是一款广泛使用的开源2D游戏引擎,尤其在移动平台上的应用非常广泛。cocos2d-x 3.0版本带来了许多性能优化和新特性,使得开发者能够更高效地创建游戏。本篇文章将深入探讨cocos2d-x 3.0中...

    Cocos2d-x实战 JS卷 Cocos2d-JS开发

    2. **图形与动画**:讲解如何使用Cocos2d-x的绘图API绘制2D图形,实现精灵(Sprite)、动画(Animation)和粒子系统(Particle System)。 3. **物理引擎**:介绍Cocos2d-x内置的Box2D物理引擎,用于模拟游戏中的...

    cocos2d-x-2.1.5

    cocos2d-x-2.1.5

    Cocos2d-x实战++JS卷++Cocos2d-JS开发+PDF电子书下载+带书签目录+完整

    3. Cocos2d-JS开发:这里强调的是使用Cocos2d-x框架结合JavaScript语言进行开发的过程。由于Cocos2d-x支持多种编程语言(包括C++、JavaScript和Lua),Cocos2d-JS意味着开发者可以采用JavaScript来构建游戏项目。 4...

    cocos2d-x-2.1.4.rar

    2. C++ 基础:cocos2d-x 使用C++作为主要编程语言,同时提供了Python、JavaScript等语言的绑定,满足不同开发者的需求。 3. 图形渲染:框架内置了基于OpenGL的图形渲染引擎,提供2D图形绘制、动画处理等功能,使...

    cocos2d-x源码素材

    【cocos2d-x源码素材】是一套用于学习cocos2d-x游戏开发的代码资源,它在Windows平台上使用Visual Studio 2010进行编译并通过了测试。这个资源包涵盖了多个重要的游戏开发技术,包括碰撞检测、瓦片地图(Tile Map)...

    Cocos2d-x实战 JS卷

    《Cocos2d-x实战 JS卷》是一本深入探讨Cocos2d-x游戏开发的专著,主要聚焦于使用JavaScript语言进行游戏编程。Cocos2d-x是一个开源的游戏开发框架,广泛应用于移动设备和桌面平台,支持iOS、Android、Windows等多...

    cocos2d-x API中文文档

    【cocos2d-x API中文文档】是一份详尽的资料,主要涵盖了cocos2d-x游戏...通过这份文档,开发者可以了解如何利用cocos2d-x的API构建游戏场景、处理用户交互、动画效果以及实现游戏逻辑,从而提高开发效率和游戏质量。

    Cocos2d-x 闪电特效

    Cocos2d-x提供了光照模型和着色器支持,可以结合使用来实现这种闪烁效果。 此外,为了实现闪电的随机性和多样性,开发者可能需要引入一定的随机性,比如随机调整闪电的分支数量、长度和弯曲度。这可以通过在代码中...

Global site tag (gtag.js) - Google Analytics