npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@akashic-extension/akashic-animation

v4.2.0

Published

A skeletal animation library for Akashic Engine

Downloads

45

Readme

Akashic Animation

Akashic AnimationはAkashic Engine向けのアニメーションライブラリです。

利用方法

akashic-cliをインストールした後、

akashic install @akashic-extension/akashic-animation

でインストールできます。コンテンツからは、

var aa = require("@akashic-extension/akashic-animation");

で利用してください。

Akashic Engineの詳細な利用方法については、 公式ページ を参照してください。

APIリファレンス

こちら

補足

利用可能なキーフレームの補間方法

以下の補完方法をサポートします。

  • 補間なし
  • 線形
  • ベジェ
  • エルミート
  • 加速(SpriteStudio)
  • 減速(SpriteStudio)

ループアニメーションの補間

アニメーションをループ再生するとき、最後のフレームと最初のフレームの間は常に線形補間になります。

キーフレームの外挿

再生するアニメーションの0フレーム目がキーフレームでない時、akashic-animationは0フレーム目に初期値を与えます。初期値は属性により異なります(次の表参照)。

| 属性 | 値 | |:------------------- |:---------- | | X,Y座標 | 0, 0 | | Z回転 | 0 | | X,Yスケール | 1, 1 | | ローカルX,Yスケール | 1, 1 | | アルファ | 1 | | ローカルアルファ | 無し | | セル | 無し | | セル中心座標 | 0, 0 | | セルUV | 0, 0 | | 優先順位 | 0 | | 可視・不可視 | 可視 | | 円アタリ判定半径 | 0 | | 水平フリップ | しない | | 垂直フリップ | しない | | ユーザデータ | 無し |

最終フレームがキーフレームでない時も同様に値を与えます。この値は最後のキーフレームと同じ値になります。

E#modified()とActor#calc()の順序

Actor#calc()はActor自体の座標や回転の値から導かれる行列を利用します。そのため、Actor#calc()の前にActor#modified()を実行してください。さらにColliderActor#calc()の計算結果を利用します。

以上から、Actorを利用したプログラムはおよそ次のような順序で実行することになります。

// アクターの更新
actor.x += 10;
actor.angle += 1;
actor.modified();

...

// アニメーションの更新
actor.calc();

...

// 当たり判定
actor.colliders.forEach(function(c) {
    var volume = c.getVolume();
    if (! volume) return;
    var aabb = volume.aabb();
    // 具体的な計算
});

Attachment

AttachmentActorのボーンに描画可能なオブジェクトをアタッチするクラスです。現在はActorのスキンからセルを取り出し、それを任意のボーンにアタッチすることできます。

Collider

Colliderは衝突判定に必要な値を導出するクラスです。asabnファイルにセルに基づいた当たり判定の情報が記述されている時、自動的にBoneCellColliderが生成されます。

CellAttachmentColliderCellAttachmentを衝突判定に利用するコライダーです。Actorにセルをアタッチした時、これで当たり判定を扱いたい時に利用してください。

Colliderにはnametagの2つのプロパティがあります。nameはコンバータによって使用される可能性があります。BoneCellColliderではボーン名が設定されます。

tagはコンバータもakashic-animationも利用することはありません。衝突判定に必要な情報を紐付けるなどご利用ください。

Volume

当たり判定の領域を表すクラスです。Collider#getVolume()を用いて取得できます。

Volume#aabb()でAABBを取得できます。

Volumeにはいくつかの派生クラスがあります。Colliderの返すVolueの型を確認しダウンキャストすることでより具体的な情報が得られます。

Volume#aabbFirstフラグはDCCツールまたはプログラム中で設定されます。これは当たり判定でAABBを優先する(ダウンキャスト後の詳細な情報でなく)ことを示します。

アニメーションの座標系

akashic-animationは Actor#x,Actor#y を原点とする座標系で描画されます。

アニメーション計算ハンドラ

Actor#calculated()を用いることでアニメーションの計算結果を変更したり、ユーザデータを受け取ることが出来ます。

標準的なハンドラの書き方 (JavaScript)

