私はsendExtraCommand()メソッドを使用してプログラム的に自分のスマートフォンのgpsチップをクリアしようとしています。私はそのように呼んで場所sendExtraCommands - メソッドが機能せず、アプリケーションをシャットダウンします
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"/>
方法自体::
locationManager.sendExtraCommand(LocationManager.GPS_PROVIDER, "delete_aiding_data", null)
私はエミュレータ上または上にそれをしようとすると、私のマニフェストファイルでは、私はこのような余分なコマンドを送信する権限を追加しました私のスマートフォンアプリがクラッシュします。私は何が間違っているのか分からないので、誰かが私の問題を見てもらえると非常に感謝しています。
私の唯一のアクティビティ、MainActivity:
public class MainActivity extends AppCompatActivity {
private TextView textView;
private Button button;
private LocationManager locationManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView) findViewById(R.id.txtView1);
textView.setText("Gps Reset: ");
button = (Button) findViewById(R.id.button);
locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
boolean enabled = locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER);
System.out.println(enabled);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
sendXtraCommand();
}
});
}
private void sendXtraCommand(){
boolean reset = locationManager.sendExtraCommand(LocationManager.GPS_PROVIDER, "delete_aiding_data", null);
if(reset){
textView.append("true");
}else{
textView.append("false");
}
}
}
そして、ここに私のマニフェスト・ファイル:
11/25 14:32:41: Launching app
$ adb shell am start -n "com.example.felix.resetgps/com.example.felix.resetgps.MainActivity" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER -D
Waiting for application to come online: com.example.felix.resetgps | com.example.felix.resetgps.test
Waiting for application to come online: com.example.felix.resetgps | com.example.felix.resetgps.test
Connecting to com.example.felix.resetgps
I/art: Not late-enabling -Xcheck:jni (already on)
W/art: Unexpected CPU variant for X86 using defaults: x86
W/ActivityThread: Application com.example.felix.resetgps is waiting for the debugger on port 8100...
I/System.out: Sending WAIT chunk
[ 11-25 13:32:41.598 1794: 1815 D/ ]
HostConnection::get() New Host Connection established 0x8bf7f400, tid 1815
I/art: Debugger is active
Connected to the target VM, address: 'localhost:8615', transport: 'socket'
I/System.out: Debugger has connected
I/System.out: waiting for debugger to settle...
I/System.out: waiting for debugger to settle...
I/System.out: waiting for debugger to settle...
I/System.out: waiting for debugger to settle...
I/System.out: waiting for debugger to settle...
I/System.out: waiting for debugger to settle...
I/System.out: waiting for debugger to settle...
I/System.out: debugger has settled (1396)
W/System: ClassLoader referenced unknown path: /data/app/com.example.felix.resetgps-1/lib/x86
I/InstantRun: Instant Run Runtime started. Android package is com.example.felix.resetgps, real application class is null.
W/System: ClassLoader referenced unknown path: /data/app/com.example.felix.resetgps-1/lib/x86
I/art: Starting a blocking GC Instrumentation
W/art: Before Android 4.1, method android.graphics.PorterDuffColorFilter android.support.graphics.drawable.VectorDrawableCompat.updateTintFilter(android.graphics.PorterDuffColorFilter, android.content.res.ColorStateList, android.graphics.PorterDuff$Mode) would have incorrectly overridden the package-private method in android.graphics.drawable.Drawable
I/System.out: true
I/OpenGLRenderer: Initialized EGL, version 1.4
D/OpenGLRenderer: Swap behavior 1
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.felix.resetgps, PID: 4869
java.lang.SecurityException: "gps" location provider requires ACCESS_FINE_LOCATION permission.
at android.os.Parcel.readException(Parcel.java:1683)
at android.os.Parcel.readException(Parcel.java:1636)
at android.location.ILocationManager$Stub$Proxy.sendExtraCommand(ILocationManager.java:1274)
at android.location.LocationManager.sendExtraCommand(LocationManager.java:2226)
at com.example.felix.resetgps.MainActivity.sendXtraCommand(MainActivity.java:51)
at com.example.felix.resetgps.MainActivity.access$000(MainActivity.java:16)
at com.example.felix.resetgps.MainActivity$1.onClick(MainActivity.java:44)
at android.view.View.performClick(View.java:5610)
at android.view.View$PerformClick.run(View.java:22265)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
Disconnected from the target VM, address: 'localhost:8615', transport: 'socket'
こんにちは、Surja、あなたの答えをありがとうございました。はい、エラーはそれを言いますが、私はすでにこのマニフェストにこの許可を持っています。 – Felix
ダイナミックパーミッションを追加しようとすると問題が解決するかもしれませんが、このリンクを参照することができます。https://stackoverflow.com/questions/46915957/access-fine-location-permissions –
ああ、ありがとうございます。私はこれを試します:) – Felix