È possibile farlo con ScaleAnimations
impostato su ViewFlipper
. Faccio una cosa simile senza la seconda scala. Ho due animazioni, una per la vista in uscita e una per la vista in arrivo. Le posterò qui come punto di partenza per te.
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>
Poi in app li ho impostato il ViewFlipper
in questo modo:
mViewFlipper.setInAnimation(context, R.anim.grow_from_middle);
mViewFlipper.setOutAnimation(context, R.anim.shrink_to_middle);
Come ho detto, questo non è esattamente quello che hai descritto, ma è molto vicino e ti consentirà di iniziare.
--EDIT--
Ecco il codice utilizzando il pivotX e pivotY (beh, basta pivotY nel mio 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" />
Grazie per il puntatore. Sicuramente un buon antipasto. Invece di usare un'altra animazione - translate, ho fatto un pivotX = 50%, pivotY = 50% e alcune altre modifiche. Grazie per l'antipasto però –
Bello! Grazie per il suggerimento sul pivotX, in modo pivot! – CaseyB
ti preghiamo di fornire il codice usando pivotX, pivotY – gypsicoder