This repository has been archived by the owner on Jul 5, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
112 lines (95 loc) · 3.33 KB
/
index.html
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
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="format-detection" content="telephone=no" />
<meta name="msapplication-tap-highlight" content="no" />
<meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width, height=device-height, target-densitydpi=device-dpi" />
<title>OGX StarEngine JS Demo</title>
<!--adjust paths as needed here-->
<script type="text/javascript" src="js/lib/jquery/jquery-3.3.1.min.js"></script>
<script type="text/javascript" src="js/lib/pixijs/v4/pixi.min.js"></script>
<script type="text/javascript" src="js/bin/ES6/class.Tile.js"></script>
<script type="text/javascript" src="js/bin/ES6/class.Camera.js"></script>
<script type="text/javascript" src="js/bin/ES6/class.Map.js"></script>
<script type="text/javascript" src="js/bin/ES6/class.MapConverter.js"></script>
<script type="text/javascript" src="js/bin/ES6/class.Engine.js"></script>
<script type="text/javascript">
$(document).ready(function(e) {
$(document).on(OGX.StarEngine.Engine.TEXTURES_LOADED, function(){
$(document).off(OGX.StarEngine.Engine.TEXTURES_LOADED);
loadMap('map.txt', onMapLoaded);
});
let config = {container:'canvas', tileSize:77, zoom:1, levels:3, level:0, layer:'tiles', width:840, height:420, textures:['img/sprites_json/level0', 'img/sprites_json/level1', 'img/sprites_json/level2']};
let TileEngine = new OGX.StarEngine.Engine(config);
let mapConverter = new OGX.StarEngine.MapConverter();
let map;
let camera = new OGX.StarEngine.Camera({name:'cam', x:1540+39, y:3080+39, viz:{x:14, y:14}});
let dir = {x:0, y:0}
let speed = 36;
function loadMap(__file, __cb){
let d = new Date();
$('#load').load('maps/'+__file+'?v='+d.getTime(), function(__data){
$('#load').empty();
__cb(__data);
});
}
function onMapLoaded(__data){
map = mapConverter.convertMap('map', __data);
TileEngine.setMap(map);
TileEngine.setCamera(camera);
setTimeout(start, 1000);
}
function start(){
TileEngine.renderView();
TileEngine.start();
let intv = setInterval(move, 10);
$(window).on('keydown', function(__e){
switch(__e.keyCode){
case 40:
dir.y = 1;
break;
case 38:
dir.y = -1;
break;
case 37:
dir.x = -1;
break;
case 39:
dir.x = 1;
break;
}
});
$(window).on('keyup', function(__e){
switch(__e.keyCode){
case 40:
dir.y = 0;
break;
case 38:
dir.y = 0;
break;
case 37:
dir.x = 0;
break;
case 39:
dir.x = 0;
break;
}
});
}
function move(){
let s = speed;
if(dir.x && dir.y){
s /= 2;
}
camera.x += s*dir.x;
camera.y += s*dir.y;
}
});
</script>
</head>
<body>
<div id="canvas" style="width:840px; height:420px; border:solid 1px #CCC;"></div>
<div id="load" style="display:none;"></div>
</body>
</html>