仅在某些设备上用于动画的 NullPointerException
NullPointerException for Animation on some devices only
某些设备在启动此应用程序时抛出 NullPointerException,但其他设备似乎运行良好。我似乎无法弄清楚该怎么做,因为 ivMonkeyStart
错误引用不为空。我已经尝试了不同的设置方式 ivMonkeyStart
但还没有找到有影响的方式...
public class MainActivity extends Activity {
ImageView ivMonkeyStart;
Context context;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ivMonkeyStart = (ImageView)findViewById(R.id.ivMonkeyStart);
final Animation startMonkeyScaleIn = AnimationUtils.loadAnimation(getApplicationContext(), R.anim.start_scale);
final Animation startMonkeyPulse = AnimationUtils.loadAnimation(this, R.anim.start_pulse);
ivMonkeyStart.startAnimation(startMonkeyScaleIn);
startMonkeyScaleIn.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
ivMonkeyStart.startAnimation(startMonkeyPulse);
}
@Override
public void onAnimationRepeat(Animation animation) {
}
});
ivMonkeyStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
FlurryAgent.logEvent("Clicked Start");
Intent myIntent = new Intent(MainActivity.this, GuessActivity.class);
MainActivity.this.startActivity(myIntent);
}
});
}
这是日志:
01-01 22:59:56.658 2188-2188/com.zdkapps.guesszoo E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: com.zdkapps.guesszoo, PID: 2188
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.zdkapps.guesszoo/com.zdkapps.guesszoo.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ImageView.startAnimation(android.view.animation.Animation)' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
at android.app.ActivityThread.access0(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ImageView.startAnimation(android.view.animation.Animation)' on a null object reference
at com.zdkapps.guesszoo.MainActivity.onCreate(MainActivity.java:49)
at android.app.Activity.performCreate(Activity.java:5933)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
at android.app.ActivityThread.access0(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
错误引用了这一行:
ivMonkeyStart.startAnimation(startMonkeyScaleIn);
有什么想法吗?谢谢!
从 question/answer 机制的评论中复制:
这些设备是什么?有什么具体的区别吗?也许您有两种布局,一种带有 ivMonkeyStart ImageView,另一种没有,而这些设备采用第二种布局?
某些设备在启动此应用程序时抛出 NullPointerException,但其他设备似乎运行良好。我似乎无法弄清楚该怎么做,因为 ivMonkeyStart
错误引用不为空。我已经尝试了不同的设置方式 ivMonkeyStart
但还没有找到有影响的方式...
public class MainActivity extends Activity {
ImageView ivMonkeyStart;
Context context;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ivMonkeyStart = (ImageView)findViewById(R.id.ivMonkeyStart);
final Animation startMonkeyScaleIn = AnimationUtils.loadAnimation(getApplicationContext(), R.anim.start_scale);
final Animation startMonkeyPulse = AnimationUtils.loadAnimation(this, R.anim.start_pulse);
ivMonkeyStart.startAnimation(startMonkeyScaleIn);
startMonkeyScaleIn.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
ivMonkeyStart.startAnimation(startMonkeyPulse);
}
@Override
public void onAnimationRepeat(Animation animation) {
}
});
ivMonkeyStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
FlurryAgent.logEvent("Clicked Start");
Intent myIntent = new Intent(MainActivity.this, GuessActivity.class);
MainActivity.this.startActivity(myIntent);
}
});
}
这是日志:
01-01 22:59:56.658 2188-2188/com.zdkapps.guesszoo E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: com.zdkapps.guesszoo, PID: 2188
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.zdkapps.guesszoo/com.zdkapps.guesszoo.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ImageView.startAnimation(android.view.animation.Animation)' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
at android.app.ActivityThread.access0(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ImageView.startAnimation(android.view.animation.Animation)' on a null object reference
at com.zdkapps.guesszoo.MainActivity.onCreate(MainActivity.java:49)
at android.app.Activity.performCreate(Activity.java:5933)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
at android.app.ActivityThread.access0(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
错误引用了这一行:
ivMonkeyStart.startAnimation(startMonkeyScaleIn);
有什么想法吗?谢谢!
从 question/answer 机制的评论中复制:
这些设备是什么?有什么具体的区别吗?也许您有两种布局,一种带有 ivMonkeyStart ImageView,另一种没有,而这些设备采用第二种布局?