Adobe Animate: ticker を使って移動 & Classの作成
this.addEventListener('tick', counter);
createjs.Ticker.framerate = 1; //フレームレート
function counter(ev) {
acum ++;
console.log(acum);
}
サンプル
data:image/s3,"s3://crabby-images/8617f/8617f2140da4841b4ced78b07bc34236bc105a80" alt=""
右ナナメ上(-45°)に移動
this.on("tick", update.bind(this));
//ラジアン = 度 * Math.PI / 180;
function update(ev) {
var angle = -45 * Math.PI / 180;
this.shikaku.x += Math.cos(angle) * 5;
this.shikaku.y += Math.sin(angle) * 5;
}
泥棒を追いかける警察
this.on("tick", update.bind(this));
function update(ev){
var dx = this.thief.x - this.policeman.x;
var dy = this.thief.y - this.policeman.y;
var angle = Math.atan2(dy, dx);
this.policeman.x += Math.cos(angle) * 3;
this.policeman.y += Math.sin(angle) * 3;
}
イージングあり
this.on("tick", update.bind(this));
var easing = 0.05;
function update(ev){
var dx = this.thief.x - this.policeman.x;
var dy = this.thief.y - this.policeman.y;
this.policeman.x += dx * easing;
this.policeman.y += dy * easing;
}
ドキュメントの中心を軸に円移動
this.on("tick", update.bind(this));
var angle = 0;
console.log(lib.properties.width);
function update(ev) {
this.ball.x = lib.properties.width / 2 + Math.cos(angle) * 150; //中心から150px離す
this.ball.y = lib.properties.height / 2 + Math.sin(angle) * 150; //中心から150px離す
angle += 0.1;
}
Classの作成
data:image/s3,"s3://crabby-images/7592c/7592ca1008b53509a06641323dfd3d246fab7b28" alt=""
data:image/s3,"s3://crabby-images/8e940/8e94020bd586699090962d991d34c7304a0460e6" alt=""
Bear Class アクション
class Bear {
constructor(_content) {
this.content = _content;
this.movieClip = new lib.Bear();
this.content.addChild(this.movieClip);
}
update() {
this.movieClip.x += 3;
}
}
Cat Class アクション
class Cat {
constructor(_content) {
this.content = _content;
this.movieClip = new lib.Cat();
this.movieClip.x = 100;
this.movieClip.y = 100;
this.content.addChild(this.movieClip);
}
update() {
this.movieClip.y += 3;
}
}
Game アクション
一番下のレイヤーに配置すること!
var bear01 = new Bear(this);
var bear02 = new Bear(this);
var cat01 = new Cat(this);
var cat02= new Cat(this);
bear02.movieClip.y = 100;
cat02.movieClip.x = 10;
this.on("tick", update.bind(this));
function update(ev) {
bear01.update();
bear02.update();
cat01.update();
cat02.update();
}