Используйте Transition API, который доступен в пакете поддержки (androidx). Просто позвоните TransitionManager.beginDelayedTransition
и измените высоту обзора. TransitionManager
обработает эти изменения и обеспечит переход, который изменит imageView с анимацией.
![enter image description here](https://i.stack.imgur.com/EvXvU.gif)
scaleType
из 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>
UPDATE:
Существует 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);