(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. 如何使用Node.js搭建一个服务器

    在node环境中运行下面的代码 "use strict"; const http = require("http"), path = require(" ...

  2. Python学习笔记(字典)

    今天学习一个python中的基本类型--字典(dictionary) 字典这种数据结构有点像我们平常用的通讯录,有一个名字和这个名字对应的信息.在字典中,名字叫做“键”,对应的内容信息叫做“值”.字典 ...

  3. 关于setTimeout(fn,0)

    JS是单线程引擎:它把任务放到队列中,不会同步去执行,必须在完成一个任务后才开始另外一个任务. 浏览器的内核是多线程的,它们在内核制控下相互配合以保持同步,一个浏览器至少实现三个常驻线程:javasc ...

  4. python 定位

    #字符串定位 使用str.find() 其结果为如下: #列表中元素的定位 使用list.index() 其结果如下:

  5. oracle rownum(转)

    对于Oracle的rownum问题,很多资料都说不支持>,>=,=,between……and,只能用以上符号(<.& lt;=.!=),并非说用>,>=,=,be ...

  6. python所有的魔术方法

    据说,Python 的对象天生拥有一些神奇的方法,它们总被双下划线所包围,他们是面向对象的 Python 的一切. 他们是可以给你的类增加魔力的特殊方法,如果你的对象实现(重载)了这些方法中的某一个, ...

  7. 【手撸一个ORM】第二步、封装实体描述和实体属性描述

    一.实体属性描述 [MyProperty.cs] Name,属性名称 PropertyInfo,反射获取的属性信息,后面很多地方需要通过该属性获取对应的实体类型,或调用SetValue进行赋值 Fie ...

  8. 一文读懂DDD

    何为DDD DDD不是架构设计方法,不能把每个设计细节具象化,DDD是一套体系,决定了其开放性,体系中可以用任何一种方法来解决这些问题,但是如果一些关键问题没有具体方案落地,可能让团队无所适从. 有的 ...

  9. 自定义Spring Security的身份验证失败处理

    1.概述 在本快速教程中,我们将演示如何在Spring Boot应用程序中自定义Spring Security的身份验证失败处理.目标是使用表单登录方法对用户进行身份验证. 2.认证和授权(Authe ...

  10. storm中的topology-worker-executor-task

    调度角色 调度方法 自定义调度 1 调度角色   任务角色结构 上图是JStorm中一个topology对应的任务执行结构,其中worker是进程,executor对应于线程,task对应着spout ...