我正在運行eclipse並誠實地教導自己瞭解android編程的基礎知識。我想我會開始一個簡單的手電筒應用程序,所以我可以更好地瞭解這是如何工作的。該應用程序本身工作正常,並啓動相機閃光燈。應用程序在關閉/重新打開時崩潰,然後按下按鈕
我的問題是,當我按主頁按鈕,然後回到應用程序,然後按下按鈕打開手電筒,應用程序崩潰。我一直在閱讀很多,我猜這是因爲我沒有「onResume」,但我可能是錯的。任何幫助是極大的讚賞。
import android.app.Activity;
import android.content.Context;
import android.content.pm.PackageManager;
import android.hardware.Camera;
import android.hardware.Camera.Parameters;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import com.pmm.lettherebe.R;
public class MainActivity extends Activity {
//flag to detect flash is on or off
private boolean isLighOn = false;
private Camera camera;
private Button button;
@Override
protected void onPause() {
super.onPause();
if (camera != null) {
camera.release();;
}
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.buttonFlashlight);
Context context = this;
PackageManager pm = context.getPackageManager();
// if device support camera?
if (!pm.hasSystemFeature(PackageManager.FEATURE_CAMERA)) {
Log.e("err", "Device has no camera!");
return;
}
camera = Camera.open();
final Parameters p = camera.getParameters();
button.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
if (isLighOn) {
Log.i("info", "torch is turn off!");
p.setFlashMode(Parameters.FLASH_MODE_OFF);
camera.setParameters(p);
camera.stopPreview();
isLighOn = false;
} else {
Log.i("info", "torch is turn on!");
p.setFlashMode(Parameters.FLASH_MODE_TORCH);
camera.setParameters(p);
camera.startPreview();
isLighOn = true;
}
}
});
}
}
這裏是logcat的錯誤:
07-02 20:32:19.680: D/OpenGLRenderer(14897): Enabling debug mode 0 07-02 20:32:21.121: I/info(14897): torch is turn on! 07-02 20:32:22.553: I/info(14897): torch is turn off! 07-02 20:32:23.363: I/info(14897): torch is turn on! 07-02 20:32:23.964: I/info(14897): torch is turn off! 07-02 20:32:29.090: I/info(14897): torch is turn on! 07-02 20:32:29.090: D/AndroidRuntime(14897): Shutting down VM 07-02 20:32:29.090: W/dalvikvm(14897): threadid=1: thread exiting withuncaught exception (group=0x41b46930) 07-02 20:32:29.090: E/AndroidRuntime(14897): FATAL EXCEPTION: main 07-02 20:32:29.090: E/AndroidRuntime(14897): java.lang.RuntimeException: Method alled after release() 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.hardware.Camera.native_setParameters(Native Method) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.hardware.Camera.setParameters(Camera.java:1496) 07-02 20:32:29.090: E/AndroidRuntime(14897): at com.pmm.lettherebe.MainActivity$1.onClick(MainActivity.java:74) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.view.View.performClick(View.java:4204) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.view.View$PerformClick.run(View.java:17355) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.os.Handler.handleCallback(Handler.java:725) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.os.Handler.dispatchMessage(Handler.java:92) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.os.Looper.loop(Looper.java:137) 07-02 20:32:29.090: E/AndroidRuntime(14897): at android.app.ActivityThread.main(ActivityThread.java:5195) 07-02 20:32:29.090: E/AndroidRuntime(14897): at java.lang.reflect.Method.invokeNative(Native Method) 07-02 20:32:29.090: E/AndroidRuntime(14897): at java.lang.reflect.Method.invoke(Method.java:511) 07-02 20:32:29.090: E/AndroidRuntime(14897): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795) 07-02 20:32:29.090: E/AndroidRuntime(14897): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562) 07-02 20:32:29.090: E/AndroidRuntime(14897): at dalvik.system.NativeStart.main(Native Method) 07-02 20:32:31.222: I/Process(14897): Sending signal. PID: 14897 SIG: 9
[發佈後釋放()異常無法使用安卓相機恢復後調用的方法的可能的重複](http://stackoverflow.com/questions/8868732/method-called-after-re- elease-exception-unable-to-resume- with-android-camera) – Simon