2022-09-20 15:50:01 +00:00
|
|
|
module.export = cc.Class({
|
|
|
|
extends: cc.Component,
|
|
|
|
|
|
|
|
properties: {
|
|
|
|
lastMovedAt: {
|
|
|
|
type: cc.Float,
|
|
|
|
default: 0 // In "GMT milliseconds"
|
2022-11-12 12:34:38 +00:00
|
|
|
}
|
2022-09-20 15:50:01 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
// LIFE-CYCLE CALLBACKS:
|
|
|
|
start() {
|
|
|
|
const self = this;
|
|
|
|
self.activeDirection = {
|
|
|
|
dx: 0,
|
|
|
|
dy: 0
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2022-11-19 12:58:07 +00:00
|
|
|
ctor() {},
|
|
|
|
|
2022-09-20 15:50:01 +00:00
|
|
|
onLoad() {
|
|
|
|
const self = this;
|
|
|
|
const canvasNode = self.mapNode.parent;
|
2022-09-21 09:22:34 +00:00
|
|
|
self.mapIns = self.mapNode.getComponent("Map");
|
2022-09-20 15:50:01 +00:00
|
|
|
const joystickInputControllerScriptIns = canvasNode.getComponent("TouchEventsManager");
|
|
|
|
self.ctrl = joystickInputControllerScriptIns;
|
|
|
|
},
|
|
|
|
|
|
|
|
scheduleNewDirection(newScheduledDirection, forceAnimSwitch) {
|
|
|
|
if (!newScheduledDirection) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2022-09-21 09:22:34 +00:00
|
|
|
if (forceAnimSwitch || null == this.activeDirection || (newScheduledDirection.dx != this.activeDirection.dx || newScheduledDirection.dy != this.activeDirection.dy)) {
|
|
|
|
this.activeDirection = newScheduledDirection;
|
2022-11-19 12:58:07 +00:00
|
|
|
if (this.animComp && this.animComp.node) {
|
|
|
|
if (0 > newScheduledDirection.dx) {
|
|
|
|
this.animComp.node.scaleX = (-1.0);
|
|
|
|
} else if (0 < newScheduledDirection.dx) {
|
|
|
|
this.animComp.node.scaleX = (1.0);
|
2022-09-20 15:50:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2022-11-12 12:34:38 +00:00
|
|
|
update(dt) {},
|
2022-09-20 15:50:01 +00:00
|
|
|
|
2022-11-12 12:34:38 +00:00
|
|
|
lateUpdate(dt) {},
|
2022-09-20 15:50:01 +00:00
|
|
|
|
|
|
|
_generateRandomDirection() {
|
|
|
|
return ALL_DISCRETE_DIRECTIONS_CLOCKWISE[Math.floor(Math.random() * ALL_DISCRETE_DIRECTIONS_CLOCKWISE.length)];
|
|
|
|
},
|
|
|
|
|
|
|
|
updateSpeed(proposedSpeed) {
|
|
|
|
if (0 == proposedSpeed && 0 < this.speed) {
|
2022-11-12 12:34:38 +00:00
|
|
|
this.startFrozenDisplay();
|
|
|
|
}
|
2022-09-20 15:50:01 +00:00
|
|
|
if (0 < proposedSpeed && 0 == this.speed) {
|
2022-11-12 12:34:38 +00:00
|
|
|
this.stopFrozenDisplay();
|
|
|
|
}
|
|
|
|
this.speed = proposedSpeed;
|
2022-09-20 15:50:01 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
});
|