2016-04-06 01:59:37 +02:00
|
|
|
var ani_ship_r = OS.A.Add("Ship Right", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 4});
|
|
|
|
var ani_ship_ur = OS.A.Add("Ship Up-Right", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 7});
|
|
|
|
var ani_ship_u = OS.A.Add("Ship Up", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 5});
|
|
|
|
var ani_ship_ul = OS.A.Add("Ship Up-Left", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 6});
|
|
|
|
var ani_ship_l = OS.A.Add("Ship Left", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 3});
|
|
|
|
var ani_ship_dl = OS.A.Add("Ship Down-Left", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 1});
|
2016-04-06 00:51:00 +02:00
|
|
|
var ani_ship_d = OS.A.Add("Ship Down", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 0});
|
2016-04-06 01:59:37 +02:00
|
|
|
var ani_ship_dr = OS.A.Add("Ship Down-Right", 64, 64, {columns: 2, speed: 1/60, yOffset: 64 * 2});
|
2016-04-05 19:39:18 +02:00
|
|
|
|
|
|
|
function shipPrefab() {}
|
|
|
|
|
2016-04-06 00:51:00 +02:00
|
|
|
var pr_ship = OS.P.Add("Ship", {
|
|
|
|
solid: true,
|
|
|
|
imageSrc: "images/ship_sheet.png",
|
|
|
|
maskImageSrc: "images/ship_mask.png",
|
|
|
|
animations: [ani_ship_r, ani_ship_ur, ani_ship_u, ani_ship_ul, ani_ship_l, ani_ship_dl, ani_ship_d, ani_ship_dr],
|
|
|
|
|
|
|
|
direction: 0,
|
2016-04-06 01:59:37 +02:00
|
|
|
currentSpeed: 0,
|
2016-04-06 00:51:00 +02:00
|
|
|
moveStepSize: 3,
|
2016-04-06 01:59:37 +02:00
|
|
|
moveStepAmount: 5 * Oversimplified.R[Oversimplified.R.currentRoom].stepSpeed,
|
2016-04-06 00:51:00 +02:00
|
|
|
moveStepProgress: 0,
|
2016-04-06 01:59:37 +02:00
|
|
|
doTakeStep: false,
|
|
|
|
|
|
|
|
// Ship stats.
|
|
|
|
speedStat: 1
|
2016-04-06 00:51:00 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
pr_ship.Do = function () {
|
2016-04-06 01:59:37 +02:00
|
|
|
if (ct_left().down) {
|
2016-04-06 00:51:00 +02:00
|
|
|
this.direction += 45;
|
2016-04-06 01:59:37 +02:00
|
|
|
} else if (ct_right().down) {
|
2016-04-06 00:51:00 +02:00
|
|
|
this.direction -= 45;
|
|
|
|
}
|
|
|
|
this.direction = Math.clampAngle(this.direction);
|
|
|
|
|
|
|
|
if (ct_up().down) {
|
2016-04-06 01:59:37 +02:00
|
|
|
this.currentSpeed++;
|
2016-04-06 00:51:00 +02:00
|
|
|
} else if (ct_down().down) {
|
2016-04-06 01:59:37 +02:00
|
|
|
this.currentSpeed--;
|
2016-04-06 00:51:00 +02:00
|
|
|
}
|
2016-04-06 01:59:37 +02:00
|
|
|
this.currentSpeed = Math.clamp(this.currentSpeed, 0, 4);
|
2016-04-06 00:51:00 +02:00
|
|
|
|
2016-04-06 01:59:37 +02:00
|
|
|
this.moveStepProgress += this.currentSpeed * this.moveStepAmount;
|
|
|
|
if (this.moveStepProgress >= this.moveStepSize) {
|
|
|
|
this.moveStepProgress -= this.moveStepSize;
|
|
|
|
this.doTakeStep = true;
|
|
|
|
} else {
|
|
|
|
this.doTakeStep = false;
|
2016-04-06 00:51:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pr_ship.AfterDo = function () {
|
|
|
|
switch (this.direction) {
|
|
|
|
case 0:
|
|
|
|
if (this.image.currentAnimation != "Ship Right") this.SetAnimation("Ship Right");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) this.x += (this.speedStat + this.currentSpeed) * OS.S.pixelScale;
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 45:
|
|
|
|
if (this.image.currentAnimation != "Ship Up-Right") this.SetAnimation("Ship Up-Right");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) { this.x += (this.speedStat + this.currentSpeed) * OS.S.pixelScale; this.y -= (this.speedStat + this.currentSpeed) * OS.S.pixelScale; }
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 90:
|
|
|
|
if (this.image.currentAnimation != "Ship Up") this.SetAnimation("Ship Up");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) this.y -= (this.speedStat + this.currentSpeed) * OS.S.pixelScale;
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 135:
|
|
|
|
if (this.image.currentAnimation != "Ship Up-Left") this.SetAnimation("Ship Up-Left");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) { this.x -= (this.speedStat + this.currentSpeed) * OS.S.pixelScale; this.y -= (this.speedStat + this.currentSpeed) * OS.S.pixelScale; }
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 180:
|
|
|
|
if (this.image.currentAnimation != "Ship Left") this.SetAnimation("Ship Left");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) this.x -= (this.speedStat + this.currentSpeed) * OS.S.pixelScale;
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 225:
|
|
|
|
if (this.image.currentAnimation != "Ship Down-Left") this.SetAnimation("Ship Down-Left");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) { this.x -= (this.speedStat + this.currentSpeed) * OS.S.pixelScale; this.y += (this.speedStat + this.currentSpeed) * OS.S.pixelScale; }
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 270:
|
|
|
|
if (this.image.currentAnimation != "Ship Down") this.SetAnimation("Ship Down");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) this.y += (this.speedStat + this.currentSpeed) * OS.S.pixelScale;
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
case 315:
|
|
|
|
if (this.image.currentAnimation != "Ship Down-Right") this.SetAnimation("Ship Down-Right");
|
2016-04-06 01:59:37 +02:00
|
|
|
if (this.doTakeStep) { this.x += (this.speedStat + this.currentSpeed) * OS.S.pixelScale; this.y += (this.speedStat + this.currentSpeed) * OS.S.pixelScale; }
|
2016-04-06 00:51:00 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
console.log("No valid direction");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|