某些Android设备上的相机访问错误

时间:2016-06-15 14:10:23

标签: android

我写了一个应用程序,它可以使用手机的相机。 在大多数设备上,我尝试过它工作正常,但有些应用程序在打开时崩溃。 一点点调试表明,尝试访问相机时出现问题。

完整错误消息:

06-14 23:15:01.550 21872-21872/bguproject.vlc E/AndroidRuntime: FATAL EXCEPTION: main
Process: bguproject.vlc, PID: 21872
java.lang.RuntimeException: Unable to start activity ComponentInfo{bguproject.vlc/bguproject.vlc.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'android.hardware.Camera$Parameters android.hardware.Camera.getParameters()' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2434)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2494)
at android.app.ActivityThread.access$900(ActivityThread.java:157)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1356)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5525)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:730)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.hardware.Camera$Parameters android.hardware.Camera.getParameters()' on a null object reference
at bguproject.vlc.MainActivity.onCreate(MainActivity.java:54)
at android.app.Activity.performCreate(Activity.java:6272)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2387)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2494) 
at android.app.ActivityThread.access$900(ActivityThread.java:157) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1356) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:148) 
at android.app.ActivityThread.main(ActivityThread.java:5525) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:730) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620) 

你可以看到错误说我尝试在空对象引用上调用虚方法,如果mCamera的编写正确完成就不会发生

代码(写作在最后的try-catch短语中):

package bguproject.vlc;

import android.app.Activity;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.hardware.Camera;
import android.net.Uri;
import android.os.Bundle;
import android.os.SystemClock;
import android.view.View;
import android.widget.FrameLayout;
import android.widget.ScrollView;


public class MainActivity extends Activity implements View.OnClickListener{
    private Camera mCamera = null;
    private CameraView mCameraView = null;
    private int fpsRate[] = new int[2];
    private  boolean work = true,receiving = false;
    private boolean send = false;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Logger l = Logger.getInstance(this); //create the logger instance

        Logger.Log("Starting VLC app...");

        try{
            bguproject.vlc.Logger.Log("\tAccessing camera...");
            mCamera = Camera.open();//you can use open(int) to use different cameras
        } catch (Exception e){
            bguproject.vlc.Logger.LogError("\tFailed to get camera: " + e.getMessage());
        }

完整代码: http://pastebin.com/hxqJK3t2

所有破碎的手机都配有相机并且相对较新(三星s6,三星s7和LG g4)。

1 个答案:

答案 0 :(得分:3)

三星S6和LG G4都可以升级到Android Marshmallow(v6或API 23),三星S7在库存ROM上运行Marshmallow,所以我假设所有这三款设备都运行Marshmallow :)

  

来自https://developer.android.com/training/permissions/requesting.html   
注意:从Android 6.0(API级别23)开始,用户可以随时撤消任何应用程序的权限,即使应用程序的API级别较低。无论您的应用针对什么API级别,您都应该测试您的应用,以确认它在错过所需权限时的行为是否正常。

除了清单中设置的权限之外,您还需要请求/检查运行时权限。您可以使用示例代码,或者......


快速解决方案,

  

转到“设置” - >应用 - >(您的应用名称) - >权限并启用相机权限。       完成,但不推荐用于最终产品

然后再次尝试您的应用。应该现在正在工作:D