簡體   English   中英

release()錯誤后調用的方法

[英]Method called after release() error

我是android新手。 我想知道為什么當我在模擬器中單擊/按下時,總是不幸的是,cameraActivity已停止。這是我的CameraTestActivity

public class CameraTestActivity extends Activity
{
private Camera mCamera;
private CameraPreview mPreview;
private Handler autoFocusHandler;

TextView scanText;
Button scanButton, btn_next;

ImageScanner scanner;

private boolean barcodeScanned = false;
private boolean previewing = true;

static {
    System.loadLibrary("iconv");
} 

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setContentView(R.layout.main);

    setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);

    autoFocusHandler = new Handler();
    mCamera = getCameraInstance();

    /* Instance barcode scanner */
    scanner = new ImageScanner();
    scanner.setConfig(0, Config.X_DENSITY, 3);
    scanner.setConfig(0, Config.Y_DENSITY, 3);

    mPreview = new CameraPreview(this, mCamera, previewCb, autoFocusCB);
    FrameLayout preview = (FrameLayout)findViewById(R.id.cameraPreview);
    preview.addView(mPreview);

    scanText = (TextView)findViewById(R.id.scanText);

    btn_next = (Button)findViewById(R.id.button1);
    btn_next.setOnClickListener(new OnClickListener() {
        public void onClick(View v) {
            Intent intent = new Intent (CameraTestActivity.this,  
                             SecondActivity.class);
            startActivity(intent);
        }
    });

    scanButton = (Button)findViewById(R.id.ScanButton);

    scanButton.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                if (barcodeScanned) {
                    barcodeScanned = false;
                    scanText.setText("Scanning...");
                    mCamera.setPreviewCallback(previewCb);
                    mCamera.startPreview();
                    previewing = true;
                    mCamera.autoFocus(autoFocusCB);
                }
            }
        });
}

public void onPause() {
    super.onPause();
    releaseCamera();
}

/** A safe way to get an instance of the Camera object. */
public static Camera getCameraInstance(){
    Camera c = null;
    try {
        c = Camera.open();
    } catch (Exception e){
    }
    return c;
}

private void releaseCamera() {
    if (mCamera != null) {
        previewing = false;
        mCamera.setPreviewCallback(null);
        mCamera.release();
        mCamera = null;
    }
}

private Runnable doAutoFocus = new Runnable() {
        public void run() {
            if (previewing)
                mCamera.autoFocus(autoFocusCB);
        }
    };

PreviewCallback previewCb = new PreviewCallback() {
        public void onPreviewFrame(byte[] data, Camera camera) {
            Camera.Parameters parameters = camera.getParameters();
            Size size = parameters.getPreviewSize();

            Image barcode = new Image(size.width, size.height, "Y800");
            barcode.setData(data);

            int result = scanner.scanImage(barcode);

            if (result != 0) {
                previewing = false;
                mCamera.setPreviewCallback(null);
                mCamera.stopPreview();

                SymbolSet syms = scanner.getResults();
                for (Symbol sym : syms) {
                    scanText.setText("barcode result " + sym.getData());
                    barcodeScanned = true;
                }
            }
        }
    };

// Mimic continuous auto-focusing
AutoFocusCallback autoFocusCB = new AutoFocusCallback() {
        public void onAutoFocus(boolean success, Camera camera) {
            autoFocusHandler.postDelayed(doAutoFocus, 1000);
        }
    };
}

我的第二項活動沒有任何功能。 但是,每當我按回設備以返回CameraTestActivity時,都會說在release()之后調用的方法,這是我的logcat錯誤:

08-02 15:01:56.620: E/AndroidRuntime(7772): java.lang.RuntimeException: Method called 
after release()
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.hardware.Camera.setPreviewDisplay(Native Method)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.hardware.Camera.setPreviewDisplay(Camera.java:407)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at           
net.sourceforge.zbar.android.CameraTest.CameraPreview.surfaceCreated(CameraPreview.
java:69)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at    
android.view.SurfaceView.updateWindow(SurfaceView.java:533)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.SurfaceView.onWindowVisibilityChanged(SurfaceView.java:226)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.View.dispatchWindowVisibilityChanged(View.java:5844)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:945)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:945)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:945)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:945)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewGroup.dispatchWindowVisibilityChanged(ViewGroup.java:945)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:965)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2442)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.os.Handler.dispatchMessage(Handler.java:99)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.os.Looper.loop(Looper.java:137)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.app.ActivityThread.main(ActivityThread.java:4424)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
java.lang.reflect.Method.invokeNative(Native Method)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
java.lang.reflect.Method.invoke(Method.java:511)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
dalvik.system.NativeStart.main(Native Method)

有人可以幫我解決這個問題嗎?

查看您的日志:

08-02 15:01:56.620: E/AndroidRuntime(7772): java.lang.RuntimeException: Method called 
after release()
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.hardware.Camera.setPreviewDisplay(Native Method)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at 
android.hardware.Camera.setPreviewDisplay(Camera.java:407)
08-02 15:01:56.620: E/AndroidRuntime(7772):     at           
net.sourceforge.zbar.android.CameraTest.CameraPreview.surfaceCreated(CameraPreview.
java:69)

是否在onPause之后調用了surfaceCreated onPause ,您釋放了相機。 核實。

您應該實現onResume()方法,因為在按下返回按鈕后返回上一個活動時會調用該方法。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM