Skip to content
This repository was archived by the owner on Dec 9, 2024. It is now read-only.

Commit 6f362dc

Browse files
committed
Motion: Support predictive back in Container transform
Change-Id: I9adb4a48be47761dc725f67e50be872a8865587a
1 parent 1f1c48b commit 6f362dc

File tree

6 files changed

+73
-24
lines changed

6 files changed

+73
-24
lines changed

Motion/app/build.gradle

Lines changed: 17 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -19,12 +19,12 @@ apply plugin: 'kotlin-android'
1919
apply plugin: "androidx.navigation.safeargs.kotlin"
2020

2121
android {
22-
compileSdk 31
22+
compileSdk 34
2323

2424
defaultConfig {
25-
applicationId 'com.example.android.motion'
26-
minSdk 14
27-
targetSdk 31
25+
namespace 'com.example.android.motion'
26+
minSdk 19
27+
targetSdk 34
2828
versionCode 1
2929
versionName '1.0'
3030
testInstrumentationRunner 'androidx.test.runner.AndroidJUnitRunner'
@@ -51,33 +51,33 @@ android {
5151
dependencies {
5252
implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
5353

54-
implementation 'androidx.core:core-ktx:1.7.0'
55-
implementation 'androidx.fragment:fragment-ktx:1.4.1'
56-
implementation 'androidx.appcompat:appcompat:1.4.1'
54+
implementation 'androidx.core:core-ktx:1.12.0'
55+
implementation 'androidx.fragment:fragment-ktx:1.6.2'
56+
implementation 'androidx.appcompat:appcompat:1.6.1'
5757
implementation 'androidx.transition:transition:1.4.1'
5858
implementation 'androidx.dynamicanimation:dynamicanimation:1.1.0-alpha03'
59-
implementation 'androidx.recyclerview:recyclerview:1.2.1'
59+
implementation 'androidx.recyclerview:recyclerview:1.3.2'
6060

61-
implementation 'androidx.constraintlayout:constraintlayout:2.1.3'
61+
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
6262

63-
def lifecycle_version = '2.4.1'
63+
def lifecycle_version = '2.7.0'
6464
implementation "androidx.lifecycle:lifecycle-viewmodel-ktx:$lifecycle_version"
6565
implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version"
6666

67-
implementation 'androidx.paging:paging-runtime-ktx:3.1.1'
67+
implementation 'androidx.paging:paging-runtime-ktx:3.2.1'
6868

69-
implementation 'com.google.android.material:material:1.6.0'
69+
implementation 'com.google.android.material:material:1.11.0'
7070

7171
implementation "androidx.navigation:navigation-fragment-ktx:$navigation_version"
7272
implementation "androidx.navigation:navigation-ui-ktx:$navigation_version"
7373

74-
implementation 'com.github.bumptech.glide:glide:4.10.0'
74+
implementation 'com.github.bumptech.glide:glide:4.15.1'
7575

7676
testImplementation 'junit:junit:4.13.2'
7777
testImplementation 'com.google.truth:truth:1.1.3'
7878

79-
testImplementation 'androidx.test:core:1.4.0'
80-
androidTestImplementation 'androidx.test.ext:truth:1.4.0'
81-
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
82-
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
79+
testImplementation 'androidx.test:core:1.5.0'
80+
androidTestImplementation 'androidx.test.ext:truth:1.5.0'
81+
androidTestImplementation 'androidx.test.ext:junit:1.1.5'
82+
androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'
8383
}

Motion/app/src/main/AndroidManifest.xml

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -27,12 +27,14 @@
2727

2828
<application
2929
android:allowBackup="false"
30+
android:enableOnBackInvokedCallback="true"
3031
android:icon="@mipmap/ic_launcher"
3132
android:label="@string/app_name"
3233
android:roundIcon="@mipmap/ic_launcher_round"
3334
android:supportsRtl="true"
3435
android:theme="@style/Theme.Motion"
35-
tools:ignore="GoogleAppIndexingWarning">
36+
tools:ignore="GoogleAppIndexingWarning"
37+
tools:targetApi="34">
3638

3739
<activity
3840
android:name=".MainActivity"

Motion/app/src/main/java/com/example/android/motion/demo/containertransform/CheeseArticleFragment.kt

Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,8 @@ import android.widget.FrameLayout
2424
import android.widget.ImageView
2525
import android.widget.LinearLayout
2626
import android.widget.TextView
27+
import androidx.activity.BackEventCompat
28+
import androidx.activity.OnBackPressedCallback
2729
import androidx.appcompat.widget.Toolbar
2830
import androidx.coordinatorlayout.widget.CoordinatorLayout
2931
import androidx.core.view.ViewCompat
@@ -35,7 +37,10 @@ import androidx.core.widget.NestedScrollView
3537
import androidx.fragment.app.Fragment
3638
import androidx.fragment.app.viewModels
3739
import androidx.navigation.findNavController
40+
import androidx.navigation.fragment.findNavController
3841
import androidx.navigation.fragment.navArgs
42+
import androidx.transition.ChangeTransform
43+
import androidx.transition.TransitionManager
3944
import com.example.android.motion.R
4045
import com.google.android.material.appbar.CollapsingToolbarLayout
4146
import com.google.android.material.transition.MaterialContainerTransform
@@ -50,6 +55,8 @@ class CheeseArticleFragment : Fragment() {
5055

5156
private val viewModel: CheeseArticleViewModel by viewModels()
5257

58+
private val cancelTransition = ChangeTransform()
59+
5360
override fun onCreate(savedInstanceState: Bundle?) {
5461
super.onCreate(savedInstanceState)
5562

@@ -111,5 +118,45 @@ class CheeseArticleFragment : Fragment() {
111118
toolbar.setNavigationOnClickListener { v ->
112119
v.findNavController().popBackStack()
113120
}
121+
122+
requireActivity().onBackPressedDispatcher.addCallback(
123+
viewLifecycleOwner,
124+
object : OnBackPressedCallback(true) {
125+
override fun handleOnBackPressed() {
126+
// This invokes the sharedElementReturnTransition, which is
127+
// MaterialContainerTransform.
128+
// TODO: It pops the scaleX/Y back to 1f. It would look nicer to retain the
129+
// scale. How should we handle it?
130+
findNavController().popBackStack()
131+
}
132+
133+
override fun handleOnBackProgressed(backEvent: BackEventCompat) {
134+
val progress = backEvent.progress
135+
// Translate as far as 20% of finger movement.
136+
val translation = progress * background.width * 0.2f
137+
background.translationX =
138+
if (backEvent.swipeEdge == BackEventCompat.EDGE_LEFT) {
139+
translation
140+
} else {
141+
-translation
142+
}
143+
// TODO: Consider handling backEvent.touchY to reflect the vertical movement.
144+
145+
// Scale down from 100% to 50%.
146+
val scale = (2f - progress) * 0.5f
147+
background.scaleX = scale
148+
background.scaleY = scale
149+
}
150+
151+
override fun handleOnBackCancelled() {
152+
TransitionManager.beginDelayedTransition(background, cancelTransition)
153+
background.run {
154+
translationX = 0f
155+
scaleX = 1f
156+
scaleY = 1f
157+
}
158+
}
159+
}
160+
)
114161
}
115162
}

Motion/app/src/main/java/com/example/android/motion/demo/sharedelement/MirrorView.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ class MirrorView @JvmOverloads constructor(
4747
setWillNotDraw(value == null)
4848
}
4949

50-
override fun onDraw(canvas: Canvas?) {
50+
override fun onDraw(canvas: Canvas) {
5151
_substance?.draw(canvas)
5252
}
5353
}

Motion/build.gradle

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -15,14 +15,14 @@
1515
*/
1616

1717
buildscript {
18-
ext.kotlin_version = '1.6.21'
19-
ext.navigation_version = '2.4.2'
18+
ext.kotlin_version = '1.9.22'
19+
ext.navigation_version = '2.7.7'
2020
repositories {
2121
google()
2222
mavenCentral()
2323
}
2424
dependencies {
25-
classpath 'com.android.tools.build:gradle:7.3.0'
25+
classpath 'com.android.tools.build:gradle:8.2.2'
2626
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
2727
classpath "androidx.navigation:navigation-safe-args-gradle-plugin:$navigation_version"
2828
}
Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
1-
#Wed Oct 28 16:25:10 JST 2020
1+
#Fri Feb 16 14:02:28 JST 2024
22
distributionBase=GRADLE_USER_HOME
33
distributionPath=wrapper/dists
4+
distributionUrl=https\://services.gradle.org/distributions/gradle-8.2-bin.zip
45
zipStoreBase=GRADLE_USER_HOME
56
zipStorePath=wrapper/dists
6-
distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip

0 commit comments

Comments
 (0)