AgentVerse's picture
first commit
670a607
import Base from '../base/Base.js';
import { Line } from '../utils/Geoms.js';
import Yoyo from '../utils/Yoyo.js';
const Linear = Phaser.Math.Linear;
const ExpoIn = Phaser.Math.Easing.Expo.In;
const RowNum = 2;
const ColNum = 2;
class Cube extends Base {
constructor(scene, config) {
super(scene, config);
this.type = 'rexSpinnerCube';
}
buildShapes() {
var cnt = RowNum * ColNum;
for (var i = 0; i < cnt; i++) {
var line = new Line();
this.addShape(line);
}
}
updateShapes() {
var centerX = this.centerX;
var centerY = this.centerY;
var radius = this.radius;
var leftBound = centerX - radius;
var topBound = centerY - radius;
var cellWidth = (radius * 2) / ColNum;
var cellHeight = (radius * 2) / RowNum;
var shapes = this.getShapes(),
cnt = shapes.length;
for (var i = 0; i < cnt; i++) {
var colIdx = (i % ColNum);
var rowIdx = Math.floor(i / RowNum);
var x = leftBound + (cellWidth * (colIdx + 0.5));
var y = topBound + (cellHeight * (rowIdx + 0.5));
var line = shapes[i];
var t = (this.value + ((cnt - i) * 0.1)) % 1;
t = ExpoIn(Yoyo(t));
var lineAlpha = (cnt - i) / cnt;
var lineHeight = Linear(0.7, 1, t) * cellHeight;
var lineWidth = Linear(0.7, 1, t) * cellWidth;
line
.lineStyle(lineWidth, this.color, lineAlpha)
.setP0(x - (lineHeight / 2), y)
.setP1(x + (lineHeight / 2), y);
}
}
}
export default Cube;