Puede hacerlo con ScaleAnimations
en un ViewFlipper
. Hago algo similar sin la segunda escala. Tengo dos animaciones, una para que salga la vista y otra para que entre la vista. Las publicaré aquí como punto de partida para ti.
shrink_to_middle.xml
<set xmlns:android="http://schemas.android.com/apk/res/android">
<scale
android:interpolator="@android:anim/linear_interpolator"
android:fromXScale="1.0"
android:toXScale="1.0"
android:fromYScale="1.0"
android:toYScale="0.0"
android:fillAfter="false"
android:duration="200" />
<translate
android:fromYDelta="0"
android:toYDelta="50%"
android:duration="200"/>
</set>
grow_from_middle.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<scale
android:interpolator="@android:anim/linear_interpolator"
android:fromXScale="1.0"
android:toXScale="1.0"
android:fromYScale="0.0"
android:toYScale="1.0"
android:fillAfter="false"
android:startOffset="200"
android:duration="200" />
<translate
android:fromYDelta="50%"
android:toYDelta="0"
android:startOffset="200"
android:duration="200"/>
</set>
Luego, en la aplicación que les establece en el ViewFlipper
así:
mViewFlipper.setInAnimation(context, R.anim.grow_from_middle);
mViewFlipper.setOutAnimation(context, R.anim.shrink_to_middle);
Como dije, esto no es exactamente lo que usted describió, pero es bastante cercano y lo ayudará a comenzar.
--EDIT--
Este es el código utilizando el PivotX y pivotY (bueno, sólo pivotY en mi caso):
shrink_to_middle.xml
<?xml version="1.0" encoding="utf-8"?>
<scale
xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/linear_interpolator"
android:fromXScale="1.0"
android:toXScale="1.0"
android:fromYScale="1.0"
android:toYScale="0.0"
android:pivotY="50%"
android:fillAfter="false"
android:duration="200" />
grow_from_middle.xml
<?xml version="1.0" encoding="utf-8"?>
<scale
xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/linear_interpolator"
android:fromXScale="1.0"
android:toXScale="1.0"
android:fromYScale="0.0"
android:toYScale="1.0"
android:pivotY="50%"
android:fillAfter="false"
android:startOffset="200"
android:duration="200" />
Gracias por el puntero. Definitivamente un buen principiante. En lugar de usar otra animación - traducir, hice un pivotX = 50%, pivotY = 50% y algunos otros cambios. Gracias por empezar aunque –
¡Agradable! Gracias por el consejo sobre el pivotX, pivotY! – CaseyB
¿Podría dar el código usando pivotX, pivotY – gypsicoder