50
28

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Transition サポート ライブラリ 26.0.0

Last updated at Posted at 2017-05-25

Transition サポート ライブラリ

Transition サポート ライブラリは、API レベル 19 KitKat で追加された Transition API を API レベル 14 Ice Cream Sandwich までバックポートするライブラリです。2017 年 7 月に公開されたバージョン 26.0.0 で大幅にパワーアップしました。具体的には Lollipop 以降に導入された様々な API を追加し、また Transition XML もサポートしました。

build.gradle
dependencies {
    compile "com.android.support:transition:26.0.0"
}

Lollipop で追加された API

新しい Transition タイプ

これまで利用できた KitKat の Transition タイプ (ChangeBounds, Fade, AutoTransition, TransitionSet) に加えて、Lollipop で追加された新しい Transition タイプがサポート ライブラリでも利用できます。

ChangeClipBounds
ViewCompat.setClipBounds をアニメーション
ChangeImageTransform
ImageView.setScaleType などをアニメーション
ChangeTransform
View.setTranslationX, Y などをアニメーション
Explode
View.setVisibility をアニメーション - 中心点から離れるように画面外に移動
Slide
View.setVisibility をアニメーション - 画面の端に移動
ChangeScroll
スクロールをアニメーション

例えばボタンを押すたびに対象の View が画面の端から出てきたり引っ込んだりするようなアニメーションをするなら新しく追加された Slide を使ってできます。

MainActivity.kt
companion object {
    val SLIDE = Slide(Gravity.END)
}

// (略)

    // toggle はボタン
    toggle.setOnClickListener {
        // root は親 ViewGroup
        TransitionManager.beginDelayedTransition(root, SLIDE)
        // box が対象の View
        box.visibility = if (box.visibility == View.VISIBLE) View.INVISIBLE else View.VISIBLE
    }

自前で View.animate() などを使って実装することもできるでしょうが、Transition API なら一行です。ボタンを連打しても対象の View は途中の状態からうまくアニメーションします。

Transition の機能

PathMotion
View の移動やサイズ変更など二次元的な動きをするアニメーションについて、X 軸と Y 軸を指定された曲線に沿って変化させる
TransitionPropagation
Transition を複数の View に同時に適用するとき、View ごとに開始するタイミングをずらす
Epicenter
Transition の中心点を指定する

例えばボタンを押すたびに対象の View の Gravity を切り替え、その移動を円弧に従ってアニメーションするならこのようにできます。

MainActivity.kt
companion object {
    val GRAVITY1 = Gravity.START or Gravity.TOP
    val GRAVITY2 = Gravity.END or Gravity.BOTTOM
    val CHANGE_BOUNDS = ChangeBounds().apply {
        pathMotion = ArcMotion()
        interpolator = FastOutSlowInInterpolator()
    }
}

// (略)

    toggle.setOnClickListener {
        TransitionManager.beginDelayedTransition(root, CHANGE_BOUNDS)
        val lp = box.layoutParams as FrameLayout.LayoutParams
        lp.gravity = if (lp.gravity == GRAVITY1) GRAVITY2 else GRAVITY1
        box.layoutParams = lp
    }

クリックリスナーの中では Transition API を呼び出して LayoutParams を書き換えているだけです。

Transition XML

これまでサポート ライブラリで利用することができなかった Transition 用のリソース XMLが利用できるようになりました。

Transition XML は例えば以下のようなものです。

res/transition/my_transition.xml
<transitionSet xmlns:android="http://schemas.android.com/apk/res/android"
    android:transitionOrdering="sequential">
    <fade android:fadingMode="fade_out" />
    <changeBounds />
    <fade android:fadingMode="fade_in" />
</transitionSet>

コードから以下のようにしてインスタンス化できます。

MainActivity.kt
val myTransition = TransitionInflater.from(this).inflateTransition(R.transition.my_transition)

ここで登場する android:fadingMode という属性は KitKat で追加されたものです。通常サポート ライブラリでバックポートされるこのような XML 属性を利用する場合
android: ではなく app: と書き換えなければならないことが多いのですが、Transition XML では android: のまま利用できます。すでにある Transition XML を書き換える必要は一切ありません。その代わり、build.gradle に以下の記述が必要です。

build.gradle
android {
    // (略)
    aaptOptions {
        additionalParameters "--no-version-transitions"
    }
}

その他、バグ報告やフィードバックは Google Issue Tracker にお願いします。

50
28
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
50
28

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?