1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
{
"uid": "D98F90F2K8EF9A42FDS925AE12EEBFB09029",
"isLoaded": true,
"lastModificationTime": 1426885735019,
"items": {
"name": "ResourceManager",
"type": "game_script",
"order": 4,
"content": "# ===================================================================\n#\n# Script: ResourceManager\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass ResourceManagerContext\n ###*\n * If associated to a gs.ResourceManager, a resource context registers all loaded resources\n * resources. If gs.ResourceManager needs to dispose resources, it will only dispose\n * resource associated if the current context.\n *\n * By default, each game scene creates it's own resource context to only dispose resources\n * created by itself.\n *\n * @module gs\n * @class ResourceManager\n * @memberof gs\n * @constructor\n ###\n constructor: -> \n ###*\n * All resources associated with this context.\n * @property resources\n * @type Object[]\n * @readOnly\n ###\n @resources = []\n \n \n ###*\n * Converts the resource context into a data-bundle for serialization. The data-bundle will only contain\n * the names of the resources associated with this context but not the resource-data itself.\n * @method toDataBundle\n * @return {string[]} An array of resource names associated with this context.\n ### \n toDataBundle: -> @resources.select (r) -> r.name\n \n ###*\n * Initializes the resource context from a data-bundle. Any already existing resource associations\n * with this context will be deleted.\n * @method fromDataBundle\n ###\n fromDataBundle: (data, resourcesByPath) -> @resources = data.select (n) -> name: n, data: resourcesByPath[n]\n \n ###*\n * Adds the specified resource to the context.\n * @method add\n * @param {string} name - A unique name for the resource like the file-path for example.\n * @param {gs.Bitmap|gs.AudioBuffer|gs.Video|gs.Live2DModel} data - The resource data like a gs.Bitmap object for example.\n ### \n add: (name, resource) -> @resources.push({ name: name, data: resource })\n \n ###*\n * Removes the resource with the specified name from the context.\n * @method remove\n * @param {string} name - The name of the resource to remove. For Example: The file name.\n ### \n remove: (name) -> @resources.remove(@resources.first((r) -> r.name == name))\n \ngs.ResourceManagerContext = ResourceManagerContext\n\nclass ResourceManager\n ###*\n * Manages the resources of the game like graphics, audio, fonts, etc. It\n * offers a lot of methods to easily access game resources and automatically\n * caches them. So if an image is requested a second time it will be taken\n * from the cache instead of loading it again.\n *\n * @module gs\n * @class ResourceManager\n * @memberof gs\n * @constructor\n ###\n constructor: ->\n ###*\n * Current resource context. All loaded resources will be associated with it. If current context\n * is set to <b>null</b>, the <b>systemContext</b> is used instead.\n * @property context\n * @type gs.ResourceManagerContext\n * @protected\n ###\n @context_ = null\n \n ###*\n * System resource context. All loaded system resources are associated with this context. Resources\n * which are associated with the system context are not disposed until the game ends.\n * @property context\n * @type gs.ResourceManagerContext\n ### \n @systemContext = @createContext()\n \n ###*\n * Holds in-memory created bitmaps.\n * @property customBitmapsByKey\n * @type Object\n * @protected\n ###\n @customBitmapsByKey = {}\n \n ###*\n * Caches resources by file path.\n * @property resourcesByPath\n * @type Object\n * @protected\n ###\n @resourcesByPath = {}\n \n ###*\n * Caches resources by file path and HUE.\n * @property resourcesByPath\n * @type Object\n * @protected\n ###\n @resourcesByPathHue = {}\n \n ###*\n * Stores all loaded resources.\n * @property resources\n * @type Object[]\n ###\n @resources = []\n \n ###*\n * Indicates if all requested resources are loaded.\n * @property resourcesLoaded\n * @type boolean\n ###\n @resourcesLoaded = true\n \n ###*\n * @property events\n * @type gs.EventEmitter\n ###\n @events = new gs.EventEmitter()\n \n ###*\n * Current resource context. All loaded resources will be associated with it. If current context\n * is set to <b>null</b>, the <b>systemContext</b> is used instead.\n * @property context\n * @type gs.ResourceManagerContext\n ###\n @accessors \"context\", \n set: (v) -> @context_ = v\n get: -> @context_ ? @systemContext\n \n ###*\n * Creates a new resource context. Use <b>context</b> to set the new created context\n * as current context.\n *\n * @method createContext\n ###\n createContext: -> new gs.ResourceManagerContext()\n \n ###*\n * Disposes all bitmap resources associated with the current context.\n *\n * @method disposeBitmaps\n ###\n disposeBitmaps: ->\n for resource in @context.resources\n if resource.data instanceof gs.Bitmap\n resource.data.dispose()\n @resources.remove(resource.data)\n if resource.name\n @resourcesByPath[resource.name] = null\n delete @resourcesByPath[resource.name]\n ###*\n * Disposes all video resources associated with the current context.\n *\n * @method disposeVideos\n ###\n disposeVideos: -> \n for resource in @context.resources\n if resource.data instanceof gs.Video\n resource.data.dispose()\n @resources.remove(resource.data)\n @resourcesByPath[resource.name] = null\n delete @resourcesByPath[resource.name]\n \n ###*\n * Disposes all audio resources associated with the current context.\n *\n * @method disposeAudio\n ### \n disposeAudio: ->\n AudioManager.dispose(@context)\n \n for resource in @context.resources\n if resource.data instanceof GS.AudioBuffer or resource instanceof GS.AudioBufferStream\n resource.data.dispose()\n @resources.remove(resource.data)\n @resourcesByPath[resource.name] = null\n delete @resourcesByPath[resource.name]\n \n ###*\n * Disposes all Live2D resources associated with the current context.\n *\n * @method disposeLive2D\n ###\n disposeLive2D: -> \n for resource in @context.resources\n if resource.data instanceof gs.Live2DModel\n resource.data.dispose()\n @resources.remove(resource.data)\n @resourcesByPath[resource.name] = null\n delete @resourcesByPath[resource.name]\n \n ###*\n * Disposes all resources.\n *\n * @method dispose\n ### \n dispose: -> \n @disposeBitmaps()\n @disposeVideos()\n @disposeAudio()\n @disposeLive2D()\n \n @context = @systemContext\n \n ###*\n * Loads all custom fonts in Graphics/Fonts folder.\n *\n * @method loadFonts\n ### \n loadFonts: ->\n resource = { loaded: no }\n @resources.push(resource)\n @resourcesByPath[\"Graphics/Fonts\"] = resource\n \n gs.Font.loadCustomFonts((error) =>\n @resourcesByPath[\"Graphics/Fonts\"].loaded = yes\n if error\n @resourcesByPath[\"Graphics/Fonts\"].error = yes\n )\n ###*\n * Gets a custom created bitmap by key.\n *\n * @method getCustomBitmap\n * @param {String} key - The key for the bitmap to get.\n * @return {gs.Bitmap} The bitmap or <b>null</b> if no bitmap exists for the specified key.\n ### \n getCustomBitmap: (key) ->\n return @customBitmapsByKey[key]\n \n ###*\n * Sets a custom created bitmap for a specified key.\n *\n * @method setCustomBitmap\n * @param {String} key - The key for the bitmap to set.\n * @param {gs.Bitmap} bitmap - The bitmap to set.\n ### \n setCustomBitmap: (key, bitmap) ->\n @customBitmapsByKey[key] = bitmap\n if not bitmap.loaded?\n @resources.push(bitmap)\n @resourcesLoaded = false\n \n ###*\n * Adds a custom created bitmap to the resource manager.\n *\n * @method addCustomBitmap\n * @param {gs.Bitmap} bitmap - The bitmap to add.\n ### \n addCustomBitmap: (bitmap) ->\n @context.resources.push(name: \"\", data: bitmap)\n\n ###*\n * Gets a Live2D model.\n *\n * @method getLive2DModel\n * @param {String} filePath - Path to the Live2D model file.\n * @return {gs.Live2DModel} The Live2D model or <b>null</b> if no model exists at the specified file path.\n ### \n getLive2DModel: (filePath) ->\n result = @resourcesByPath[filePath]\n \n if not result? or result.disposed\n profile = LanguageManager.profile\n result = new gs.Live2DModel(filePath, (if profile? and profile.items? then profile.items.code else null))\n @resourcesByPath[filePath] = result\n @resources.push(result)\n @resourcesLoaded = false\n @context.resources.push(name: filePath, data: result)\n \n return result\n \n ###*\n * Gets a font.\n *\n * @method getFont\n * @param {String} name - The name of the font to get.\n * @param {number} size - The size of the font to get.\n * @return {gs.Font} The font or <b>null</b> if no font with the specified name exists.\n ### \n getFont: (name, size) ->\n result = new Font(name, size)\n \n @resources.push(result)\n @resourcesLoaded = false\n \n return result\n \n ###*\n * Gets a video.\n *\n * @method getVideo\n * @param {String} filePath - Path to the video file.\n * @return {gs.Video} The video or <b>null</b> if no video exists at the specified file path.\n ### \n getVideo: (filePath) ->\n if filePath.endsWith(\"/\") then return null\n \n result = @resourcesByPath[filePath]\n \n if not result? or result.disposed\n profile = LanguageManager.profile\n result = new gs.Video(filePath, (if profile? and profile.items? then profile.items.code else null))\n @resourcesByPath[filePath] = result\n @resources.push(result)\n @resourcesLoaded = false\n @context.resources.push(name: filePath, data: result)\n \n return result\n \n ###*\n * Gets a bitmap.\n *\n * @method getBitmap\n * @param {String} filePath - Path to the bitmap file.\n * @param {number} hue - The bitmap's hue. The bitmap will be loaded and then recolored.\n * @return {gs.Bitmap} The bitmap or <b>null</b> if no bitmap exists at the specified file path.\n ### \n getBitmap: (filePath, hue) ->\n if filePath.endsWith(\"/\") then return null\n \n \n hue = hue || 0\n result = @resourcesByPath[filePath] || @customBitmapsByKey[filePath]\n \n if not result?\n profile = LanguageManager.profile\n result = new Bitmap(filePath, (if profile? and profile.items? then profile.items.code else null), no)\n result.hue = hue\n result.filePath = filePath\n @resourcesByPath[filePath] = result\n @resources.push(result)\n @resourcesLoaded = false\n @context.resources.push(name: filePath, data: result)\n else if not result.loaded and result.hue != hue\n profile = LanguageManager.profile\n result = new Bitmap(filePath, (if profile? and profile.items? then profile.items.code else null))\n result.hue = hue\n result.filePath = filePath\n @resources.push(result)\n @resourcesLoaded = false \n else if hue > 0\n hueBitmap = @resourcesByPathHue[filePath+\"@\"+hue]\n if not hueBitmap? and result.loaded\n hueBitmap = new Bitmap(result.image)\n hueBitmap.changeHue(hue)\n @resourcesByPathHue[filePath+\"@\"+hue] = hueBitmap\n if hueBitmap? then result = hueBitmap\n \n return result\n\n ###*\n * Gets an HTML image.\n *\n * @method getImage\n * @param {String} filePath - Path to the image file.\n * @return {HTMLImageElement} The image or <b>null</b> if no image exists at the specified file path.\n ### \n getImage: (filePath) ->\n result = @resourcesByPath[filePath]\n \n if not result?\n result = new Bitmap(\"resources/#{filePath}.png\");\n \n @resourcesByPath[filePath] = result\n @resources.push(result)\n @resourcesLoaded = false\n \n return result\n\n ###*\n * Gets an audio stream.\n *\n * @method getAudioStream\n * @param {String} filePath - Path to the audio file.\n * @return {gs.AudioBuffer} The audio buffer or <b>null</b> if no audio file exists at the specified file path.\n ### \n getAudioStream: (filePath) ->\n result = @resourcesByPath[filePath]\n profile = LanguageManager.profile\n languageCode = if profile? and profile.items? then profile.items.code else null\n \n if not result?\n result = new GS.AudioBuffer(filePath)\n \n @resourcesByPath[filePath] = result\n @resources.push(result)\n @resourcesLoaded = false\n \n @context.resources.push(name: filePath, data: result)\n \n \n \n return result\n \n ###*\n * Gets an audio buffer. The audio data is fully loaded and decoded in memory. It is recommeneded\n * for sound effects but for a long background music, <b>getAudioStream</b> should be used instead. That is especially\n * the case on mobile devices.\n *\n * @method getAudioBuffer\n * @param {String} filePath - Path to the audio file.\n * @return {gs.AudioBuffer} The audio buffer or <b>null</b> if no audio file exists at the specified file path.\n ### \n getAudioBuffer: (filePath) ->\n result = @resourcesByPath[filePath]\n profile = LanguageManager.profile\n languageCode = if profile? and profile.items? then profile.items.code else null\n \n if not result?\n result = new GS.AudioBuffer(filePath)\n \n @resourcesByPath[filePath] = result\n @resources.push(result)\n @resourcesLoaded = false\n \n @context.resources.push(name: filePath, data: result)\n \n return result\n\n ###*\n * Updates the loading process. Needs to be called once per frame to keep \n * the ResourceManager up to date.\n *\n * @method update\n ### \n update: ->\n if not @events? then @events = new gs.EventEmitter()\n if not @resourcesLoaded\n @resourcesLoaded = true\n for i in [0...@resources.length]\n if not @resources[i].loaded\n @resourcesLoaded = false\n break\n else if @resources[i].hue? and @resources[i].hue > 0\n bitmap = new Bitmap(@resources[i].image)\n \n @resourcesByPath[@resources[i].filePath] = bitmap\n @resources[i].changeHue(@resources[i].hue)\n @resourcesByPathHue[@resources[i].filePath+\"@\"+@resources[i].hue] = @resources[i]\n delete @resources[i].filePath\n delete @resources[i].hue\n if @resourcesLoaded\n @events.emit(\"loaded\", this)\n \n return null\n\nwindow.ResourceManager = ResourceManager\ngs.ResourceManager = ResourceManager",
"compiledContent": "var ResourceManager, ResourceManagerContext;\n\nResourceManagerContext = (function() {\n\n /**\n * If associated to a gs.ResourceManager, a resource context registers all loaded resources\n * resources. If gs.ResourceManager needs to dispose resources, it will only dispose\n * resource associated if the current context.\n *\n * By default, each game scene creates it's own resource context to only dispose resources\n * created by itself.\n *\n * @module gs\n * @class ResourceManager\n * @memberof gs\n * @constructor\n */\n function ResourceManagerContext() {\n\n /**\n * All resources associated with this context.\n * @property resources\n * @type Object[]\n * @readOnly\n */\n this.resources = [];\n }\n\n\n /**\n * Converts the resource context into a data-bundle for serialization. The data-bundle will only contain\n * the names of the resources associated with this context but not the resource-data itself.\n * @method toDataBundle\n * @return {string[]} An array of resource names associated with this context.\n */\n\n ResourceManagerContext.prototype.toDataBundle = function() {\n return this.resources.select(function(r) {\n return r.name;\n });\n };\n\n\n /**\n * Initializes the resource context from a data-bundle. Any already existing resource associations\n * with this context will be deleted.\n * @method fromDataBundle\n */\n\n ResourceManagerContext.prototype.fromDataBundle = function(data, resourcesByPath) {\n return this.resources = data.select(function(n) {\n return {\n name: n,\n data: resourcesByPath[n]\n };\n });\n };\n\n\n /**\n * Adds the specified resource to the context.\n * @method add\n * @param {string} name - A unique name for the resource like the file-path for example.\n * @param {gs.Bitmap|gs.AudioBuffer|gs.Video|gs.Live2DModel} data - The resource data like a gs.Bitmap object for example.\n */\n\n ResourceManagerContext.prototype.add = function(name, resource) {\n return this.resources.push({\n name: name,\n data: resource\n });\n };\n\n\n /**\n * Removes the resource with the specified name from the context.\n * @method remove\n * @param {string} name - The name of the resource to remove. For Example: The file name.\n */\n\n ResourceManagerContext.prototype.remove = function(name) {\n return this.resources.remove(this.resources.first(function(r) {\n return r.name === name;\n }));\n };\n\n return ResourceManagerContext;\n\n})();\n\ngs.ResourceManagerContext = ResourceManagerContext;\n\nResourceManager = (function() {\n\n /**\n * Manages the resources of the game like graphics, audio, fonts, etc. It\n * offers a lot of methods to easily access game resources and automatically\n * caches them. So if an image is requested a second time it will be taken\n * from the cache instead of loading it again.\n *\n * @module gs\n * @class ResourceManager\n * @memberof gs\n * @constructor\n */\n function ResourceManager() {\n\n /**\n * Current resource context. All loaded resources will be associated with it. If current context\n * is set to <b>null</b>, the <b>systemContext</b> is used instead.\n * @property context\n * @type gs.ResourceManagerContext\n * @protected\n */\n this.context_ = null;\n\n /**\n * System resource context. All loaded system resources are associated with this context. Resources\n * which are associated with the system context are not disposed until the game ends.\n * @property context\n * @type gs.ResourceManagerContext\n */\n this.systemContext = this.createContext();\n\n /**\n * Holds in-memory created bitmaps.\n * @property customBitmapsByKey\n * @type Object\n * @protected\n */\n this.customBitmapsByKey = {};\n\n /**\n * Caches resources by file path.\n * @property resourcesByPath\n * @type Object\n * @protected\n */\n this.resourcesByPath = {};\n\n /**\n * Caches resources by file path and HUE.\n * @property resourcesByPath\n * @type Object\n * @protected\n */\n this.resourcesByPathHue = {};\n\n /**\n * Stores all loaded resources.\n * @property resources\n * @type Object[]\n */\n this.resources = [];\n\n /**\n * Indicates if all requested resources are loaded.\n * @property resourcesLoaded\n * @type boolean\n */\n this.resourcesLoaded = true;\n\n /**\n * @property events\n * @type gs.EventEmitter\n */\n this.events = new gs.EventEmitter();\n }\n\n\n /**\n * Current resource context. All loaded resources will be associated with it. If current context\n * is set to <b>null</b>, the <b>systemContext</b> is used instead.\n * @property context\n * @type gs.ResourceManagerContext\n */\n\n ResourceManager.accessors(\"context\", {\n set: function(v) {\n return this.context_ = v;\n },\n get: function() {\n var ref;\n return (ref = this.context_) != null ? ref : this.systemContext;\n }\n });\n\n\n /**\n * Creates a new resource context. Use <b>context</b> to set the new created context\n * as current context.\n *\n * @method createContext\n */\n\n ResourceManager.prototype.createContext = function() {\n return new gs.ResourceManagerContext();\n };\n\n\n /**\n * Disposes all bitmap resources associated with the current context.\n *\n * @method disposeBitmaps\n */\n\n ResourceManager.prototype.disposeBitmaps = function() {\n var j, len, ref, resource, results;\n ref = this.context.resources;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n resource = ref[j];\n if (resource.data instanceof gs.Bitmap) {\n resource.data.dispose();\n this.resources.remove(resource.data);\n if (resource.name) {\n this.resourcesByPath[resource.name] = null;\n results.push(delete this.resourcesByPath[resource.name]);\n } else {\n results.push(void 0);\n }\n } else {\n results.push(void 0);\n }\n }\n return results;\n };\n\n\n /**\n * Disposes all video resources associated with the current context.\n *\n * @method disposeVideos\n */\n\n ResourceManager.prototype.disposeVideos = function() {\n var j, len, ref, resource, results;\n ref = this.context.resources;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n resource = ref[j];\n if (resource.data instanceof gs.Video) {\n resource.data.dispose();\n this.resources.remove(resource.data);\n this.resourcesByPath[resource.name] = null;\n results.push(delete this.resourcesByPath[resource.name]);\n } else {\n results.push(void 0);\n }\n }\n return results;\n };\n\n\n /**\n * Disposes all audio resources associated with the current context.\n *\n * @method disposeAudio\n */\n\n ResourceManager.prototype.disposeAudio = function() {\n var j, len, ref, resource, results;\n AudioManager.dispose(this.context);\n ref = this.context.resources;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n resource = ref[j];\n if (resource.data instanceof GS.AudioBuffer || resource instanceof GS.AudioBufferStream) {\n resource.data.dispose();\n this.resources.remove(resource.data);\n this.resourcesByPath[resource.name] = null;\n results.push(delete this.resourcesByPath[resource.name]);\n } else {\n results.push(void 0);\n }\n }\n return results;\n };\n\n\n /**\n * Disposes all Live2D resources associated with the current context.\n *\n * @method disposeLive2D\n */\n\n ResourceManager.prototype.disposeLive2D = function() {\n var j, len, ref, resource, results;\n ref = this.context.resources;\n results = [];\n for (j = 0, len = ref.length; j < len; j++) {\n resource = ref[j];\n if (resource.data instanceof gs.Live2DModel) {\n resource.data.dispose();\n this.resources.remove(resource.data);\n this.resourcesByPath[resource.name] = null;\n results.push(delete this.resourcesByPath[resource.name]);\n } else {\n results.push(void 0);\n }\n }\n return results;\n };\n\n\n /**\n * Disposes all resources.\n *\n * @method dispose\n */\n\n ResourceManager.prototype.dispose = function() {\n this.disposeBitmaps();\n this.disposeVideos();\n this.disposeAudio();\n this.disposeLive2D();\n return this.context = this.systemContext;\n };\n\n\n /**\n * Loads all custom fonts in Graphics/Fonts folder.\n *\n * @method loadFonts\n */\n\n ResourceManager.prototype.loadFonts = function() {\n var resource;\n resource = {\n loaded: false\n };\n this.resources.push(resource);\n this.resourcesByPath[\"Graphics/Fonts\"] = resource;\n return gs.Font.loadCustomFonts((function(_this) {\n return function(error) {\n _this.resourcesByPath[\"Graphics/Fonts\"].loaded = true;\n if (error) {\n return _this.resourcesByPath[\"Graphics/Fonts\"].error = true;\n }\n };\n })(this));\n };\n\n\n /**\n * Gets a custom created bitmap by key.\n *\n * @method getCustomBitmap\n * @param {String} key - The key for the bitmap to get.\n * @return {gs.Bitmap} The bitmap or <b>null</b> if no bitmap exists for the specified key.\n */\n\n ResourceManager.prototype.getCustomBitmap = function(key) {\n return this.customBitmapsByKey[key];\n };\n\n\n /**\n * Sets a custom created bitmap for a specified key.\n *\n * @method setCustomBitmap\n * @param {String} key - The key for the bitmap to set.\n * @param {gs.Bitmap} bitmap - The bitmap to set.\n */\n\n ResourceManager.prototype.setCustomBitmap = function(key, bitmap) {\n this.customBitmapsByKey[key] = bitmap;\n if (bitmap.loaded == null) {\n this.resources.push(bitmap);\n return this.resourcesLoaded = false;\n }\n };\n\n\n /**\n * Adds a custom created bitmap to the resource manager.\n *\n * @method addCustomBitmap\n * @param {gs.Bitmap} bitmap - The bitmap to add.\n */\n\n ResourceManager.prototype.addCustomBitmap = function(bitmap) {\n return this.context.resources.push({\n name: \"\",\n data: bitmap\n });\n };\n\n\n /**\n * Gets a Live2D model.\n *\n * @method getLive2DModel\n * @param {String} filePath - Path to the Live2D model file.\n * @return {gs.Live2DModel} The Live2D model or <b>null</b> if no model exists at the specified file path.\n */\n\n ResourceManager.prototype.getLive2DModel = function(filePath) {\n var profile, result;\n result = this.resourcesByPath[filePath];\n if ((result == null) || result.disposed) {\n profile = LanguageManager.profile;\n result = new gs.Live2DModel(filePath, ((profile != null) && (profile.items != null) ? profile.items.code : null));\n this.resourcesByPath[filePath] = result;\n this.resources.push(result);\n this.resourcesLoaded = false;\n this.context.resources.push({\n name: filePath,\n data: result\n });\n }\n return result;\n };\n\n\n /**\n * Gets a font.\n *\n * @method getFont\n * @param {String} name - The name of the font to get.\n * @param {number} size - The size of the font to get.\n * @return {gs.Font} The font or <b>null</b> if no font with the specified name exists.\n */\n\n ResourceManager.prototype.getFont = function(name, size) {\n var result;\n result = new Font(name, size);\n this.resources.push(result);\n this.resourcesLoaded = false;\n return result;\n };\n\n\n /**\n * Gets a video.\n *\n * @method getVideo\n * @param {String} filePath - Path to the video file.\n * @return {gs.Video} The video or <b>null</b> if no video exists at the specified file path.\n */\n\n ResourceManager.prototype.getVideo = function(filePath) {\n var profile, result;\n if (filePath.endsWith(\"/\")) {\n return null;\n }\n result = this.resourcesByPath[filePath];\n if ((result == null) || result.disposed) {\n profile = LanguageManager.profile;\n result = new gs.Video(filePath, ((profile != null) && (profile.items != null) ? profile.items.code : null));\n this.resourcesByPath[filePath] = result;\n this.resources.push(result);\n this.resourcesLoaded = false;\n this.context.resources.push({\n name: filePath,\n data: result\n });\n }\n return result;\n };\n\n\n /**\n * Gets a bitmap.\n *\n * @method getBitmap\n * @param {String} filePath - Path to the bitmap file.\n * @param {number} hue - The bitmap's hue. The bitmap will be loaded and then recolored.\n * @return {gs.Bitmap} The bitmap or <b>null</b> if no bitmap exists at the specified file path.\n */\n\n ResourceManager.prototype.getBitmap = function(filePath, hue) {\n var hueBitmap, profile, result;\n if (filePath.endsWith(\"/\")) {\n return null;\n }\n hue = hue || 0;\n result = this.resourcesByPath[filePath] || this.customBitmapsByKey[filePath];\n if (result == null) {\n profile = LanguageManager.profile;\n result = new Bitmap(filePath, ((profile != null) && (profile.items != null) ? profile.items.code : null), false);\n result.hue = hue;\n result.filePath = filePath;\n this.resourcesByPath[filePath] = result;\n this.resources.push(result);\n this.resourcesLoaded = false;\n this.context.resources.push({\n name: filePath,\n data: result\n });\n } else if (!result.loaded && result.hue !== hue) {\n profile = LanguageManager.profile;\n result = new Bitmap(filePath, ((profile != null) && (profile.items != null) ? profile.items.code : null));\n result.hue = hue;\n result.filePath = filePath;\n this.resources.push(result);\n this.resourcesLoaded = false;\n } else if (hue > 0) {\n hueBitmap = this.resourcesByPathHue[filePath + \"@\" + hue];\n if ((hueBitmap == null) && result.loaded) {\n hueBitmap = new Bitmap(result.image);\n hueBitmap.changeHue(hue);\n this.resourcesByPathHue[filePath + \"@\" + hue] = hueBitmap;\n }\n if (hueBitmap != null) {\n result = hueBitmap;\n }\n }\n return result;\n };\n\n\n /**\n * Gets an HTML image.\n *\n * @method getImage\n * @param {String} filePath - Path to the image file.\n * @return {HTMLImageElement} The image or <b>null</b> if no image exists at the specified file path.\n */\n\n ResourceManager.prototype.getImage = function(filePath) {\n var result;\n result = this.resourcesByPath[filePath];\n if (result == null) {\n result = new Bitmap(\"resources/\" + filePath + \".png\");\n this.resourcesByPath[filePath] = result;\n this.resources.push(result);\n this.resourcesLoaded = false;\n }\n return result;\n };\n\n\n /**\n * Gets an audio stream.\n *\n * @method getAudioStream\n * @param {String} filePath - Path to the audio file.\n * @return {gs.AudioBuffer} The audio buffer or <b>null</b> if no audio file exists at the specified file path.\n */\n\n ResourceManager.prototype.getAudioStream = function(filePath) {\n var languageCode, profile, result;\n result = this.resourcesByPath[filePath];\n profile = LanguageManager.profile;\n languageCode = (profile != null) && (profile.items != null) ? profile.items.code : null;\n if (result == null) {\n result = new GS.AudioBuffer(filePath);\n this.resourcesByPath[filePath] = result;\n this.resources.push(result);\n this.resourcesLoaded = false;\n this.context.resources.push({\n name: filePath,\n data: result\n });\n }\n return result;\n };\n\n\n /**\n * Gets an audio buffer. The audio data is fully loaded and decoded in memory. It is recommeneded\n * for sound effects but for a long background music, <b>getAudioStream</b> should be used instead. That is especially\n * the case on mobile devices.\n *\n * @method getAudioBuffer\n * @param {String} filePath - Path to the audio file.\n * @return {gs.AudioBuffer} The audio buffer or <b>null</b> if no audio file exists at the specified file path.\n */\n\n ResourceManager.prototype.getAudioBuffer = function(filePath) {\n var languageCode, profile, result;\n result = this.resourcesByPath[filePath];\n profile = LanguageManager.profile;\n languageCode = (profile != null) && (profile.items != null) ? profile.items.code : null;\n if (result == null) {\n result = new GS.AudioBuffer(filePath);\n this.resourcesByPath[filePath] = result;\n this.resources.push(result);\n this.resourcesLoaded = false;\n this.context.resources.push({\n name: filePath,\n data: result\n });\n }\n return result;\n };\n\n\n /**\n * Updates the loading process. Needs to be called once per frame to keep \n * the ResourceManager up to date.\n *\n * @method update\n */\n\n ResourceManager.prototype.update = function() {\n var bitmap, i, j, ref;\n if (this.events == null) {\n this.events = new gs.EventEmitter();\n }\n if (!this.resourcesLoaded) {\n this.resourcesLoaded = true;\n for (i = j = 0, ref = this.resources.length; 0 <= ref ? j < ref : j > ref; i = 0 <= ref ? ++j : --j) {\n if (!this.resources[i].loaded) {\n this.resourcesLoaded = false;\n break;\n } else if ((this.resources[i].hue != null) && this.resources[i].hue > 0) {\n bitmap = new Bitmap(this.resources[i].image);\n this.resourcesByPath[this.resources[i].filePath] = bitmap;\n this.resources[i].changeHue(this.resources[i].hue);\n this.resourcesByPathHue[this.resources[i].filePath + \"@\" + this.resources[i].hue] = this.resources[i];\n delete this.resources[i].filePath;\n delete this.resources[i].hue;\n }\n }\n if (this.resourcesLoaded) {\n this.events.emit(\"loaded\", this);\n }\n }\n return null;\n };\n\n return ResourceManager;\n\n})();\n\nwindow.ResourceManager = ResourceManager;\n\ngs.ResourceManager = ResourceManager;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: ResourceManager\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass ResourceManagerContext\n    ###*\n    * If associated to a gs.ResourceManager, a resource context registers all loaded resources\n    * resources. If gs.ResourceManager needs to dispose resources, it will only dispose\n    * resource associated if the current context.\n    *\n    * By default, each game scene creates it's own resource context to only dispose resources\n    * created by itself.\n    *\n    * @module gs\n    * @class ResourceManager\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: -> \n        ###*\n        * All resources associated with this context.\n        * @property resources\n        * @type Object[]\n        * @readOnly\n        ###\n        @resources = []\n    \n    \n    ###*\n    * Converts the resource context into a data-bundle for serialization. The data-bundle will only contain\n    * the names of the resources associated with this context but not the resource-data itself.\n    * @method toDataBundle\n    * @return {string[]} An array of resource names associated with this context.\n    ###  \n    toDataBundle: -> @resources.select (r) -> r.name\n    \n    ###*\n    * Initializes the resource context from a data-bundle. Any already existing resource associations\n    * with this context will be deleted.\n    * @method fromDataBundle\n    ###\n    fromDataBundle: (data, resourcesByPath) -> @resources = data.select (n) -> name: n, data: resourcesByPath[n]\n    \n    ###*\n    * Adds the specified resource to the context.\n    * @method add\n    * @param {string} name - A unique name for the resource like the file-path for example.\n    * @param {gs.Bitmap|gs.AudioBuffer|gs.Video|gs.Live2DModel} data - The resource data like a gs.Bitmap object for example.\n    ###   \n    add: (name, resource) -> @resources.push({ name: name, data: resource })\n    \n    ###*\n    * Removes the resource with the specified name from the context.\n    * @method remove\n    * @param {string} name - The name of the resource to remove. For Example: The file name.\n    ###  \n    remove: (name) -> @resources.remove(@resources.first((r) -> r.name == name))\n    \ngs.ResourceManagerContext = ResourceManagerContext\n\nclass ResourceManager\n    ###*\n    * Manages the resources of the game like graphics, audio, fonts, etc. It\n    * offers a lot of methods to easily access game resources and automatically\n    * caches them. So if an image is requested a second time it will be taken\n    * from the cache instead of loading it again.\n    *\n    * @module gs\n    * @class ResourceManager\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * Current resource context. All loaded resources will be associated with it. If current context\n        * is set to <b>null</b>, the <b>systemContext</b> is used instead.\n        * @property context\n        * @type gs.ResourceManagerContext\n        * @protected\n        ###\n        @context_ = null\n        \n        ###*\n        * System resource context. All loaded system resources are associated with this context. Resources\n        * which are associated with the system context are not disposed until the game ends.\n        * @property context\n        * @type gs.ResourceManagerContext\n        ###    \n        @systemContext = @createContext()\n            \n        ###*\n        * Holds in-memory created bitmaps.\n        * @property customBitmapsByKey\n        * @type Object\n        * @protected\n        ###\n        @customBitmapsByKey = {}\n        \n        ###*\n        * Caches resources by file path.\n        * @property resourcesByPath\n        * @type Object\n        * @protected\n        ###\n        @resourcesByPath = {}\n        \n        ###*\n        * Caches resources by file path and HUE.\n        * @property resourcesByPath\n        * @type Object\n        * @protected\n        ###\n        @resourcesByPathHue = {}\n        \n        ###*\n        * Stores all loaded resources.\n        * @property resources\n        * @type Object[]\n        ###\n        @resources = []\n        \n        ###*\n        * Indicates if all requested resources are loaded.\n        * @property resourcesLoaded\n        * @type boolean\n        ###\n        @resourcesLoaded = true\n        \n        ###*\n        * @property events\n        * @type gs.EventEmitter\n        ###\n        @events = new gs.EventEmitter()\n    \n    ###*\n    * Current resource context. All loaded resources will be associated with it. If current context\n    * is set to <b>null</b>, the <b>systemContext</b> is used instead.\n    * @property context\n    * @type gs.ResourceManagerContext\n    ###\n    @accessors \"context\", \n        set: (v) -> @context_ = v\n        get: -> @context_ ? @systemContext\n        \n    ###*\n    * Creates a new resource context. Use <b>context</b> to set the new created context\n    * as current context.\n    *\n    * @method createContext\n    ###\n    createContext: -> new gs.ResourceManagerContext()\n    \n    ###*\n    * Disposes all bitmap resources associated with the current context.\n    *\n    * @method disposeBitmaps\n    ###\n    disposeBitmaps: ->\n        for resource in @context.resources\n            if resource.data instanceof gs.Bitmap\n                resource.data.dispose()\n                @resources.remove(resource.data)\n                if resource.name\n                    @resourcesByPath[resource.name] = null\n                    delete @resourcesByPath[resource.name]\n    ###*\n    * Disposes all video resources associated with the current context.\n    *\n    * @method disposeVideos\n    ###\n    disposeVideos: ->            \n        for resource in @context.resources\n            if resource.data instanceof gs.Video\n                resource.data.dispose()\n                @resources.remove(resource.data)\n                @resourcesByPath[resource.name] = null\n                delete @resourcesByPath[resource.name]\n     \n    ###*\n    * Disposes all audio resources associated with the current context.\n    *\n    * @method disposeAudio\n    ###           \n    disposeAudio: ->\n        AudioManager.dispose(@context)\n        \n        for resource in @context.resources\n            if resource.data instanceof GS.AudioBuffer or resource instanceof GS.AudioBufferStream\n                resource.data.dispose()\n                @resources.remove(resource.data)\n                @resourcesByPath[resource.name] = null\n                delete @resourcesByPath[resource.name]\n                \n    ###*\n    * Disposes all Live2D resources associated with the current context.\n    *\n    * @method disposeLive2D\n    ###\n    disposeLive2D: ->            \n        for resource in @context.resources\n            if resource.data instanceof gs.Live2DModel\n                resource.data.dispose()\n                @resources.remove(resource.data)\n                @resourcesByPath[resource.name] = null\n                delete @resourcesByPath[resource.name]\n                \n    ###*\n    * Disposes all resources.\n    *\n    * @method dispose\n    ###        \n    dispose: -> \n        @disposeBitmaps()\n        @disposeVideos()\n        @disposeAudio()\n        @disposeLive2D()\n        \n        @context = @systemContext\n     \n    ###*\n    * Loads all custom fonts in Graphics/Fonts folder.\n    *\n    * @method loadFonts\n    ###       \n    loadFonts: ->\n        resource = { loaded: no }\n        @resources.push(resource)\n        @resourcesByPath[\"Graphics/Fonts\"] = resource\n        \n        gs.Font.loadCustomFonts((error) =>\n            @resourcesByPath[\"Graphics/Fonts\"].loaded = yes\n            if error\n                @resourcesByPath[\"Graphics/Fonts\"].error = yes\n        )\n    ###*\n    * Gets a custom created bitmap by key.\n    *\n    * @method getCustomBitmap\n    * @param {String} key - The key for the bitmap to get.\n    * @return {gs.Bitmap} The bitmap or <b>null</b> if no bitmap exists for the specified key.\n    ###     \n    getCustomBitmap: (key) ->\n        return @customBitmapsByKey[key]\n    \n    ###*\n    * Sets a custom created bitmap for a specified key.\n    *\n    * @method setCustomBitmap\n    * @param {String} key - The key for the bitmap to set.\n    * @param {gs.Bitmap} bitmap - The bitmap to set.\n    ### \n    setCustomBitmap: (key, bitmap) ->\n        @customBitmapsByKey[key] = bitmap\n        if not bitmap.loaded?\n            @resources.push(bitmap)\n            @resourcesLoaded = false\n    \n    ###*\n    * Adds a custom created bitmap to the resource manager.\n    *\n    * @method addCustomBitmap\n    * @param {gs.Bitmap} bitmap - The bitmap to add.\n    ###         \n    addCustomBitmap: (bitmap) ->\n        @context.resources.push(name: \"\", data: bitmap)\n\n    ###*\n    * Gets a Live2D model.\n    *\n    * @method getLive2DModel\n    * @param {String} filePath - Path to the Live2D model file.\n    * @return {gs.Live2DModel} The Live2D model or <b>null</b> if no model exists at the specified file path.\n    ###  \n    getLive2DModel: (filePath) ->\n        result = @resourcesByPath[filePath]\n        \n        if not result? or result.disposed\n            profile = LanguageManager.profile\n            result = new gs.Live2DModel(filePath, (if profile? and profile.items? then profile.items.code else null))\n            @resourcesByPath[filePath] = result\n            @resources.push(result)\n            @resourcesLoaded = false\n            @context.resources.push(name: filePath, data: result)\n          \n        return result\n    \n    ###*\n    * Gets a font.\n    *\n    * @method getFont\n    * @param {String} name - The name of the font to get.\n    * @param {number} size - The size of the font to get.\n    * @return {gs.Font} The font or <b>null</b> if no font with the specified name exists.\n    ###  \n    getFont: (name, size) ->\n        result = new Font(name, size)\n        \n        @resources.push(result)\n        @resourcesLoaded = false\n        \n        return result\n    \n    ###*\n    * Gets a video.\n    *\n    * @method getVideo\n    * @param {String} filePath - Path to the video file.\n    * @return {gs.Video} The video or <b>null</b> if no video exists at the specified file path.\n    ###   \n    getVideo: (filePath) ->\n        if filePath.endsWith(\"/\") then return null\n        \n        result = @resourcesByPath[filePath]\n        \n        if not result? or result.disposed\n            profile = LanguageManager.profile\n            result = new gs.Video(filePath, (if profile? and profile.items? then profile.items.code else null))\n            @resourcesByPath[filePath] = result\n            @resources.push(result)\n            @resourcesLoaded = false\n            @context.resources.push(name: filePath, data: result)\n          \n        return result\n    \n    ###*\n    * Gets a bitmap.\n    *\n    * @method getBitmap\n    * @param {String} filePath - Path to the bitmap file.\n    * @param {number} hue - The bitmap's hue. The bitmap will be loaded and then recolored.\n    * @return {gs.Bitmap} The bitmap or <b>null</b> if no bitmap exists at the specified file path.\n    ###   \n    getBitmap: (filePath, hue) ->\n        if filePath.endsWith(\"/\") then return null\n        \n        \n        hue = hue || 0\n        result = @resourcesByPath[filePath] || @customBitmapsByKey[filePath]\n        \n        if not result?\n            profile = LanguageManager.profile\n            result = new Bitmap(filePath, (if profile? and profile.items? then profile.items.code else null), no)\n            result.hue = hue\n            result.filePath = filePath\n            @resourcesByPath[filePath] = result\n            @resources.push(result)\n            @resourcesLoaded = false\n            @context.resources.push(name: filePath, data: result)\n        else if not result.loaded and result.hue != hue\n            profile = LanguageManager.profile\n            result = new Bitmap(filePath, (if profile? and profile.items? then profile.items.code else null))\n            result.hue = hue\n            result.filePath = filePath\n            @resources.push(result)\n            @resourcesLoaded = false  \n        else if hue > 0\n            hueBitmap = @resourcesByPathHue[filePath+\"@\"+hue]\n            if not hueBitmap? and result.loaded\n                hueBitmap = new Bitmap(result.image)\n                hueBitmap.changeHue(hue)\n                @resourcesByPathHue[filePath+\"@\"+hue] = hueBitmap\n            if hueBitmap? then result = hueBitmap\n          \n        return result\n\n    ###*\n    * Gets an HTML image.\n    *\n    * @method getImage\n    * @param {String} filePath - Path to the image file.\n    * @return {HTMLImageElement} The image or <b>null</b> if no image exists at the specified file path.\n    ###  \n    getImage: (filePath) ->\n        result = @resourcesByPath[filePath]\n        \n        if not result?\n            result = new Bitmap(\"resources/#{filePath}.png\");\n            \n            @resourcesByPath[filePath] = result\n            @resources.push(result)\n            @resourcesLoaded = false\n        \n        return result\n\n    ###*\n    * Gets an audio stream.\n    *\n    * @method getAudioStream\n    * @param {String} filePath - Path to the audio file.\n    * @return {gs.AudioBuffer} The audio buffer or <b>null</b> if no audio file exists at the specified file path.\n    ### \n    getAudioStream: (filePath) ->\n        result = @resourcesByPath[filePath]\n        profile = LanguageManager.profile\n        languageCode = if profile? and profile.items? then profile.items.code else null\n        \n        if not result?\n            result = new GS.AudioBuffer(filePath)\n            \n            @resourcesByPath[filePath] = result\n            @resources.push(result)\n            @resourcesLoaded = false\n            \n            @context.resources.push(name: filePath, data: result)\n        \n        \n        \n        return result\n        \n    ###*\n    * Gets an audio buffer. The audio data is fully loaded and decoded in memory. It is recommeneded\n    * for sound effects but for a long background music, <b>getAudioStream</b> should be used instead. That is especially\n    * the case on mobile devices.\n    *\n    * @method getAudioBuffer\n    * @param {String} filePath - Path to the audio file.\n    * @return {gs.AudioBuffer} The audio buffer or <b>null</b> if no audio file exists at the specified file path.\n    ### \n    getAudioBuffer: (filePath) ->\n        result = @resourcesByPath[filePath]\n        profile = LanguageManager.profile\n        languageCode = if profile? and profile.items? then profile.items.code else null\n        \n        if not result?\n            result = new GS.AudioBuffer(filePath)\n            \n            @resourcesByPath[filePath] = result\n            @resources.push(result)\n            @resourcesLoaded = false\n        \n            @context.resources.push(name: filePath, data: result)\n        \n        return result\n\n    ###*\n    * Updates the loading process. Needs to be called once per frame to keep \n    * the ResourceManager up to date.\n    *\n    * @method update\n    ###  \n    update: ->\n        if not @events? then @events = new gs.EventEmitter()\n        if not @resourcesLoaded\n            @resourcesLoaded = true\n            for i in [0...@resources.length]\n                if not @resources[i].loaded\n                    @resourcesLoaded = false\n                    break\n                else if @resources[i].hue? and @resources[i].hue > 0\n                    bitmap = new Bitmap(@resources[i].image)\n                  \n                    @resourcesByPath[@resources[i].filePath] = bitmap\n                    @resources[i].changeHue(@resources[i].hue)\n                    @resourcesByPathHue[@resources[i].filePath+\"@\"+@resources[i].hue] = @resources[i]\n                    delete @resources[i].filePath\n                    delete @resources[i].hue\n            if @resourcesLoaded\n                @events.emit(\"loaded\", this)\n        \n        return null\n\nwindow.ResourceManager = ResourceManager\ngs.ResourceManager = ResourceManager"]}\n//# sourceURL=ResourceManager_58.js",
"parentId": "C0268943K60B3A42B7SA6F1EDDCF2F642FD7"
},
"summary": [
"name",
"type",
"order"
]
}
|