2013-07-03 127 views
2

我正在運行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 
+0

[發佈後釋放()異常無法使用安卓相機恢復後調用的方法的可能的重複](http://stackoverflow.com/questions/8868732/method-called-after-re- elease-exception-unable-to-resume- with-android-camera) – Simon

回答

3

看來,你的活動被調用,而你釋放相機 - 這是件好事。但是,你永遠不會重新初始化它。

Android開發人員指南有this exact example

基本上,你需要做這樣的事情:

@Override 
protected void onPause() { 
    super.onPause(); 

    if (camera != null) { 
     camera.release(); 
     camera = null; 
    } 
} 

@Override 
protected void onResume() { 
    super.onResume(); 

    if (camera == null) { 
     initializeCamera(); 
    } 
} 

然後你把所有的相機初始化代碼從onCreate到一個新的initializeCamera方法。

請注意,您不應該在onCreate中初始化攝像頭,因爲它在onResume中完成(即使在第一次加載時也會調​​用該攝像頭)。

+0

謝謝你,亞當!這工作完美!沒有更多的崩潰! :) – skatalite

+0

我知道這是舊的,但如果預覽是在一個片段上呢? –

+0

我_assume_(沒有看任何代碼),這將直接插入片段'onPause' /'onResume'方法。看看這個答案,它看起來像提問者編輯他們的問題,以刪除他們的示例代碼。對任何未來的觀衆來說,坦白地說這毫無幫助(特別是考慮到答案取決於這個背景),所以我會把它推回去。 –

相關問題