2013-02-22 11:04:09 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2013 cocos2d-x.org
|
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __AssetsManager__
|
|
|
|
#define __AssetsManager__
|
|
|
|
|
|
|
|
#include <string>
|
2013-08-07 13:07:01 +08:00
|
|
|
|
2013-06-24 13:59:41 +08:00
|
|
|
#include <mutex>
|
2013-02-22 11:04:09 +08:00
|
|
|
|
2013-02-26 16:29:52 +08:00
|
|
|
#include "cocos2d.h"
|
2013-10-16 16:48:39 +08:00
|
|
|
#include "extensions/ExtensionMacros.h"
|
2013-02-26 16:43:46 +08:00
|
|
|
|
|
|
|
NS_CC_EXT_BEGIN
|
2013-02-22 11:04:09 +08:00
|
|
|
|
2013-05-15 17:09:28 +08:00
|
|
|
class AssetsManagerDelegateProtocol;
|
|
|
|
|
|
|
|
/*
|
2013-02-22 11:04:09 +08:00
|
|
|
* This class is used to auto update resources, such as pictures or scripts.
|
|
|
|
* The updated package should be a zip file. And there should be a file named
|
|
|
|
* version in the server, which contains version code.
|
|
|
|
*/
|
2013-08-07 13:07:01 +08:00
|
|
|
class AssetsManager : public Node
|
2013-02-22 11:04:09 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-07-26 12:08:18 +08:00
|
|
|
enum class ErrorCode
|
2013-02-22 11:04:09 +08:00
|
|
|
{
|
2013-05-15 17:09:28 +08:00
|
|
|
// Error caused by creating a file to store downloaded data
|
2013-07-26 12:08:18 +08:00
|
|
|
CREATE_FILE,
|
2013-05-15 17:09:28 +08:00
|
|
|
/** Error caused by network
|
|
|
|
-- network unavaivable
|
|
|
|
-- timeout
|
|
|
|
-- ...
|
|
|
|
*/
|
2013-07-26 12:08:18 +08:00
|
|
|
NETWORK,
|
2013-05-15 17:09:28 +08:00
|
|
|
/** There is not a new version
|
|
|
|
*/
|
2013-07-26 12:08:18 +08:00
|
|
|
NO_NEW_VERSION,
|
2013-05-15 17:09:28 +08:00
|
|
|
/** Error caused in uncompressing stage
|
|
|
|
-- can not open zip file
|
|
|
|
-- can not read file global information
|
|
|
|
-- can not read file information
|
|
|
|
-- can not create a directory
|
|
|
|
-- ...
|
|
|
|
*/
|
2013-07-26 12:08:18 +08:00
|
|
|
UNCOMPRESS,
|
2013-02-22 11:04:09 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/* @brief Creates a AssetsManager with new package url, version code url and storage path.
|
|
|
|
*
|
|
|
|
* @param packageUrl URL of new package, the package should be a zip file.
|
|
|
|
* @param versionFileUrl URL of version file. It should contain version code of new package.
|
|
|
|
* @param storagePath The path to store downloaded resources.
|
2013-09-13 16:46:31 +08:00
|
|
|
* @js NA
|
2013-02-22 11:04:09 +08:00
|
|
|
*/
|
2013-05-15 17:09:28 +08:00
|
|
|
AssetsManager(const char* packageUrl = NULL, const char* versionFileUrl = NULL, const char* storagePath = NULL);
|
2013-09-13 11:41:20 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2013-05-15 17:09:28 +08:00
|
|
|
virtual ~AssetsManager();
|
2013-02-22 11:04:09 +08:00
|
|
|
|
2013-08-07 13:07:01 +08:00
|
|
|
typedef std::function<void(int)> ErrorCallback;
|
|
|
|
typedef std::function<void(int)> ProgressCallback;
|
|
|
|
typedef std::function<void(void)> SuccessCallback;
|
|
|
|
|
|
|
|
/* @brief To access within scripting environment
|
|
|
|
*/
|
|
|
|
static AssetsManager* create(const char* packageUrl, const char* versionFileUrl, const char* storagePath, ErrorCallback errorCallback, ProgressCallback progressCallback, SuccessCallback successCallback );
|
|
|
|
|
2013-02-22 11:04:09 +08:00
|
|
|
/* @brief Check out if there is a new version resource.
|
|
|
|
* You may use this method before updating, then let user determine whether
|
|
|
|
* he wants to update resources.
|
|
|
|
*/
|
|
|
|
virtual bool checkUpdate();
|
|
|
|
|
2013-02-22 16:02:53 +08:00
|
|
|
/* @brief Download new package if there is a new version, and uncompress downloaded zip file.
|
|
|
|
* Ofcourse it will set search path that stores downloaded files.
|
|
|
|
*/
|
2013-11-11 12:49:38 +08:00
|
|
|
virtual void update(float delta) override;
|
2013-02-22 11:04:09 +08:00
|
|
|
|
|
|
|
/* @brief Gets url of package.
|
|
|
|
*/
|
|
|
|
const char* getPackageUrl() const;
|
|
|
|
|
2013-02-22 16:02:53 +08:00
|
|
|
/* @brief Sets package url.
|
2013-02-22 11:04:09 +08:00
|
|
|
*/
|
|
|
|
void setPackageUrl(const char* packageUrl);
|
|
|
|
|
2013-02-22 16:02:53 +08:00
|
|
|
/* @brief Gets version file url.
|
|
|
|
*/
|
2013-02-22 11:04:09 +08:00
|
|
|
const char* getVersionFileUrl() const;
|
2013-02-22 16:02:53 +08:00
|
|
|
|
|
|
|
/* @brief Gets version file url.
|
|
|
|
*/
|
2013-02-22 11:04:09 +08:00
|
|
|
void setVersionFileUrl(const char* versionFileUrl);
|
|
|
|
|
2013-02-22 16:02:53 +08:00
|
|
|
/* @brief Gets current version code.
|
|
|
|
*/
|
|
|
|
std::string getVersion();
|
|
|
|
|
|
|
|
/* @brief Deletes recorded version code.
|
|
|
|
*/
|
|
|
|
void deleteVersion();
|
|
|
|
|
2013-02-22 11:04:09 +08:00
|
|
|
/* @brief Gets storage path.
|
|
|
|
*/
|
|
|
|
const char* getStoragePath() const;
|
|
|
|
|
|
|
|
/* @brief Sets storage path.
|
|
|
|
*
|
|
|
|
* @param storagePath The path to store downloaded resources.
|
2013-02-22 16:02:53 +08:00
|
|
|
* @warm The path should be a valid path.
|
2013-02-22 11:04:09 +08:00
|
|
|
*/
|
|
|
|
void setStoragePath(const char* storagePath);
|
|
|
|
|
2013-05-15 17:09:28 +08:00
|
|
|
/** @brief Sets delegate, the delegate will receive messages
|
2013-09-13 11:41:20 +08:00
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
2013-05-15 17:09:28 +08:00
|
|
|
*/
|
|
|
|
void setDelegate(AssetsManagerDelegateProtocol *delegate);
|
|
|
|
|
2013-10-22 16:14:49 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2013-11-04 14:43:22 +08:00
|
|
|
AssetsManagerDelegateProtocol* getDelegate() const { return _delegate ;}
|
2013-10-22 16:14:49 +08:00
|
|
|
|
2013-05-15 17:09:28 +08:00
|
|
|
/** @brief Sets connection time out in seconds
|
|
|
|
*/
|
|
|
|
void setConnectionTimeout(unsigned int timeout);
|
|
|
|
|
|
|
|
/** @brief Gets connection time out in secondes
|
|
|
|
*/
|
|
|
|
unsigned int getConnectionTimeout();
|
|
|
|
|
|
|
|
/* downloadAndUncompress is the entry of a new thread
|
|
|
|
*/
|
|
|
|
friend int assetsManagerProgressFunc(void *, double, double, double, double);
|
2013-08-07 13:36:26 +08:00
|
|
|
|
2013-02-22 11:04:09 +08:00
|
|
|
protected:
|
|
|
|
bool downLoad();
|
|
|
|
void checkStoragePath();
|
|
|
|
bool uncompress();
|
|
|
|
bool createDirectory(const char *path);
|
|
|
|
void setSearchPath();
|
2013-05-15 17:09:28 +08:00
|
|
|
void sendErrorMessage(ErrorCode code);
|
2013-06-24 13:59:41 +08:00
|
|
|
void downloadAndUncompress();
|
2013-05-15 17:09:28 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
typedef struct _Message
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
_Message() : what(0), obj(NULL){}
|
|
|
|
unsigned int what; // message type
|
|
|
|
void* obj;
|
|
|
|
} Message;
|
|
|
|
|
2013-06-20 14:15:53 +08:00
|
|
|
class Helper : public cocos2d::Object
|
2013-05-15 17:09:28 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-09-13 16:46:31 +08:00
|
|
|
/**
|
|
|
|
* @js ctor
|
|
|
|
*/
|
2013-05-15 17:09:28 +08:00
|
|
|
Helper();
|
2013-09-13 11:41:20 +08:00
|
|
|
/**
|
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
|
|
|
*/
|
2013-05-15 17:09:28 +08:00
|
|
|
~Helper();
|
|
|
|
|
|
|
|
virtual void update(float dt);
|
|
|
|
void sendMessage(Message *msg);
|
|
|
|
|
|
|
|
private:
|
|
|
|
void handleUpdateSucceed(Message *msg);
|
|
|
|
|
|
|
|
std::list<Message*> *_messageQueue;
|
2013-06-24 13:59:41 +08:00
|
|
|
std::mutex _messageQueueMutex;
|
2013-05-15 17:09:28 +08:00
|
|
|
};
|
2013-08-07 13:07:01 +08:00
|
|
|
|
2013-09-06 15:10:11 +08:00
|
|
|
private:
|
|
|
|
/** @brief Initializes storage path.
|
|
|
|
*/
|
|
|
|
void createStoragePath();
|
|
|
|
|
|
|
|
/** @brief Destroys storage path.
|
|
|
|
*/
|
|
|
|
void destroyStoragePath();
|
2013-02-22 11:04:09 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
//! The path to store downloaded resources.
|
|
|
|
std::string _storagePath;
|
|
|
|
|
|
|
|
//! The version of downloaded resources.
|
|
|
|
std::string _version;
|
|
|
|
|
|
|
|
std::string _packageUrl;
|
|
|
|
std::string _versionFileUrl;
|
|
|
|
|
2013-05-15 17:09:28 +08:00
|
|
|
std::string _downloadedVersion;
|
|
|
|
|
2013-08-07 13:07:01 +08:00
|
|
|
void *_curl;
|
|
|
|
|
2013-05-15 17:09:28 +08:00
|
|
|
Helper *_schedule;
|
|
|
|
unsigned int _connectionTimeout;
|
|
|
|
|
2013-08-07 13:07:01 +08:00
|
|
|
AssetsManagerDelegateProtocol *_delegate;
|
2013-06-24 13:59:41 +08:00
|
|
|
|
|
|
|
bool _isDownloading;
|
2013-08-08 17:36:56 +08:00
|
|
|
bool _shouldDeleteDelegateWhenExit;
|
2013-08-08 16:29:29 +08:00
|
|
|
|
2013-08-09 13:39:40 +08:00
|
|
|
std::string keyOfVersion() const;
|
|
|
|
std::string keyOfDownloadedVersion() const;
|
2013-05-15 17:09:28 +08:00
|
|
|
};
|
|
|
|
|
2013-08-08 17:36:56 +08:00
|
|
|
class AssetsManagerDelegateProtocol
|
2013-05-15 17:09:28 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/* @brief Call back function for error
|
|
|
|
@param errorCode Type of error
|
2013-09-13 11:41:20 +08:00
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
2013-05-15 17:09:28 +08:00
|
|
|
*/
|
|
|
|
virtual void onError(AssetsManager::ErrorCode errorCode) {};
|
|
|
|
/** @brief Call back function for recording downloading percent
|
|
|
|
@param percent How much percent downloaded
|
2013-08-01 17:47:37 +08:00
|
|
|
@warning This call back function just for recording downloading percent.
|
2013-05-15 17:09:28 +08:00
|
|
|
AssetsManager will do some other thing after downloading, you should
|
|
|
|
write code in onSuccess() after downloading.
|
2013-09-13 11:41:20 +08:00
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
2013-05-15 17:09:28 +08:00
|
|
|
*/
|
|
|
|
virtual void onProgress(int percent) {};
|
|
|
|
/** @brief Call back function for success
|
2013-09-13 11:41:20 +08:00
|
|
|
* @js NA
|
|
|
|
* @lua NA
|
2013-05-15 17:09:28 +08:00
|
|
|
*/
|
|
|
|
virtual void onSuccess() {};
|
2013-02-22 11:04:09 +08:00
|
|
|
};
|
|
|
|
|
2013-07-25 10:33:19 +08:00
|
|
|
// Deprecated declaration
|
|
|
|
CC_DEPRECATED_ATTRIBUTE typedef AssetsManager CCAssetsManager;
|
|
|
|
CC_DEPRECATED_ATTRIBUTE typedef AssetsManagerDelegateProtocol CCAssetsManagerDelegateProtocol;
|
|
|
|
|
2013-02-26 16:43:46 +08:00
|
|
|
NS_CC_EXT_END;
|
|
|
|
|
2013-02-22 11:04:09 +08:00
|
|
|
#endif /* defined(__AssetsManager__) */
|