Как я могу масштабировать textView внутри родительского представления с помощью макета движения?

Я пытаюсь масштабировать textView внутри представления контейнера. В Activity используется макет движения. Я могу масштабировать textView, если не помещаю его в контейнер. Вот мой макет действия и файл описания макета движения. Как заставить работать scaleX и scaleY?

Схема занятий

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.motion.MotionLayout xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/motionLayout"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layoutDescription="@xml/motion_scene_text_size">

    <View
        android:id="@+id/button"
        android:layout_width="64dp"
        android:layout_height="64dp"
        android:background="@color/colorAccent"
        android:text="Button" />

    <android.support.constraint.ConstraintLayout
        android:id="@+id/container"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_marginTop="100dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <TextView
            android:id="@+id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="TextView"
            android:textSize="20sp"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

    </android.support.constraint.ConstraintLayout>

</android.support.constraint.motion.MotionLayout>

Сцена движения

<?xml version="1.0" encoding="utf-8"?>
<MotionScene xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:motion="http://schemas.android.com/apk/res-auto">

    <Transition
        motion:constraintSetStart="@+id/start"
        motion:constraintSetEnd="@+id/end"
        motion:duration="1000">
        <OnSwipe
            motion:touchAnchorId="@+id/button"
            motion:touchAnchorSide="right"
            motion:dragDirection="dragRight" />
    </Transition>

    <ConstraintSet android:id="@+id/start">
        <Constraint
            android:id="@id/button"
            android:layout_width="64dp"
            android:layout_height="64dp"
            android:layout_marginStart="8dp"
            motion:layout_constraintBottom_toBottomOf="parent"
            motion:layout_constraintStart_toStartOf="parent"
            motion:layout_constraintTop_toTopOf="parent" />

        <Constraint
            android:id="@id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="TextView"
            android:textSize="20sp"
            android:scaleX="1.0"
            android:scaleY="1.0"
            motion:layout_constraintBottom_toBottomOf="parent"
            motion:layout_constraintEnd_toEndOf="parent"
            motion:layout_constraintStart_toStartOf="parent"
            motion:layout_constraintTop_toTopOf="parent" />

    </ConstraintSet>

    <ConstraintSet android:id="@+id/end">
        <Constraint
            android:id="@id/button"
            android:layout_width="64dp"
            android:layout_height="64dp"
            android:layout_marginEnd="8dp"
            motion:layout_constraintBottom_toBottomOf="parent"
            motion:layout_constraintEnd_toEndOf="parent"
            motion:layout_constraintTop_toTopOf="parent" />

        <Constraint
            android:id="@id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="TextView"
            android:textSize="20sp"
            android:scaleX="2.0"
            android:scaleY="2.0"
            motion:layout_constraintBottom_toBottomOf="parent"
            motion:layout_constraintEnd_toEndOf="parent"
            motion:layout_constraintStart_toStartOf="parent"
            motion:layout_constraintTop_toTopOf="parent" />

    </ConstraintSet>

</MotionScene>

person syloc    schedule 03.12.2018    source источник
comment
Я не совсем уверен, что ты хочешь делать. Если вы хотите просто изменить размер TextView, но не размер текста, просто анимируйте ширину и высоту. Если вы хотите переместить размер текста, попробуйте иметь два разных размера текста в вашем наборе ограничений.   -  person RDO    schedule 06.12.2018
comment
Расскажите, пожалуйста, как вы решили эту проблему?   -  person K Pradeep Kumar Reddy    schedule 19.06.2021
comment
@KPradeepKumarReddy Взгляните на MotionLayout.TransitionListener. Просто используйте событие onTransitionChange и делайте все, что хотите, с текущим значением прогресса.   -  person syloc    schedule 20.06.2021
comment
спасибо @syloc, попробовал. Когда мы медленно перетаскиваем экран, анимация выглядит не очень хорошо. Можем ли мы ускорить анимацию макета движения? или Можем ли мы попробовать вложить MotionLayout в MotionLayout для решения этой проблемы вместо использования MotionLayout.TransitionListener?   -  person K Pradeep Kumar Reddy    schedule 20.06.2021
comment
@KPradeepKumarReddy Я не знаю вашего варианта использования, но, возможно, ключевые кадры - это то, что вы ищете. medium.com/google-developers/   -  person syloc    schedule 20.06.2021


Ответы (2)


Стоит отметить, что вы можете анимировать только прямые дочерние элементы MotionLayout.

Если вам нужно использовать этот контейнер, вы можете использовать matchParent для height и width вашего TextView, а затем использовать AutoSizeText.

<MotionLayout
   ...>

   <ConstraintLayout
    android:id="@+id/container"
    ...>

      <TextView
       android:layout_width="matchParent"
       android:layout_height="matchParent"
       app:autoSizeTextType="uniform"
       app:autoSizeMinTextSize="20sp"
       app:autoSizeMaxTextSize="40sp"
       .../>

   </ConstraintLayout>

</MotionLayout>

В MotionScene измените размер ConstraintLayout:

<ConstraintSet android:id="@+id/endConstraintSet">

   <Constraint
    android:id="@id/container"
    android:layout_width="200dp"
    android:layout_height="200dp"
    ... />

</ConstraintSet />
person jossiwolf    schedule 07.12.2018
comment
да. Проблема в том, чтобы не быть прямым ребенком. В итоге я использовал значение motionlayout для выполнения и делал это программно. - person syloc; 10.12.2018
comment
@syloc Можно ли обойтись без ограничения Motion Layout для работы только с его прямыми дочерними элементами. Он не поддерживает вложенные иерархии макетов или переходы действий. - person K Pradeep Kumar Reddy; 19.06.2021

Что сработало для меня, так это установить HEIGHT TextView и TextSize, все вместе для изменения размера, например:

<Transition
    motion:constraintSetEnd="@+id/end"
    motion:constraintSetStart="@+id/start" />

<ConstraintSet android:id="@+id/start">
    <Constraint android:id="@id/titleTextView">
        <Layout
            ........
            android:layout_width="match_parent"
            android:layout_height="32dp"
            .......
            />
        <CustomAttribute
            motion:attributeName="textSize"
            motion:customFloatValue="28" />
    </Constraint>
    ......
</ConstraintSet>

<ConstraintSet android:id="@+id/end">
    <Constraint android:id="@id/titleTextView">
        <Layout
            android:layout_width="match_parent"
            android:layout_height="20dp"
            ..........
        />
        <CustomAttribute
            motion:attributeName="textSize"
            motion:customFloatValue="16" />
    </Constraint>
</ConstraintSet>
person Vitalie Suba    schedule 14.04.2020
comment
Я попытался изменить textSize с помощью CustomAttribute, но этот вариант не работал гладко. Поэтому мне пришлось использовать android: scaleX = ... android: scaleY = ... в ‹Constraint›. - person macros013; 14.05.2020
comment
@ macros013 не могли бы вы опубликовать свое решение? Я уточнил, что нужно обязательно изменить и размер, и высоту. - person Vitalie Suba; 16.05.2020
comment
Я упомянул решение в этом ответе stackoverflow.com/a/61796281/3607032 - person macros013; 18.05.2020