Общие элементы работают не так, как должны (странное поведение)

#android #kotlin #transition

Вопрос:

Очевидно, я делаю все шаги правильно, но переход работает неправильно.

Я открыл новый очень простой проект, в котором всего два действия, в макете MainActivity у меня есть изображение с центром, а во втором действии у меня такое же изображение, но больше

Происходит следующее:

Когда я открываю приложение и нажимаю на изображение, оно открывает вторую активность, но без перехода, теперь все еще во второй активности, когда я нажимаю кнопку «Назад», оно возвращается к основной активности, но все еще без перехода. И с этого момента, когда я нажимаю на ImageView, SecondActivity больше не открывается, однако, когда я сворачиваю приложение (при прохождении через onPause) и возвращаюсь, SecondActivity открыта, и когда я нажимаю кнопку «Назад», «обратный переход» происходит правильно.

activity_main.xml

 <?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <ImageView
        android:id="@ id/menu_image_view"
        android:layout_width="200dp"
        android:layout_height="300dp"
        android:clickable="true"
        android:focusable="true"
        android:scaleType="centerCrop"
        android:src="@drawable/cardapio"
        android:transitionName="image"

        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>
 

Основная активность.тыс. т

 class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val menuImageView = findViewById<ImageView>(R.id.menu_image_view)
        menuImageView.transitionName = "image"

        val i = Intent(this, SecondActivity::class.java)

        val options: Bundle? = ActivityOptionsCompat.makeSceneTransitionAnimation(
            this, menuImageView, "image"
        ).toBundle()

        menuImageView.setOnClickListener {
            startActivity(i, options)
        }
    }
}
 

activity_second.xml

 <?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".SecondActivity">

    <ImageView
        android:layout_width="400dp"
        android:layout_height="600dp"
        android:scaleType="centerCrop"
        android:src="@drawable/cardapio"
        android:transitionName="image"

        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>
 

Вторая активность.тыс. т

 class SecondActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_second)
    }

    override fun onBackPressed() {
        // To support reverse transitions when user clicks the device back button
        supportFinishAfterTransition()
    }
}
 

И мой themes.xml:

 <resources xmlns:tools="http://schemas.android.com/tools">
    <!-- Base application theme. -->
    <style name="Theme.Animations" parent="Theme.MaterialComponents.DayNight.NoActionBar">
        <!-- Primary brand color. -->
        <item name="colorPrimary">@color/purple_500</item>
        <item name="colorPrimaryVariant">@color/purple_700</item>
        <item name="colorOnPrimary">@color/white</item>
        <!-- Secondary brand color. -->
        <item name="colorSecondary">@color/teal_200</item>
        <item name="colorSecondaryVariant">@color/teal_700</item>
        <item name="colorOnSecondary">@color/black</item>
        <!-- Status bar color. -->
        <item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>
        <!-- Customize your theme here. -->
        <item name="android:windowActivityTransitions">true</item>
    </style>
</resources>
 

Я уже пробовал использовать и то
<item name="android:windowActivityTransitions">true</item>
и другое
<item name="android:windowContentTransitions">true</item>

Может ли это быть ошибка в студии Android?

Комментарии:

1. Вы пробовали положить i и options внутрь setOnClickListener ?

2. @TicherhazFreePalestine Я чувствую себя сейчас совершенно глупо, ахаха! Это сработало, не могли бы вы объяснить мне, почему? Теперь мне любопытно

3. Вы можете проверить ответ.

Ответ №1:

Вы должны быть с ними внутри onClickListener . Если вы поместите его внутрь onCreate , он создаст его, как только действие будет создано. Когда вы свернете приложения, onPaused будут запущены только они.

     menuImageView.setOnClickListener {
        val i = Intent(this, SecondActivity::class.java)

        val options: Bundle? = ActivityOptionsCompat.makeSceneTransitionAnimation(
        this, menuImageView, "image"
        ).toBundle()
        startActivity(i, options)
    }