我是 Android 开发和 StackOverflow 的初学者,所以如果我踩到任何脚趾,请不要向我开枪!我正在尝试让一个简单的应用程序工作,其中用户按下按钮并在按住按钮时显示整数增量,并且在释放按钮时按钮保持原样。开创性的东西!
所以我采用了以下方法:
public class MainActivity extends Activity {
Button pushBtn;
TextView textView,inc_txt;
String TAG ="Button Act";
int inc_val =0;
public Handler myHandler=null;
boolean finishedThread = false;
boolean threadRunning = false;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.i(TAG, "in onCreate");
}
@Override
protected void onStart() {
// TODO Auto-generated method stub
super.onStart();
Log.i(TAG, "in onStart");
pushBtn=(Button)findViewById(R.id.Btn_Push);
Log.i(TAG, "in onStart 1");
textView=(TextView)findViewById(R.id.testText);
inc_txt=(TextView)findViewById(R.id.increment_text);
pushBtn.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent Button_event) {
Log.i(TAG, "in onTouch Event");
switch (Button_event.getAction()) {
case MotionEvent.ACTION_DOWN:
Log.i(TAG, " ..Down");
textView.setText("Button Down");
if(myHandler!=null)
{
Log.i(TAG, "Handle was not null");
return true;
}
myHandler=new Handler();
Log.i(TAG, "postingAction Original");
myHandler.postDelayed(pushedAction, 250);
return true;
case MotionEvent.ACTION_UP:
textView.setText("Button Up");
myHandler.removeCallbacks(pushedAction);
myHandler=null;
return true;
default:
textView.setText("Default");
myHandler=null;
break;
}
return false;
}
});
Log.i(TAG, "in onStart 3");
}
Runnable pushedAction= new Runnable() {
@Override
public void run() {
inc_txt.setText(Integer.toString(inc_val));
inc_val++;
Log.i(TAG, "postingAction Repeat");
myHandler.postDelayed(this, 250);
// TODO Auto-generated method stub
}
};
快乐的日子,这适用于 AVD (4.2.2)。(它只是一个 Button 和两个 TextViews)
但是当我把它放到我的 Nexus 4(4.3)上时,原来的 postDelayed(在“onStart”中)工作正常,但是第二个 postDelayed,runnable 本身中的递归调用会引发空指针异常。
查看日志猫:
08-08 10:08:14.245: I/Button Act(19992): 在 onTouch 事件中 08-08 10:08:14.245: I/Button Act(19992): ..Down 08-08 10:08:14.245: I /Button Act(19992):postingAction Original 08-08 10:08:14.275:I/Button Act(19992):在 onTouch 事件中 08-08 10:08:14.385:I/Button Act(19992):在 onTouch 事件中 08 -08 10:08:14.405: I/Button Act(19992): 在 onTouch 事件中 08-08 10:08:14.425: I/Button Act(19992): 在 onTouch 事件中 08-08 10:08:14.495: I/按钮动作(19992):postingAction 重复08-08 10:08:14.495:D/AndroidRuntime(19992):关闭 VM 08-08 10:08:14.495:W/dalvikvm(19992):threadid=1:线程退出未捕获的异常 (group=0x4152c700) 08-08 10:08:14.495: E/AndroidRuntime(19992):致命异常: main 08-08 10:08:14.495: E/AndroidRuntime(19992):java.lang.NullPointerException08-08 10:08:14.495: E/AndroidRuntime(19992): 在 com.example.buttonexperiments.MainActivity$1.run(MainActivity.java:94) 08-08 10:08:14.495: E/AndroidRuntime(19992):在 android.os.Handler.handleCallback(Handler.java:730) 08-08 10:08:14.495: E/AndroidRuntime(19992): 在 android.os.Handler.dispatchMessage(Handler.java:92) 08-08 10 :08:14.495: E/AndroidRuntime(19992): 在 android.os.Looper.loop(Looper.java:137) 08-08 10:08:14.495: E/AndroidRuntime(19992): 在 android.app.ActivityThread。 main(ActivityThread.java:5103) 08-08 10:08:14.495: E/AndroidRuntime(19992): at java.lang.reflect.Method.invokeNative(Native Method) 08-08 10:08:14.495: E/AndroidRuntime (19992): 在 java.lang.reflect.Method.invoke(Method.java:525) 08-08 10:08:14.495: E/AndroidRuntime(19992): 在 com.android.internal.os。ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 08-08 10:08:14.495: E/AndroidRuntime(19992): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 08-08 10:08:14.495:E/AndroidRuntime(19992):在 dalvik.system.NativeStart.main(本机方法)
谁能看到我做错了什么?所有帮助表示赞赏。对不起,如果我把这个问题弄得一团糟(The LogCat ..我知道)!安全旅行 !