actor.calculated("root", true).handle(this, function(param) { // rootボーンにハンドラ登録
    if (param.left.time === param.currentFrame && param.left.userData) {
        // 現在時刻のユーザデータが存在するとき、効果音を再生する
        playSound(param.left.userData.str);
    }
    if (param.posture) {
        // アニメーション計算結果を書き換え
        param.posture.attrs[AttrId.alpha] *= 0.5;
        // ハンドラはPosture#updateMatrix()を実行するかPosture#mに適切な値を格納する責任を持ちます
        param.posture.updateMatrix();
        // Posture#updateMatrix()の結果を書き換え
        param.posture.m._matrix[5] += 10;
    }
}, "root handler"); // g.Trigger.removeByName() でハンドラを削除するときに利用するハンドラ名

AnimationHandlerParam

登録されたハンドラにはAnimationHandlerParam型のオブジェクトが渡されます。

interface AnimationHandlerParam {
    posture?: Posture;
    left?: AnimationHandlerKeyFrameInfo;
    right?: AnimationHandlerKeyFrameInfo;
    currentFrame: number;
    frameCount: number;
 };
interface AnimationHandlerKeyFrameInfo {
    time: number;
    userData?: any;
}

アニメーション計算ハンドラの実行タイミング

ハンドラが実行されるタイミングは2つあります。ハンドラ実行タイミングによってAnimationHandlerParamに格納される値が変わります。

  • 各ボーンのアニメーション計算開始前
    • 前回のActor#calc()から今回のActor#calc()の間に1つ以上のキーフレームがスキップされており、それらがユーザデータを持つときハンドラを実行します。実行回数はスキップされたキーフレーム数になります。
    • posture: undefinedになります。
    • left: スキップされたKeyFrametimeuserDataが格納されます。
    • right: undefinedになります。
    • currentFrame: left.timeと同じ値になります。
    • frameCount: 現在再生中のアニメーションのフレーム数が格納されます。
    • 次の操作の直後についてはハンドラを実行しません。
      • Actor#currentFrame
      • Actor#play()
  • 各ボーンのアニメーション計算完了後
    • posture: 計算結果が格納されます。例えばposture[AttrId.alpha]とすると半透明度の計算結果にアクセスできます。
    • left, right: 現在時刻に対して左右(前後)にある直近のKeyFrameの時刻とuserDataが格納されます。再生中のアニメーションがハンドラを取り付けたボーンに対してユーザデータを持たない時undefinedとなります。
    • currentFrame: 現在時刻(フレーム番号)が格納されます。Actorは再生速度可変のため、この値は整数とは限りません。
    • frameCount: 現在再生中のアニメーションのフレーム数が格納されます。

ハンドラはpostureundefinedかどうか確認することで呼び出しタイミングを区別できます。

アニメーション再生終了ハンドラ

Actor#endedを用いることでアニメーション再生が終了したタイミングで呼び出されるハンドラを登録できます。

 actor.ended.handle(function() {
     stopBGM();
     goNextScene();
 });

制限

Actorを他のEの子にするとColliderが正しく当たり判定領域を求められない

ColliderActor#calc() の結果を用いますが Actor#calc()Actor#parent の行列を参照しません。

属性の継承関係を変更できない

ボーンの扱う属性の継承関係は次のように固定されています。

| 属性 | 継承 | |:-------------- |:---------- | | 行列 | YES | | 透明度 | YES | | 参照セル | NO | | セル中心位置 | NO | | セルUV | NO | | セル描画順位 | NO | | セル可視フラグ | NO | | セル左右反転 | NO | | セル上下反転 | NO |

アルファブレンドモード

akashic-animationでは、セル毎にアルファブレンドを指定できるようになっています。 現在サポートしているアルファブレンドは以下の通りです。

| アルファブレンド | 説明 | |:----------------- |:--------------------------------------------------------------------------- | | normal | デフォルトの設定です。描画元のセルを描画先の内容の上に描きます | | add | 描画先の内容の色(背景色)と描画元のセルの重なる部分のカラー値が加算されます |

ビルド方法

akashic-animationはTypeScriptで書かれたライブラリであるため、ビルドにはnode.jsが必要です。

npm run build によりgulpを使ってビルドできます。

npm install
npm run build

ライセンス

本リポジトリは MIT License の元で公開されています。 詳しくは LICENSE をご覧ください。

ただし、画像ファイルおよび音声ファイルは CC BY 2.1 JP の元で公開されています。