Una possibile soluzione consiste nell'utilizzare un adattatore di rilegatura. Ecco un esempio veloce per mostrarvi la strada da percorrere:
Per prima cosa definire un adattatore personalizzato vincolante:
import android.databinding.BindingAdapter;
import android.support.v4.view.animation.FastOutSlowInInterpolator;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.Interpolator;
import android.view.animation.RotateAnimation;
import android.view.animation.TranslateAnimation;
public class ViewBusyBindings {
private static final Interpolator INTERPOLATOR = new FastOutSlowInInterpolator();
@BindingAdapter("isBusy")
public static void setIsBusy(View view, boolean isBusy) {
Animation animation = view.getAnimation();
if (isBusy && animation == null) {
view.startAnimation(getAnimation());
} else if (animation != null) {
animation.cancel();
view.setAnimation(null);
}
}
private static Animation getAnimation() {
RotateAnimation anim = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
anim.setInterpolator(INTERPOLATOR);
anim.setDuration(1400);
anim.setRepeatCount(TranslateAnimation.INFINITE);
anim.setRepeatMode(TranslateAnimation.RESTART);
return anim;
}
}
Il layout esempio sarà simile a questa:
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<data>
<variable
name="vm"
type="de.example.exampleviewmodel"/>
</data>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<ImageButton
android:id="@+id/btnPlay"
style="?attr/borderlessButtonStyle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="right|bottom"
android:src="@drawable/ic_play_circle_filled_white_36dp"
app:isBusy="@{vm.isBusy}"/>
</FrameLayout>
</layout>
come si può vedi, la proprietà 'isBusy' della tua viododel è legata alla vista (imagebutton). È possibile utilizzare questo adattatore in qualsiasi vista non solo con un pulsante immagine.
Ovviamente, la proprietà 'isBusy' deve essere associabile (ad es. Viewmodel estende BaseObservable o almeno è ObservableBoolean).
Quindi, ogni volta che si modifica la proprietà 'isBusy' su true, verrà avviata l'animazione. Impostalo su falso, si ferma.
Spero che questo aiuti?
fonte
2015-12-28 10:29:24
Si desidera attivare un'animazione se una proprietà viene modificata nella viododel? È questo il significato di "quando cambia il modello di visualizzazione"? –
sì, questo è esattamente quello che intendo. –
Aggiunta risposta con esempio. –