* Code Refactoring
* Bug Fixes in Map rendering
This commit is contained in:
39
config.wren
Normal file
39
config.wren
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
import "graphics" for Canvas
|
||||||
|
import "dome" for Window
|
||||||
|
class Config {
|
||||||
|
construct new() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static KeyboardConstants {
|
||||||
|
return {
|
||||||
|
"UP": "up",
|
||||||
|
"DOWN": "down",
|
||||||
|
"LEFT": "left",
|
||||||
|
"RIGHT": "right",
|
||||||
|
"PICK" : "c",
|
||||||
|
"SELECT": "z",
|
||||||
|
"ATTACK": "x",
|
||||||
|
"QUIT": "escape"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static setup() {
|
||||||
|
Window.resize(800, 600)
|
||||||
|
Canvas.resize(800, 600)
|
||||||
|
Window.title = "REBIRTH"
|
||||||
|
}
|
||||||
|
|
||||||
|
// static KeyboardConstants() {
|
||||||
|
// return {
|
||||||
|
// "UP": "up",
|
||||||
|
// "DOWN": "down",
|
||||||
|
// "LEFT": "left",
|
||||||
|
// "RIGHT": "right",
|
||||||
|
// "PICK" : "c",
|
||||||
|
// "SELECT": "z",
|
||||||
|
// "ATTACK": "x",
|
||||||
|
// "QUIT": "esc"
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
}
|
||||||
11
controls.wren
Normal file
11
controls.wren
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
import "input" for Keyboard
|
||||||
|
|
||||||
|
class Controls {
|
||||||
|
construct new() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static detect(keyCode) {
|
||||||
|
return Keyboard.isKeyDown(keyCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
62
level.wren
Normal file
62
level.wren
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
import "json" for Json
|
||||||
|
import "graphics" for ImageData
|
||||||
|
import "math" for Math
|
||||||
|
import "./layer_type" for LayerType
|
||||||
|
|
||||||
|
class Level {
|
||||||
|
construct new(levelName) {
|
||||||
|
_levelData = Json.load("assets/%(levelName).json")
|
||||||
|
var tileSheetData = _levelData["tilesets"][0] // Assuming I only use single tilesheet
|
||||||
|
_tileSheet = ImageData.loadFromFile("assets/%(tileSheetData["image"])")
|
||||||
|
_tileSheetH = tileSheetData["imageheight"]
|
||||||
|
_tileSheetW = tileSheetData["imagewidth"]
|
||||||
|
_tileH = tileSheetData["tileheight"]
|
||||||
|
_tileW = tileSheetData["tilewidth"]
|
||||||
|
_levelHeight = _levelData["height"]
|
||||||
|
_levelWidth = _levelData["width"]
|
||||||
|
_layers = _levelData["layers"]
|
||||||
|
_rows = Math.floor(_tileSheetW/_tileW)
|
||||||
|
_cols = Math.floor(_tileSheetH/_tileH)
|
||||||
|
}
|
||||||
|
|
||||||
|
load(levelName) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
draw(x, y) {
|
||||||
|
var startX = x
|
||||||
|
var startY = y
|
||||||
|
for(layer in _layers) {
|
||||||
|
var index = 0
|
||||||
|
for(levelY in 0...(_levelHeight)) {
|
||||||
|
for(levelX in 0...(_levelWidth)) {
|
||||||
|
if((layer["type"] == LayerType.Tile) && (layer["visible"] == true)) {
|
||||||
|
var tileIndex = layer["data"][index]
|
||||||
|
if (tileIndex > 0) {
|
||||||
|
drawTile(tileIndex-1, x, y)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
index = index + 1
|
||||||
|
x = x + 16
|
||||||
|
}
|
||||||
|
y = y + 16
|
||||||
|
x = startX
|
||||||
|
}
|
||||||
|
x = startX
|
||||||
|
y = startY
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
drawTile(tileIndex, mapX, mapY) {
|
||||||
|
var spriteX = (tileIndex % _rows)
|
||||||
|
var spriteY = Math.floor ((tileIndex - spriteX) % _cols)
|
||||||
|
_tileSheet.transform({
|
||||||
|
"srcX": spriteX * 16,
|
||||||
|
"srcY": spriteY * 16,
|
||||||
|
"srcW": _tileW,
|
||||||
|
"srcH": _tileH,
|
||||||
|
"scaleX": 1,
|
||||||
|
"scaleY": 1
|
||||||
|
}).draw(mapX,mapY)
|
||||||
|
}
|
||||||
|
}
|
||||||
63
main.wren
63
main.wren
@@ -1,25 +1,17 @@
|
|||||||
import "graphics" for ImageData
|
import "graphics" for ImageData
|
||||||
import "json" for Json
|
import "json" for Json
|
||||||
import "graphics" for Canvas, Color
|
import "graphics" for Canvas, Color
|
||||||
import "./layerType" for LayerType
|
import "dome" for Window, Process
|
||||||
import "dome" for Window
|
|
||||||
import "math" for Math
|
import "math" for Math
|
||||||
|
import "config" for Config
|
||||||
|
import "input" for Keyboard
|
||||||
|
import "./controls" for Controls
|
||||||
|
import "./level" for Level
|
||||||
|
|
||||||
class Main {
|
class Main {
|
||||||
construct new() {
|
construct new() {
|
||||||
_tileSheet = ImageData.loadFromFile("assets/tilemap_packed.png")
|
Config.setup()
|
||||||
_tileSheetH = 128
|
__level = Level.new("level1")
|
||||||
_tileSheetW = 272
|
|
||||||
_tileH = 16
|
|
||||||
_tileW = 16
|
|
||||||
_rows = _tileSheetW/_tileW
|
|
||||||
_cols = _tileSheetH/_tileH
|
|
||||||
_levelData = Json.load("assets/level1.json")
|
|
||||||
_levelHeight = _levelData["tileheight"]
|
|
||||||
_levelWidth = _levelData["tilewidth"]
|
|
||||||
_layers = _levelData["layers"]
|
|
||||||
Window.resize(256, 256)
|
|
||||||
Canvas.resize(256, 256)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
@@ -27,45 +19,14 @@ class Main {
|
|||||||
}
|
}
|
||||||
|
|
||||||
update() {
|
update() {
|
||||||
|
if(Controls.detect(Config.KeyboardConstants["QUIT"])) {
|
||||||
}
|
Process.exit(0)
|
||||||
|
|
||||||
drawTile(tileIndex, mapX, mapY) {
|
|
||||||
var spriteX = (tileIndex % _rows)
|
|
||||||
var spriteY = Math.floor ((tileIndex - spriteX) % _cols)
|
|
||||||
_tileSheet.transform({
|
|
||||||
"srcX": spriteX * 16,
|
|
||||||
"srcY": spriteY * 16,
|
|
||||||
"srcW": _tileW,
|
|
||||||
"srcH": _tileH,
|
|
||||||
"scaleX": 1,
|
|
||||||
"scaleY": 1
|
|
||||||
}).draw(mapX*16,mapY*16)
|
|
||||||
}
|
|
||||||
|
|
||||||
drawLevel(x, y) {
|
|
||||||
for(layer in _layers) {
|
|
||||||
var index = 0
|
|
||||||
for(levelY in 0...(_levelHeight)) {
|
|
||||||
for(levelX in 0...(_levelWidth)) {
|
|
||||||
if((layer["type"] == LayerType.Tile) && (layer["visible"] == true)) {
|
|
||||||
var tileIndex = layer["data"][index]
|
|
||||||
if (tileIndex > 0) {
|
|
||||||
drawTile(tileIndex-1, levelX, levelY)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
index = index + 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getTile() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
draw(alpha) {
|
draw(alpha) {
|
||||||
drawLevel(0,0)
|
Canvas.cls(Color.pink)
|
||||||
|
__level.draw(0,0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user