首页 文章

ObjectAnimator生成NotFoundException

提问于
浏览
0

我正在编写一个应用程序,通过ObjectAnimator为其设置Drawable资源ID数组来动画各种ImageView .

这是我提取的示例代码,以突出显示问题:

public class MainActivity extends AppCompatActivity {

     private final int[] drawableIDs = new int[] 
        {R.drawable.ic_launcher_background};

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

    }

    public void startNow(View view) {
        ImageView iView = findViewById(R.id.image);
        Animator animator = ObjectAnimator.ofInt(iView, "imageResource", drawableIDs);
        animator.start();
    }

和布局:

<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/main_layout"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/txt"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        android:layout_centerInParent="true"
    />

    <ImageView
        android:id="@+id/image"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@id/txt"
        android:src="@android:drawable/btn_radio"/>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Go!"
        android:id="@+id/btn_go"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:onClick="startNow"/>
</RelativeLayout>

我得到以下例外 .

W/PropertyValuesHolder: Method getImageResource() with type null not found on target class class android.support.v7.widget.AppCompatImageView
I/Choreographer: Skipped 1207 frames!  The application may be doing too much work on its main thread.
W/ResourceType: Failure getting entry for 0x01d5540e (t=212 e=21518) (error -2147483647)
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
    Process: org.spoofer.animatortest, PID: 25686
    **android.content.res.Resources$NotFoundException: Resource ID #0x1d5540e**
        at android.content.res.ResourcesImpl.getValue(ResourcesImpl.java:204)
        at android.content.res.Resources.getValue(Resources.java:1315)
        at android.support.v7.widget.AppCompatDrawableManager.createDrawableIfNeeded(AppCompatDrawableManager.java:235)
        at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:200)
        at android.support.v7.widget.AppCompatDrawableManager.getDrawable(AppCompatDrawableManager.java:191)
        at android.support.v7.content.res.AppCompatResources.getDrawable(AppCompatResources.java:102)
        at android.support.v7.widget.AppCompatImageHelper.setImageResource(AppCompatImageHelper.java:86)
        at android.support.v7.widget.AppCompatImageView.setImageResource(AppCompatImageView.java:94)
        at android.animation.PropertyValuesHolder.nCallIntMethod(Native Method)
        at android.animation.PropertyValuesHolder.-wrap7(Unknown Source:0)
        at android.animation.PropertyValuesHolder$IntPropertyValuesHolder.setAnimatedValue(PropertyValuesHolder.java:1240)
        at android.animation.ObjectAnimator.animateValue(ObjectAnimator.java:990)
        at android.animation.ValueAnimator.animateBasedOnTime(ValueAnimator.java:1316)
        at android.animation.ValueAnimator.doAnimationFrame(ValueAnimator.java:1446)
        at android.animation.AnimationHandler.doAnimationFrame(AnimationHandler.java:146)
        at android.animation.AnimationHandler.-wrap2(Unknown Source:0)
        at android.animation.AnimationHandler$1.doFrame(AnimationHandler.java:54)
        at android.view.Choreographer$CallbackRecord.run(Choreographer.java:964)
        at android.view.Choreographer.doCallbacks(Choreographer.java:778)
        at android.view.Choreographer.doFrame(Choreographer.java:710)
        at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:952)
        at android.os.Handler.handleCallback(Handler.java:789)
        at android.os.Handler.dispatchMessage(Handler.java:98)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6798)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
D/OSTracker: OS Event: crash
Disconnected from the target VM, address: 'localhost:8601', transport: 'socket'

它找不到的资源“#0x1d5540e”不是ObjectAnimator上可绘制集的资源ID . 我不知道这个ID来自哪里 .

奇怪的是,如果我使资源ID数组大于1,它不会抛出异常:

private final int[] drawableIDs = new int[]{R.drawable.ic_launcher_background, R.drawable.ic_launcher_foreground};

Update: 它's thrown only when the given int array has a single element. Reading ObjectAnimator/ValueAnimator docs, I'期望它可以使用一个值,但也许我错了 .

任何想法是什么会导致这个?

提前致谢

1 回答

  • 0

    那是因为 imageView 没有imageResource的公共getter . 您可以使用 drawable 数组来尝试它,并使用 drawable 作为动画属性 .

相关问题