目次
DOTween とは?
DOTween は移動系のアニメーション(イージング)を簡単に実装できるアセットです。
data:image/s3,"s3://crabby-images/795d3/795d3c709e937ccf240a5c1880b1b99eb9926a4b" alt="DOTween"
この記事では DOTween の簡易的な使い方をまとめました。
DOTWeen のアセットは以下のリンクから無料版がダウンロードできます。
DOTween の設定
DOTween を使う際は、namespace
の指定が必要です。
using DG.Tweening;
移動
DOMove
ターゲットを指定した位置に移動。
transform.DOMove(
new Vector3(2, 0, 0), // 移動終了地点
1f // 演出時間
);
data:image/s3,"s3://crabby-images/3b678/3b678dd42459cca59736c5f3d83b17d9bd9dc004" alt="DOMove"
ローカル座標で移動したい場合はDOLocalMove()
を使います。
オプションで第3引数にsnapping
が設定できます。true にすると座標が全て int になるよう実行されます。
単体の軸のみを移動したい時のために、DOMoveX()
、DOMoveY()
、DOMoveZ()
も存在します。
DOJump
ターゲットをY軸に沿ってジャンプ効果を適用しながら指定した位置に移動。
transform.DOJump(
new Vector3(10, 0, 0), // 移動終了地点
2f, // ジャンプの高さ
2, // ジャンプの総数
1.5f // 演出時間
);
data:image/s3,"s3://crabby-images/9d1fb/9d1fb55028864207b55e4d6a45674e1048601f28" alt="DOJump"
DOPath
設定した複数の通過地点を通って移動。
var wayPoints = new Vector3[]
{
new Vector3(0, 0, 0),
new Vector3(0, 2, 0),
new Vector3(2, 2, 0),
new Vector3(2, 0, 0),
};
transform.DOPath(
wayPoints, // 通過地点のリスト
2f // 演出時間
);
data:image/s3,"s3://crabby-images/c9a1b/c9a1ba5f75146f2923e5b0825976a32e8cccf94c" alt="DOPath"
回転
DORotate
ターゲットを指定した値に回転。
transform.DORotate(
new Vector3(45, 45, 0), // 終了時のRotation
1f // 演出時間
);
data:image/s3,"s3://crabby-images/c5c92/c5c92362632ff39dddd51b09914a39f7b9cbaa4f" alt="DORotate"
ローカル座標で回転したい場合はDOLocalRotate()
を使います。
DOLookAt
ターゲットを回転させて指定した方向 (ターゲット) へ向かせる。
[SerializeField]
Transform targetTrans; // ターゲット
transform.DOLookAt(
targetTrans.position, // ターゲットの位置
1f // 演出時間
);
data:image/s3,"s3://crabby-images/3d7da/3d7dad740ebc3eb9f5f13e6acc336e241e99d094" alt="DOLookAt"
拡大 / 縮小
DOScale
ターゲットを指定した値にスケール。
transform.DOScale(
new Vector3(2, 2, 2), // スケール値
1f // 演出時間
);
data:image/s3,"s3://crabby-images/4c99e/4c99ec7d85d2dac01e3aa1c5253330f71de78a7e" alt="DOScale"
DOScaleX()
、DOScaleY()
、DOScaleZ()
も存在します。
パンチング
DOPunchPosition
Transform の localPosition を指定した方向にパンチングし、弾性を介して開始位置に戻す。
transform.DOPunchPosition(
new Vector3(0, 1, 0), // パンチの方向と強さ
1f // 演出時間
);
data:image/s3,"s3://crabby-images/38155/381556ebb65c49703a9ca66bf3b7fada55ab14b1" alt="DOPunchPosition"
DOPunchRotation
Transform の localRotation を指定した方向にパンチングし、弾性を介して開始回転に戻す。
transform.DOPunchRotation(
new Vector3(0, 45, 0), // パンチの向きと強さ
1f // 演出時間
);
data:image/s3,"s3://crabby-images/54b52/54b52cfc5d308186b1f3c417f9d5d9cb3ecfd774" alt="DOPunchRotation"
DOPunchScale
Transform の localScale を指定したサイズに向かってパンチングし、弾性を介して開始サイズに戻す。
transform.DOPunchScale(
new Vector3(1.2f, 1.2f, 1.2f), // パンチのスケール
1f // 演出時間
);
data:image/s3,"s3://crabby-images/b53f6/b53f68719232703b5bc1551d8da8bce92c09b3bb" alt="DOPunchScale"
シェイク
DOShakePosition
指定した値で Transform の localPosition をシェイク。
transform.DOShakePosition(
duration: 1f, // 演出時間
strength: 1.5f // シェイクの強さ
);
data:image/s3,"s3://crabby-images/19a1f/19a1f86c65b39d8c4325bef3a717a30e858a0edc" alt="DOShakePosition"
DOShakeRotation
指定した値で Transform の localRotation をシェイク。
transform.DOShakeRotation(
duration: 1f, // 演出時間
strength: 90f // シェイクの強さ
);
data:image/s3,"s3://crabby-images/f9e7f/f9e7faac0224105de0def0bfc8bcfa87e9f5481c" alt="DOShakeRotation"
DOShakeScale
指定した値で Transform の localScale をシェイク。
transform.DOShakeScale(
duration: 1f, // 演出時間
strength: 1.2f // シェイクの強さ
);
data:image/s3,"s3://crabby-images/4fc70/4fc70d76e9a73c1a66f95bd8e98014d7330b50af" alt="DOShakeScale"
グラフィック
DOColor
ターゲットの色を指定した色に変更。
image.color = Color.white;
image.DOColor(
Color.yellow, // 変更後の色
1f // 演出時間
);
data:image/s3,"s3://crabby-images/10a58/10a580a7468d5e3efeca11926b57af0722259420" alt="DOColor"
DOFade
ターゲットのアルファを指定した値にフェード。
image.DOFade(
0f, // フェード後のアルファ値
1f // 演出時間
);
data:image/s3,"s3://crabby-images/7d3fb/7d3fb77b96bd98f25c5593f8809bf82e8ac74de8" alt="DOFade"
おわりに
DOTween には他にも様々なメソッドや使い方が存在します。
気になる方は DOTween の公式ドキュメントをご覧ください。
参考 DOTween ドキュメントdotween.demigiant.com
関連記事