ImageButton的onClick强制关闭,无法弄清原因

7

我正在尝试使用ImageButtons创建简单的动画效果,当我设置屏幕触摸即可触发时,它可以正常工作,但如果我尝试使用onClick来触发,应用程序会突然关闭。

Main.xml

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:gravity="center_horizontal">
       <ImageButton
        android:id="@+id/plus1"
        android:layout_width="75dp"
        android:layout_height="75dp"
        android:layout_alignParentBottom="true"
        android:layout_alignParentRight="true"
        android:background="@null"
        android:src="@drawable/plus"
        android:visibility="visible" 
        android:gravity="center_horizontal"
        android:onClick="RunAnimations" 
        />

    <ImageButton
        android:id="@+id/gears1"
        android:layout_width="75dp"
        android:layout_height="75dp"
        android:layout_alignParentBottom="true"
        android:layout_alignParentRight="true"
        android:background="@null"
        android:gravity="center_horizontal"
        android:src="@drawable/gears"
        android:textSize="42sp" />
    </LinearLayout>

translate.xml

<?xml version="1.0" encoding="utf-8"?>
<set>
<translate
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromYDelta="-100%"
    android:toYDelta="0%"
    android:duration="1000"
    android:zAdjustment="top" >
</translate>

<alpha
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromAlpha="0.0"
    android:toAlpha="1.0"
    android:duration="1000">
</alpha>
</set>

主活动:

    public class AnimationtestActivity extends Activity  {
        /** 当活动被创建时调用 */
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
        }
        private void RunAnimations() {
            Animation a = AnimationUtils.loadAnimation(this, R.anim.translate);
            View ib = findViewById(R.id.gears1);
            ib.clearAnimation(); 
            ib.startAnimation(a);     
        }
    }

编辑:

我修复了private void RunAnimations(View view)

但它仍然强制关闭

编辑2:logcat的内容

03-08 13:07:33.968: E/AndroidRuntime(29270): FATAL EXCEPTION: main
03-08 13:07:33.968: E/AndroidRuntime(29270): java.lang.IllegalStateException: Could not find a method RunAnimations(View) in the activity class com.test.AnimationtestActivity for onClick handler on view class android.widget.ImageButton with id 'plus1'
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.view.View$1.onClick(View.java:3026)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.view.View.performClick(View.java:3480)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.view.View$PerformClick.run(View.java:13983)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.os.Handler.handleCallback(Handler.java:605)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.os.Handler.dispatchMessage(Handler.java:92)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.os.Looper.loop(Looper.java:137)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.app.ActivityThread.main(ActivityThread.java:4340)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at java.lang.reflect.Method.invokeNative(Native Method)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at java.lang.reflect.Method.invoke(Method.java:511)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at dalvik.system.NativeStart.main(Native Method)
03-08 13:07:33.968: E/AndroidRuntime(29270): Caused by: java.lang.NoSuchMethodException: RunAnimations [class android.view.View]
03-08 13:07:33.968: E/AndroidRuntime(29270):    at java.lang.Class.getConstructorOrMethod(Class.java:460)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at java.lang.Class.getMethod(Class.java:915)
03-08 13:07:33.968: E/AndroidRuntime(29270):    at android.view.View$1.onClick(View.java:3019)
03-08 13:07:33.968: E/AndroidRuntime(29270):    ... 11 more

请检查您的方法。在第二行中,您试图将ImageButton强制转换为View。 - Chirag Bhuva
1个回答

3

框架没有找到您的点击处理程序方法,因为它的签名不正确。请按照以下方式声明:

public void RunAnimations(View view) {
    . . .
}

1
我修复了,但它仍然给我一个强制关闭。还有其他的想法吗? - Lucas
1
你遇到了什么异常?能否请您发布日志? - arjoan
1
我已经在问题中发布了logcat,感谢迄今为止的帮助。 - Lucas
1
@LucasMarcelli - 你还需要将方法签名更改为“public”。 - Ted Hopp
1
@TedHopp 天啊,我现在感觉像个白痴。我甚至没有注意到我将其设置为私有。非常感谢,现在它可以工作了。但愿我有足够的声望给你一个赞... - Lucas

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接