(Upgrade.h)

#include <stdio.h>

#include "cocos2d.h"

#include "framework/utils/Utils.h"

#include "framework/json/JSONObject.h"

USING_NS_CC;

#include "ide-support/SimpleConfigParser.h"

#include "extensions/cocos-ext.h"

USING_NS_CC_EXT;

using namespace std;

class Upgrade : public Layer, public AssetsManagerDelegateProtocol

{

public:

static Scene* createScene();

Upgrade();

virtual void onEnter();

virtual ~Upgrade();

virtual bool init();

void enterScene();

void upgrade(); //检查版本更新

  //重写AssetsManagerDelegateProtocol中的三个虚函数

virtual void onError(AssetsManager::ErrorCode errorCode); //错误信息

virtual void onProgress(int percent); //更新下载进度

virtual void onSuccess(); //下载成功

CREATE_FUNC(Upgrade);

private:

AssetsManager* getAssetManager();

string DirectoryPathCache_Res;

string DirectoryPathCache_Src;

string DirectoryPathCache_Resources;

};

#include "framework/updater/Upgrade.h"

#include "SimpleAudioEngine.h"

#include "CCLuaEngine.h"

#include "lua_module_register.h"

#include "cocos2d.h"

#if (CC_TARGET_PLATFORM != CC_PLATFORM_LINUX)

#include "ide-support/CodeIDESupport.h"

#endif

#if (COCOS2D_DEBUG > 0) && (CC_CODE_IDE_DEBUG_SUPPORT > 0)

#include "runtime/Runtime.h"

#include "ide-support/RuntimeLuaImpl.h"

#endif

(Upgrade.cpp)

USING_NS_CC;

USING_NS_CC_EXT;

using namespace CocosDenshion;

#define TEMP_PACKAGE_FILE_NAME "Scripts" //下载后保存的文件夹名

static const char * UpdaterConfig="res/UpdaterConfig.json";

static const char * KEY_PackageURL="PackageUrl";

static const char * KEY_VersionURL="VersionUrl";

Upgrade::Upgrade()

{

std::vector<std::string> searchPaths;

#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)

FileUtils::getInstance()->setPopupNotify(false);

searchPaths.push_back("ccs-res/");

searchPaths.push_back("ccs-res/res/");

string path= StringUtils::format("%s%s",FileUtils::getInstance()->getWritablePath().c_str(),"debugruntime/");

DirectoryPathCache_Resources=path;

DirectoryPathCache_Res=StringUtils::format("%s/res/",path.c_str());

DirectoryPathCache_Src=StringUtils::format("%s/src/",path.c_str());;

#elif (CC_TARGET_PLATFORM == CC_PLATFORM_IOS)

DirectoryPathCache_Res=FileUtils::getInstance()->fullPathForFilename("res");

DirectoryPathCache_Resources=StringUtils::format("%s/", DirectoryPathCache_Res.substr(0, DirectoryPathCache_Res.find_last_of("/")).c_str());

DirectoryPathCache_Src=FileUtils::getInstance()->fullPathForFilename("src");

#endif

searchPaths.push_back(DirectoryPathCache_Src);

searchPaths.push_back(DirectoryPathCache_Res);

FileUtils::getInstance()->setSearchPaths(searchPaths);

}

Scene* Upgrade::createScene()

{

auto scene = Scene::create();

auto layer = Upgrade::create();

scene->addChild(layer);

return scene;

}

Upgrade::~Upgrade()

{

AssetsManager* assetManager = getAssetManager();

CC_SAFE_DELETE(assetManager);

#if (COCOS2D_DEBUG > 0) && (CC_CODE_IDE_DEBUG_SUPPORT > 0)

// NOTE:Please don't remove this call if you want to debug with Cocos Code IDE

RuntimeEngine::getInstance()->end();

#endif

}

bool Upgrade::init()

{

if (!CCLayer::init())

{

return false;

}

return true;

}

void Upgrade::onError(AssetsManager::ErrorCode errorCode)

{

if (errorCode == AssetsManager::ErrorCode::NO_NEW_VERSION)

{

CCLOG("检查新版本: %s","当前已是最新版本");

}

else if (errorCode == AssetsManager::ErrorCode::NETWORK)

{

CCLOG("检查新版本: %s","更新失败 请检查网络状态");

}

else if (errorCode == AssetsManager::ErrorCode::CREATE_FILE)

{

CCLOG("检查新版本: %s","创建临时文件失败");

}else if(errorCode == AssetsManager::ErrorCode::UNCOMPRESS){

CCLOG("检查新版本: %s","更新包解压失败");

}

}

