[英]How to load/unload images in HTML5/JavaScript
我正在使用HTML5和JavaScript创建游戏,并且将使用大量图像。 一次拥有所有这些图像会占用大量内存,而我想知道如何加载/卸载不同的图像,这样,玩游戏的人就不需要8GB的存储空间,也就不需要这些图像。
<img src = "source1" id = "img1"></img>
<img src = "source2" id = "img2"></img>
<img src = "source3" id = "img3"></img>
<!--Just imagine this for every image, which is likely going to peak over 10,000 at some point-->
<img src = "source10000" id = "img10000"></img>
<canvas width = "1350" height = "600" id = "canva"></canvas>
<script>
var canvas = document.getElementById("canva");
var can = canvas.getContext("2d");
var imge = function(im, x, y, w, h) {
can.drawImage(document.getElementById(im), x, y, w, h);
};
var playerX = 0;
var playerY = 0;
var run = function() {
imge("img1", playerX, playerY, 32, 32);
//Need to use tones of images
requestAnimationFrame(run);
};
run();
</script>
我不需要一次使用10,000张图像,更不需要一次使用60张图像(玩家动画,块,敌方动画,粒子等),而且由于我处于开发初期,因此我愿意重做一些事情,就像我抓图像一样。
问题:如何在HTML5 / JavaScrpit中加载/卸载图像
您可以控制在JavaScript中加载图片 。 但是,您似乎无法强制浏览器卸载图像。 只要您的代码中不再有对该图像的引用, 浏览器就会自行决定何时将其从内存中卸载 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.