2017-04-26 5 views
0

내 매니페스트에서 COARSE 및 FINE 위치 권한을 사용할 수 있지만 공급자에 문제가있는 것 같습니다. 내 앱이 실행될 때 충돌이 발생합니다. 나는 또한 인터넷 허가를 추가했습니다.locationManager.getBestProvider return null

내 코드 :

E/AndroidRuntime: FATAL EXCEPTION: main 
       Process: com.project.korsa.korsa, PID: 32462 
       java.lang.RuntimeException: Unable to start activity ComponentInfo{com.project.korsa.korsa/com.project.korsa.korsa.YourLocation}: java.lang.IllegalArgumentException: invalid provider: null 
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3305) 
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3401) 
        at android.app.ActivityThread.access$1100(ActivityThread.java:229) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1821) 
        at android.os.Handler.dispatchMessage(Handler.java:102) 
        at android.os.Looper.loop(Looper.java:148) 
        at android.app.ActivityThread.main(ActivityThread.java:7303) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120) 
       Caused by: java.lang.IllegalArgumentException: invalid provider: null 
        at android.location.LocationManager.checkProvider(LocationManager.java:1761) 
        at android.location.LocationManager.requestLocationUpdates(LocationManager.java:464) 
        at com.project.korsa.korsa.YourLocation.onCreate(YourLocation.java:135) 
        at android.app.Activity.performCreate(Activity.java:6904) 
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1136) 
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3252) 
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3401)  
        at android.app.ActivityThread.access$1100(ActivityThread.java:229)  
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1821)  
        at android.os.Handler.dispatchMessage(Handler.java:102)  
        at android.os.Looper.loop(Looper.java:148)  
        at android.app.ActivityThread.main(ActivityThread.java:7303)  
        at java.lang.reflect.Method.invoke(Native Method)  
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)  
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)  

답변

0

체크 getBestProvider() 당신이 요청했습니다에 전화에서이 anwser https://stackoverflow.com/a/10688606/3973521

: 여기

locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); 
    provider = locationManager.getBestProvider(new Criteria(), false); 

    if (ActivityCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, android.Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { 
     ActivityCompat.requestPermissions(
       this, 
       new String[]{android.Manifest.permission.ACCESS_COARSE_LOCATION, android.Manifest.permission.ACCESS_FINE_LOCATION}, 
       PERMISSION_LOCATION_REQUEST_CODE); 
    } 
    locationManager.requestLocationUpdates(provider, 400, 1, this); 

그리고는 로그 캣입니다 사용 가능 공급자 만 해당 메소드의 두 번째 매개 변수입니다. 이 true로 설정된 통화). 사용자가 모든 제공 업체를 사용 중지 한 경우 이 null로 표시됩니다.