void Upgrade::onProgress(int percent)

{

if (percent < 0)

return;

CCLOG("下载进度: %d%%",percent);

}

void Upgrade::onEnter(){

CCLOG("onEnter!");

upgrade();

}

void Upgrade::onSuccess()

{

CCLOG("下载完毕!");

this->enterScene();

}

void Upgrade::enterScene(){

#if (COCOS2D_DEBUG > 0) && (CC_CODE_IDE_DEBUG_SUPPORT > 0)

RuntimeEngine::getInstance()->addRuntime(RuntimeLuaImpl::create(), kRuntimeEngineLua);

RuntimeEngine::getInstance()->start();

CCLOG("iShow!");

#else

auto engine = LuaEngine::getInstance();

ScriptEngineManager::getInstance()->setScriptEngine(engine);

lua_module_register(engine->getLuaStack()->getLuaState());

engine->getLuaStack()->setXXTEAKeyAndSign("2dxLua", strlen("2dxLua"), "XXTEA", strlen("XXTEA"));

engine->executeScriptFile("src/main.lua");

#endif

}

static void ConfigAndroidParameters(JSONObject * object){

#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)

JSONObject * json=JSONObject::create();

json->put("NETLOG_URL",object->getString("NETLOG_URL").c_str());

Utils::ConfigParameters(json->toString());

#endif

}

AssetsManager* Upgrade::getAssetManager()

{

static AssetsManager *assetManager = NULL;

if (!assetManager)

{

static AssetsManager *assetManager = NULL;

if (!assetManager)

{

string fileContent = "";

#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)

string fullPathFile=StringUtils::format("%s%s%s",FileUtils::getInstance()->getWritablePath().c_str(),"debugruntime/",UpdaterConfig);

CCLOG("文件路径:--------%s",fullPathFile.c_str());

fileContent = FileUtils::getInstance()->getStringFromFile(fullPathFile);

#elif(CC_TARGET_PLATFORM == CC_PLATFORM_IOS)

string fullPathFile=FileUtils::getInstance()->fullPathForFilename(UpdaterConfig);

fileContent = FileUtils::getInstance()->getStringFromFile(fullPathFile);

CCLOG("文件路径:--------%s",fullPathFile.c_str());

#endif

CCLOG("配置文件内容:%s",fileContent.c_str());

JSONObject * object=JSONObject::create(fileContent.c_str());

ConfigAndroidParameters(object);

//获取更新包地址

string packageUrl=object->getString(KEY_PackageURL);

//获取版本号地址

string versionUrl=object->getString(KEY_VersionURL);

CCLOG("更新包地址:%s",packageUrl.c_str());

CCLOG("获取版本号地址:%s",versionUrl.c_str());

string storageDirectory=DirectoryPathCache_Resources;

CCLOG("下载存储路径:%s",storageDirectory.c_str());

assetManager = new AssetsManager(packageUrl.c_str(),versionUrl.c_str(), storageDirectory.c_str());

assetManager->setDelegate(this);

assetManager->setConnectionTimeout(8);

CCLOG("当前版本号:%s",assetManager->getVersion().c_str());

if (assetManager->checkUpdate()) {

assetManager->update();

}else{

this->enterScene();

}

}

}

return assetManager;

}

void Upgrade::upgrade()

{

getAssetManager();

}

#endif

(作者很懒,此处不做注释,后续修改)

