【问题标题】:expand/collapse Animation Android half view展开/折叠动画 Android 半视图
【发布时间】:2019-04-09 15:14:44
【问题描述】:

我想展开/折叠一个 ImageView,但从 50% 图片开始以 100% 展开,折叠到 50% 不低于。

我已经看了一些关于 SO 的热门问题和答案,但我没有找到如何管理只有一半。我还想修改视图的高度,而不是宽度。

我尝试了什么:

public static void expand(final View v) {
    v.measure(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
    final int targtetHeight = v.getMeasuredHeight();

    v.getLayoutParams().height = 0;
    v.setVisibility(View.VISIBLE);
    Animation a = new Animation()
    {
        @Override
        protected void applyTransformation(float interpolatedTime, Transformation t) {
            v.getLayoutParams().height = interpolatedTime == 1
                    ? ViewGroup.LayoutParams.WRAP_CONTENT
                    : (int)(targtetHeight * interpolatedTime);
            v.requestLayout();
        }

        @Override
        public boolean willChangeBounds() {
            return true;
        }
    };

    a.setDuration((int)(targtetHeight / v.getContext().getResources().getDisplayMetrics().density));
    v.startAnimation(a);
}

public static void collapse(final View v) {
    final int initialHeight = v.getMeasuredHeight();

    Animation a = new Animation() {
        @Override
        protected void applyTransformation(float interpolatedTime, Transformation t) {
            if (interpolatedTime == 1) {
                v.setVisibility(View.VISIBLE);
            } else {
                v.getLayoutParams().height = initialHeight - (int) (initialHeight * interpolatedTime);
                v.requestLayout();
            }
        }

        @Override
        public boolean willChangeBounds() {
            return true;
        }
    };

    a.setDuration((int) (initialHeight / v.getContext().getResources().getDisplayMetrics().density));
    v.startAnimation(a);
}

正如我所说,这不是我想要的,因为它会完全消失并且会改变宽度。

我也试过这个 sn-p 但没有动画:

mImageDrawable = (ClipDrawable) pic.getDrawable();
mImageDrawable.setLevel(5000);//use set level to expand or collapse manually but no animation.

剪辑:

    <?xml version="1.0" encoding="utf-8"?>
<clip xmlns:android="http://schemas.android.com/apk/res/android"
    android:clipOrientation="vertical"
    android:drawable="@drawable/test_pic"
    android:gravity="top" />

【问题讨论】:

    标签: android animation android-animation


    【解决方案1】:

    使用支持包 (androidx) 中提供的转换 API。只需致电TransitionManager.beginDelayedTransition,然后更改视图高度。 TransitionManager 将处理此更改,并将提供过渡,该过渡将使用动画更改 imageView。

    scaleType of ImageView 这里是centerCrop 这就是为什么图像在折叠和展开时会缩放。不幸的是没有“填充宽度和裁剪底部”scaleType,所以如果你需要它我认为可以通过scaleType = matrix 来完成。

    import androidx.appcompat.app.AppCompatActivity;
    import androidx.transition.TransitionManager;
    
    public class MainActivity extends AppCompatActivity {
    
      private ImageView image;
      private ViewGroup parent;
      boolean collapse = true;
    
      @Override
      protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    
        image = findViewById(R.id.image);
        parent = findViewById(R.id.parent);
    
        findViewById(R.id.btn).setOnClickListener(view -> {
            collapse = !collapse;
            collapse();
        });
      }
    
      private void collapse() {
        TransitionManager.beginDelayedTransition(parent);
        //change layout params
        int height = image.getHeight();
        LayoutParams layoutParams = image.getLayoutParams();
        layoutParams.height = !collapse ? height / 2 : height * 2;
        image.requestLayout();
      }
    }
    

    布局:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/parent"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    
    <Button
        android:id="@+id/btn"
        android:text="start"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    
    <ImageView
        android:id="@+id/image"
        android:layout_width="match_parent"
        android:layout_height="300dp"
        android:scaleType="centerCrop"
        android:src="@drawable/qwe" />
    
    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="random text"
        android:layout_margin="8dp"/>
    </LinearLayout>
    

    更新:

    beginDelayedTransition(ViewGroup, Transtion) 方法。 beginDelayedTransition(ViewGroup) 默认使用 AutoTransition 作为过渡。 因此,如果您需要处理转换的开始/结束,您可以这样做:

        AutoTransition transition = new AutoTransition();
        transition.addListener(new TransitionListenerAdapter(){
            @Override
            public void onTransitionStart(@NonNull Transition transition) {
                //TODO
            }
            @Override
            public void onTransitionEnd(@NonNull Transition transition) {
                //TODO 
            }
        });
        TransitionManager.beginDelayedTransition(parent, transition);
    

    【讨论】:

    • 我也想要这个比例效果!所以你的代码也能正常工作,这正是我想要的! :)
    • 我还有一个与此过渡有关的问题。我怎么知道动画/过渡何时完成?过渡/动画完成后,我需要做一些事情。
    • 工作就像一个魅力!感谢您这么快更新您的答案!
    猜你喜欢
    • 1970-01-01
    • 2017-03-09
    • 1970-01-01
    • 2015-07-18
    • 1970-01-01
    • 1970-01-01
    • 2014-05-03
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多