-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathimage_loader.js.html
More file actions
129 lines (107 loc) · 4.6 KB
/
image_loader.js.html
File metadata and controls
129 lines (107 loc) · 4.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>JSDoc: Source: image_loader.js</title>
<script src="scripts/prettify/prettify.js"> </script>
<script src="scripts/prettify/lang-css.js"> </script>
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
</head>
<body>
<div id="main">
<h1 class="page-title">Source: image_loader.js</h1>
<section>
<article>
<pre class="prettyprint source linenums"><code>"use strict";
/**
* Loads {@link external:image}s and lets you know when they're all available. An instance of ImageLoader is available as {@link Splat.Game#images}.
* @constructor
*/
function ImageLoader() {
/**
* The key-value object that stores named {@link external:image}s
* @member {object}
* @private
*/
this.images = {};
/**
* The total number of images to be loaded.
* @member {number}
* @private
*/
this.totalImages = 0;
/**
* The number of images that have loaded completely.
* @member {number}
* @private
*/
this.loadedImages = 0;
/**
* The names of all the images that were requested to be loaded.
* @member {Array}
* @private
*/
this.names = [];
}
/**
* Load an {@link external:image}.
* @param {string} name The name you want to use when you {@link ImageLoader#get} the {@link external:image}
* @param {string} path The path of the {@link external:image}.
*/
ImageLoader.prototype.load = function(name, path) {
// only load an image once
if (this.names.indexOf(name) > -1) {
return;
}
this.names.push(name);
this.totalImages++;
var img = new Image();
var self = this;
img.addEventListener("load", function() {
self.loadedImages++;
self.images[name] = img;
});
img.addEventListener("error", function() {
console.error("Error loading image " + path);
});
img.src = path;
};
/**
* Test if all {@link external:image}s have loaded.
* @returns {boolean}
*/
ImageLoader.prototype.allLoaded = function() {
return this.totalImages === this.loadedImages;
};
/**
* Retrieve a loaded {@link external:image}.
* @param {string} name The name given to the image during {@link ImageLoader#load}.
* @returns {external:image}
*/
ImageLoader.prototype.get = function(name) {
var img = this.images[name];
if (img === undefined) {
console.error("Unknown image: " + name);
}
return img;
};
module.exports = ImageLoader;
</code></pre>
</article>
</section>
</div>
<nav>
<h2><a href="index.html">Home</a></h2><h3>Modules</h3><ul><li><a href="module-buffer.html">buffer</a></li><li><a href="module-KeyMap.html">KeyMap</a></li></ul><h3>Externals</h3><ul><li><a href="external-AudioContext.html">AudioContext</a></li><li><a href="external-canvas.html">canvas</a></li><li><a href="external-CanvasRenderingContext2D.html">CanvasRenderingContext2D</a></li><li><a href="external-image.html">image</a></li></ul><h3>Classes</h3><ul><li><a href="Accelerometer.html">Accelerometer</a></li><li><a href="Animation.html">Animation</a></li><li><a href="AnimationLoader.html">AnimationLoader</a></li><li><a href="FontLoader.html">FontLoader</a></li><li><a href="ImageLoader.html">ImageLoader</a></li><li><a href="Keyboard.html">Keyboard</a></li><li><a href="Mouse.html">Mouse</a></li><li><a href="SceneManager.html">SceneManager</a></li><li><a href="SoundLoader.html">SoundLoader</a></li><li><a href="Splat.AnimatedEntity.html">AnimatedEntity</a></li><li><a href="Splat.AStar.html">AStar</a></li><li><a href="Splat.BinaryHeap.html">BinaryHeap</a></li><li><a href="Splat.Camera.html">Camera</a></li><li><a href="Splat.Entity.html">Entity</a></li><li><a href="Splat.EntityBoxCamera.html">EntityBoxCamera</a></li><li><a href="Splat.Game.html">Game</a></li><li><a href="Splat.math.Random.html">Random</a></li><li><a href="Splat.NinePatch.html">NinePatch</a></li><li><a href="Splat.Scene.html">Scene</a></li><li><a href="Splat.Timer.html">Timer</a></li></ul><h3>Namespaces</h3><ul><li><a href="Splat.html">Splat</a></li><li><a href="Splat.ads.html">ads</a></li><li><a href="Splat.leaderboards.html">leaderboards</a></li><li><a href="Splat.math.html">math</a></li><li><a href="Splat.saveData.html">saveData</a></li></ul><h3><a href="global.html">Global</a></h3>
</nav>
<br class="clear">
<footer>
Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.3.2</a> on Thu Sep 17 2015 23:22:42 GMT-0400 (EDT)
</footer>
<script> prettyPrint(); </script>
<script src="scripts/linenumber.js"> </script>
</body>
</html>