cocos2dx lua 热更新方案的实现的更多相关文章

  1. 腾讯开源手游热更新方案,Unity3D下的Lua编程

    原文:http://www.sohu.com/a/123334175_355140 作者|车雄生 编辑|木环 腾讯最近在开源方面的动作不断:先是微信跨平台基础组件Mars宣布开源,腾讯手游又于近期开源 ...

  2. 【腾讯Bugly干货分享】手游热更新方案xLua开源:Unity3D下Lua编程解决方案

    本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:http://mp.weixin.qq.com/s/2bY7A6ihK9IMcA0bOFyB-Q 导语 xL ...

  3. 移动端热更新方案(iOS+Android)

    PPT资源包含iOS+Android 各种方案分析:https://github.com/qiyer/Share/blob/master/%E7%83%AD%E6%9B%B4%E6%96%B0%E5% ...

  4. Unity代码热更新方案 JSBinding + SharpKit 首页

    目前Unity的代码更新方案有很多,主要以lua为主. JSBinding + SharpKit 是一种新的技术,他做了两件事情: JSBinding将C#导出到 JavaScript (引擎是 Mo ...

  5. Unity3D 热更新方案(集合各位专家的汇总)

    http://blog.csdn.net/guofeng526/article/details/52662994 热更新”这个词,在Unity3D的应用下,是有些语义错误的,但是作为大家都熟知的一项技 ...

  6. Unity实现c#热更新方案探究(三)

    转载请标明出处:http://www.cnblogs.com/zblade/ 前面两篇文章从头到尾讲解了C#热更新的一些方案,从程序域来加载和卸载DLL,到使用ILRuntime来实现安卓和IOS平台 ...

  7. Unity3D 热更新方案总结

    如何评价腾讯在Unity下的xLua(开源)热更方案? Unity 游戏用XLua的HotFix实现热更原理揭秘 腾讯开源手游热更新方案,Unity3D下的Lua编程 [Unity]基于IL代码注入的 ...

  8. Unity官方发布热更新方案性能对照

    孙广东  2016.3.11 Unity应用的iOS热更新 作者:丁治宇 Unity TechnologiesChina Agenda •  什么是热更新 •  为何要热更新 •  怎样在iOS 上对 ...

  9. unity热更新方案对比

    Unity应用的iOS热更新 •  什么是热更新 •  为何要热更新 •  怎样在iOS 上对Unity 应用进行热更新 •  支持Unity iOS 热更新的各种Lua 插件的对照 什么是热更新 • ...

随机推荐

  1. dubbo 学习(一)

    1.dubbo(服务提供方)     ---->注册给  zookeeper 2.服务消费方通过访问zookeeper直接请求服务地址 3.zookeeper能够 1:现实环境中如果服务出现中断 ...

  2. hadoop是什么?新手自学hadoop教程【附】大数据系统学习教程

    Hadoop是一个由Apache基金会所开发的分布式系统基础架构. Hadoop是一个专为离线和大规模数据分析而设计的,并不适合那种对几个记录随机读写的在线事务处理模式. Hadoop=HDFS(文件 ...

  3. 集合中的 for-Each循环

     数组的加强型的for-Each循环很简单,我们再来看一下集合中的for-Each 循环又是怎么样的.我们都知道集合中的遍历都是通过迭代(iterator)完成的.也许有人说,也可以按照下面的方式来遍 ...

  4. gedit配置

    编辑 \(\rightarrow\) 首选项 \(\rightarrow\) 插件 \(\rightarrow\) 外部工具 启用 进入工具 \(\rightarrow\) Manage Extern ...

  5. Linux中/etc/passwd 和 /etc/shadows 详解

    linux操作系统上的用户如果需要登录主机,当其输入用户名和密码之后: 首先在/etc/passwd文件中查找是否有你的账号,如果没有无法登录,如果有的话将该用户的UID和GID读出来,此外将此用户的 ...

  6. 转 如何观察 undo Oracle DML语句回滚开销估算

    https://searchdatabase.techtarget.com.cn/7-20392/ --use_urec 详细解读: select USED_UREC from v$transacti ...

  7. airodump-ng 界面参数比较详细的解释

    BSSID: AP(access point)的MAC地址,,如果在client section中BSSID显示为"not associated" ,那么意味着该客户端没有和AP连 ...

  8. HDU 1029 一道微软面试题

    http://acm.hdu.edu.cn/showproblem.php?pid=1029 给定一个数组,其中有一个相同的数字是出现了大于等于(n + 1) / 2次的.要求找出来. 1.明显排序后 ...

  9. 使用Zeppelin时出现at org.apache.zeppelin.interpreter.thrift.RemoteInterpreterService$Client.recv_getFormType(RemoteInterpreterService.java:288)错误的解决办法(图文详解)

    不多说,直接上干货! 问题详解 org.apache.thrift.TApplicationException: Internal error processing getFormType at or ...

  10. 《javascript设计模式》笔记之第十章 和 第十一章:门面模式和适配器模式

    第十章:门面模式 一:门面模式的作用 简化已有的api,使其更加容易使用 解决浏览器的兼容问题 二:门面模式的本质 门面模式的本质就是包装已有的api来简化操作   三:门面模式的两个简单例子 下面这 ...