AndroidでプログラムでGPSを有効または無効にするにはどうすればよいですか?


158

私はアンドロイドでプログラム的にGPSをオン/オフにすることについての質問議論 きた ことを知っいます、そして答えは常に同じです:

「セキュリティ/プライバシー上の理由から、ロケーションの設定画面に転送して、ユーザーが有効化/無効化できるようにする必要があります。」

私は最近Taskerを市場から購入したことを理解していますが、それを使用して実行できる他の多くのことの中でも、所定のアプリケーションに入るときにGPSを自動有効にし、終了時にそれを無効にするルールを設定できます(ここを参照)をそれを行う方法のチュートリアル、そしてそれはうまくいく!)そしてこのアプリは多くのAndroidバージョンや異なるデバイスで機能し、ルート化する必要さえないので、ファームウェア署名キーで署名することはできません。

私のアプリでこれを行いたいのですが。もちろん、私はユーザーのプライバシーを爆破したくないので、まずユーザーに通常の「私の決定を記憶する」チェックボックスで自動的にオンにするかどうかを尋ね、はいと答えた場合は有効にします。

タスカーがこれをどのように達成するかについて誰かが何か考えや手掛かりを持っていますか?

回答:


161

パワーマネージャーウィジェットのバグを悪用することで、GPSを切り替えることができます。議論については、このxdaスレッドを参照してください。

ここに私が使用するいくつかのサンプルコードがあります

private void turnGPSOn(){
    String provider = Settings.Secure.getString(getContentResolver(), Settings.Secure.LOCATION_PROVIDERS_ALLOWED);

    if(!provider.contains("gps")){ //if gps is disabled
        final Intent poke = new Intent();
        poke.setClassName("com.android.settings", "com.android.settings.widget.SettingsAppWidgetProvider"); 
        poke.addCategory(Intent.CATEGORY_ALTERNATIVE);
        poke.setData(Uri.parse("3")); 
        sendBroadcast(poke);
    }
}

private void turnGPSOff(){
    String provider = Settings.Secure.getString(getContentResolver(), Settings.Secure.LOCATION_PROVIDERS_ALLOWED);

    if(provider.contains("gps")){ //if gps is enabled
        final Intent poke = new Intent();
        poke.setClassName("com.android.settings", "com.android.settings.widget.SettingsAppWidgetProvider");
        poke.addCategory(Intent.CATEGORY_ALTERNATIVE);
        poke.setData(Uri.parse("3")); 
        sendBroadcast(poke);
    }
}

以下を使用して、電源制御ウィジェットの既存のバージョンがgpsを切り替えることができるバージョンかどうかをテストします。

private boolean canToggleGPS() {
    PackageManager pacman = getPackageManager();
    PackageInfo pacInfo = null;

    try {
        pacInfo = pacman.getPackageInfo("com.android.settings", PackageManager.GET_RECEIVERS);
    } catch (NameNotFoundException e) {
        return false; //package not found
    }

    if(pacInfo != null){
        for(ActivityInfo actInfo : pacInfo.receivers){
            //test if recevier is exported. if so, we can toggle GPS.
            if(actInfo.name.equals("com.android.settings.widget.SettingsAppWidgetProvider") && actInfo.exported){
                return true;
            }
        }
    }

    return false; //default
}

4
この(私の)コメントの時点で、この回答のリンクは、このエクスプロイトのバグが最近修正されたことを示しているようです。私のテスト環境ではエクスプロイトがうまく機能しているように見えるので、これをあきらめないでください。機能しない場合は、コードでエラーが処理されることを確認してください。 !
SilithCrowe 2011年

1
このコメントの執筆時点では、このエクスプロイトは2.2.1 Androidフォンでも機能します。良い発見、ベンH.
Qix-モニカは

38
これは本当に悪い考えです。バグが修正されると、エクスプロイトは機能しなくなります。ユーザーを設定アプリに送るだけの方が良いでしょう。
Edward Falk

1
Android 2.3.6では正常に機能しますが、Android 4.0.3では機能しません。Android 4.0.3で有効または無効にするアイデア
クリシュナ

5
ははは...このエクスプロイトは4.2.2で再び出現し、それを見て驚いた。
amithgc 2013

70

これらすべての回答は現在許可されていません。ここに正しいものがあります:

まだ答えを探しているすべての人のために:

OLA Cabsと他のそのようなアプリがどのように実行しているかを以下に示します。

これをあなたのonCreateに追加してください

if (googleApiClient == null) {
    googleApiClient = new GoogleApiClient.Builder(this)
            .addApi(LocationServices.API).addConnectionCallbacks(this)
            .addOnConnectionFailedListener(Login.this).build();
    googleApiClient.connect();
            LocationRequest locationRequest = LocationRequest.create();
    locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
    locationRequest.setInterval(30 * 1000);
    locationRequest.setFastestInterval(5 * 1000);
    LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder()
            .addLocationRequest(locationRequest);

    // **************************
    builder.setAlwaysShow(true); // this is the key ingredient
    // **************************

    PendingResult<LocationSettingsResult> result = LocationServices.SettingsApi
            .checkLocationSettings(googleApiClient, builder.build());
    result.setResultCallback(new ResultCallback<LocationSettingsResult>() {
        @Override
        public void onResult(LocationSettingsResult result) {
            final Status status = result.getStatus();
            final LocationSettingsStates state = result
                    .getLocationSettingsStates();
            switch (status.getStatusCode()) {
            case LocationSettingsStatusCodes.SUCCESS:
                // All location settings are satisfied. The client can
                // initialize location
                // requests here.
                break;
            case LocationSettingsStatusCodes.RESOLUTION_REQUIRED:
                // Location settings are not satisfied. But could be
                // fixed by showing the user
                // a dialog.
                try {
                    // Show the dialog by calling
                    // startResolutionForResult(),
                    // and check the result in onActivityResult().
                    status.startResolutionForResult(Login.this, 1000);
                } catch (IntentSender.SendIntentException e) {
                    // Ignore the error.
                }
                break;
            case LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE:
                // Location settings are not satisfied. However, we have
                // no way to fix the
                // settings so we won't show the dialog.
                break;
            }
        }
    });
}

これらは実装されたメソッドです。

@Override
public void onConnected(Bundle arg0) {
    // TODO Auto-generated method stub

}

@Override
public void onConnectionSuspended(int arg0) {
    // TODO Auto-generated method stub

}

@Override
public void onConnectionFailed(ConnectionResult arg0) {
    // TODO Auto-generated method stub

}

これは同じのAndroidドキュメントです。

これは、彼らがまだ苦労している場合に他の人を助けるためです:

編集さらにヘルプが必要な場合、Irfan Razaのコメントを追加します。

@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {
     if (requestCode == 1000) {
         if(resultCode == Activity.RESULT_OK){
             String result=data.getStringExtra("result"); 
         } if (resultCode == Activity.RESULT_CANCELED) {
             //Write your code if there's no result 
         } 
    } 
} 

これでこの答えは受け入れられるはずです。Akshatに感謝します!!
Gurpreet 2016年

2
Google APIクライアントの統合が必要であるため、特定のユースケースのソリューションのみであり、一般的なソリューションには適合しません。
Cik 2016

@DilroopSinghどのような問題に直面していますか?私は同じコードを使用していますが、完全に機能します。
Akshat 16

1
そのビルダーを表示せずにこれを達成できますか?アラートを表示せずにgpsをオンにする必要があるためです。
プニタプリヤ2016

3
@Punithapriyaそれは不可能です。ユーザーの同意が必要なので、そのビルダーを表示する必要があります。
Akshat

50

GPSを有効にする:

Intent intent=new Intent("android.location.GPS_ENABLED_CHANGE");
intent.putExtra("enabled", true);
sendBroadcast(intent);

GPSを無効にする:

Intent intent = new Intent("android.location.GPS_ENABLED_CHANGE");
intent.putExtra("enabled", false);
sendBroadcast(intent);

1
自動的にGPSがオン/オフになります。
デバッガ2012

1
これも有効にするのに役立ちます。private void turnGPSOn(){String provider = Settings.Secure.getString(getContentResolver()、Settings.Secure.LOCATION_PROVIDERS_ALLOWED); if(!provider.contains( "gps")){// gpsが無効になっている場合final Intent poke = new Intent(); poke.setClassName( "com.android.settings"、 "com.android.settings.widget.SettingsAppWidgetProvider"); poke.addCategory(Intent.CATEGORY_ALTERNATIVE); poke.setData(Uri.parse( "3")); sendBroadcast(poke); }}
デバッガ

asamsung sIIで実行されているAndroid 2.3.4では、gpsセンサーを効果的にアクティブ化せずにgpsアイコンをオンにします。ただし、プログラムでGPSセンサーをオンにすることを選択した場合は、それが認識されます。
トニーギル

24
android 4.0.4-gps 通知のみが有効です。GPS自体ではありません。だからそれはオンになっているように見えますが、実際にはそうではありません
アレックス2012

14
java.lang.SecurityException:許可拒否:放送android.location.GPS_ENABLED_CHANGEを送信することは許されない
Abhi

28

このコードは、上で動作根ざし電話アプリがへ移動された場合 /system/aps彼らはマニフェストで次の権限を持っています

<uses-permission android:name="android.permission.WRITE_SETTINGS"/>
<uses-permission android:name="android.permission.WRITE_SECURE_SETTINGS"/>

コード

private void turnGpsOn (Context context) {
    beforeEnable = Settings.Secure.getString (context.getContentResolver(),
                                              Settings.Secure.LOCATION_PROVIDERS_ALLOWED);
    String newSet = String.format ("%s,%s",
                                   beforeEnable,
                                   LocationManager.GPS_PROVIDER);
    try {
        Settings.Secure.putString (context.getContentResolver(),
                                   Settings.Secure.LOCATION_PROVIDERS_ALLOWED,
                                   newSet); 
    } catch(Exception e) {}
}


private void turnGpsOff (Context context) {
    if (null == beforeEnable) {
        String str = Settings.Secure.getString (context.getContentResolver(),
                                                Settings.Secure.LOCATION_PROVIDERS_ALLOWED);
        if (null == str) {
            str = "";
        } else {                
            String[] list = str.split (",");
            str = "";
            int j = 0;
            for (int i = 0; i < list.length; i++) {
                if (!list[i].equals (LocationManager.GPS_PROVIDER)) {
                    if (j > 0) {
                        str += ",";
                    }
                    str += list[i];
                    j++;
                }
            }
            beforeEnable = str;
        }
    }
    try {
        Settings.Secure.putString (context.getContentResolver(),
                                   Settings.Secure.LOCATION_PROVIDERS_ALLOWED,
                                   beforeEnable);
    } catch(Exception e) {}
}

5
このメソッドについて言及する場合は+1。ルート権限を取得されていないデバイスのシステムアプリでも動作するはずです。
AlexS 2013年

これは正しい方法です。Androidのすべてのバージョンで動作します。トリックは必要ありません。
BQuadra 2014年

GPSをオフにしても機能しません!! 理由と可能な解決策を教えてください。
Shivansh 2014

現在、GPSは完全にオフおよびオンになっていますが、GPSは機能していません。つまり、緯度
経度を

<uses-permission android:name = "android.permission.WRITE_SECURE_SETTINGS" />は、システムapsの場合のみ
sijo jose '22

22

Androidバージョン4.4以降、プログラムでgpsを有効/無効にすることはできません。この回答で提案されたコードを試すと、例外が発生します。

java.lang.SecurityException: Permission Denial: not allowed to send broadcast android.location.GPS_ENABLED_CHANGE

2
それはコメントですか、それとも解決策は何ですか?
Shylendra Madda 2017

@Shylendra Madda GPSを有効にするソリューションはありません。対応するシステムダイアログのみを呼び出すことができます。
驚異的なJan

22

インテントSettings.ACTION_LOCATION_SOURCE_SETTINGSを使用する代わりに、Googleマップなどのアプリでポップアップを直接表示したり、OKボタンをクリックしてGpsに表示したりすることができます。設定にリダイレクトする必要はありません。

注:このコード行は、場所がオンでない場合にダイアログボックスを自動的に開きます。この行はGoogleマップでも使用されています

 public class MainActivity extends AppCompatActivity
    implements GoogleApiClient.ConnectionCallbacks,
    GoogleApiClient.OnConnectionFailedListener {


LocationRequest mLocationRequest;
GoogleApiClient mGoogleApiClient;
PendingResult<LocationSettingsResult> result;
final static int REQUEST_LOCATION = 199;

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

    mGoogleApiClient = new GoogleApiClient.Builder(this)
            .addApi(LocationServices.API)
            .addConnectionCallbacks(this)
            .addOnConnectionFailedListener(this).build();
    mGoogleApiClient.connect();

}

@Override
public void onConnected(Bundle bundle) {

    mLocationRequest = LocationRequest.create();
    mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
    mLocationRequest.setInterval(30 * 1000);
    mLocationRequest.setFastestInterval(5 * 1000);

    LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder()
            .addLocationRequest(mLocationRequest);
    builder.setAlwaysShow(true);

    result = LocationServices.SettingsApi.checkLocationSettings(mGoogleApiClient, builder.build());

    result.setResultCallback(new ResultCallback<LocationSettingsResult>() {
        @Override
        public void onResult(LocationSettingsResult result) {
            final Status status = result.getStatus();
            //final LocationSettingsStates state = result.getLocationSettingsStates();
            switch (status.getStatusCode()) {
                case LocationSettingsStatusCodes.SUCCESS:
                    // All location settings are satisfied. The client can initialize location
                    // requests here.
                    //...
                    break;
                case LocationSettingsStatusCodes.RESOLUTION_REQUIRED:
                    // Location settings are not satisfied. But could be fixed by showing the user
                    // a dialog.
                    try {
                        // Show the dialog by calling startResolutionForResult(),
                        // and check the result in onActivityResult().
                        status.startResolutionForResult(
                                MainActivity.this,
                                REQUEST_LOCATION);
                    } catch (SendIntentException e) {
                        // Ignore the error.
                    }
                    break;
                case LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE:
                    // Location settings are not satisfied. However, we have no way to fix the
                    // settings so we won't show the dialog.
                    //...
                    break;
            }
        }
    });

}

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data)
{
    Log.d("onActivityResult()", Integer.toString(resultCode));

    //final LocationSettingsStates states = LocationSettingsStates.fromIntent(data);
    switch (requestCode)
    {
        case REQUEST_LOCATION:
            switch (resultCode)
            {
                case Activity.RESULT_OK:
                {
                    // All required changes were successfully made
                    Toast.makeText(MainActivity.this, "Location enabled by user!", Toast.LENGTH_LONG).show();
                    break;
                }
                case Activity.RESULT_CANCELED:
                {
                    // The user was asked to change settings, but chose not to
                    Toast.makeText(MainActivity.this, "Location not enabled, user cancelled.", Toast.LENGTH_LONG).show();
                    break;
                }
                default:
                {
                    break;
                }
            }
            break;
    }
}

@Override
public void onConnectionSuspended(int i) {

}

@Override
public void onConnectionFailed(ConnectionResult connectionResult) {

}
} 

注:このコード行は、場所がオンでない場合にダイアログボックスを自動的に開きます。この行はGoogleマップでも使用されています


1
このコードは正常に動作していますが、
gradle

6

プログラムでGPSをオンまたはオフにするには、「ルート」アクセスとBusyBoxのインストールが必要です。それでも、その作業は簡単ではありません。

サンプルはこちら:GoogleドライブGithubSourceforge

2.3.5および4.1.2 Androidでテスト済み。


サンプルはもう利用できません。
Android開発者

こちらが最新のものです。rapidshare.com / files / 1458124346 / GPSToggler-20130222.7z 古いバージョンを誤って消去してしまいました。BusyBoxはもう必要ありません。
OGP 2013

まだ利用できません。多分別のファイルアップロードサービスを使用しますか?
Android開発者

フォルダーを公開して確認しました。これでダウンロードできます。また、ここに私のプライベートFTP:StackExchange:se@oldgopher.gotdns.com
OGP


5

上記の正解は非常に古く、新しいものが必要なのでここに答えがあります

最後の更新と同様に、androidxをサポートしているため、まずアプリレベルのbuild.gradleファイルに依存関係を含めます

implementation 'com.google.android.gms:play-services-location:17.0.0'

次にマニフェストファイルに追加します。

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>

リリースする場合は、これらの権限についてユーザーの同意を取得することを忘れないでください

今ここにコードはそれを使うだけです

 protected void createLocationRequest() {
    LocationRequest locationRequest = LocationRequest.create();
    locationRequest.setInterval(10000);
    locationRequest.setFastestInterval(5000);
    locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);

    LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder()
            .addLocationRequest(locationRequest);

    SettingsClient client = LocationServices.getSettingsClient(this);
    Task<LocationSettingsResponse> task = client.checkLocationSettings(builder.build());



    task.addOnSuccessListener(this, new OnSuccessListener<LocationSettingsResponse>() {
        @Override
        public void onSuccess(LocationSettingsResponse locationSettingsResponse) {
            // All location settings are satisfied. The client can initialize
            // location requests here.
            // ...

            Toast.makeText(MainActivity.this, "Gps already open", 
                                          Toast.LENGTH_LONG).show();
            Log.d("location settings",locationSettingsResponse.toString());
        }
    });

    task.addOnFailureListener(this, new OnFailureListener() {
        @Override
        public void onFailure(@NonNull Exception e) {
            if (e instanceof ResolvableApiException) {
                // Location settings are not satisfied, but this can be fixed
                // by showing the user a dialog.
                try {
                    // Show the dialog by calling startResolutionForResult(),
                    // and check the result in onActivityResult().
                    ResolvableApiException resolvable = (ResolvableApiException) e;
                    resolvable.startResolutionForResult(MainActivity.this,
                            REQUEST_CHECK_SETTINGS);
                } catch (IntentSender.SendIntentException sendEx) {
                    // Ignore the error.
                }
            }
        }
    });
}


@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
    super.onActivityResult(requestCode, resultCode, data);

    if(requestCode==REQUEST_CHECK_SETTINGS){

        if(resultCode==RESULT_OK){

            Toast.makeText(this, "Gps opened", Toast.LENGTH_SHORT).show();
            //if user allows to open gps
            Log.d("result ok",data.toString());

        }else if(resultCode==RESULT_CANCELED){

            Toast.makeText(this, "refused to open gps", 
                                         Toast.LENGTH_SHORT).show();
            // in case user back press or refuses to open gps
            Log.d("result cancelled",data.toString());
        }
    }
}

何か問題が発生した場合は、pingを送信してください


2

別の質問で回答が作成されましたが、回答は締め切られました。コミュニティにも試してもらいたいです。

boolean gpsStatus = locmanager.isProviderEnabled(LocationManager.GPS_PROVIDER);
if (!gpsStatus) {
    Settings.Secure.putString(getContentResolver(), Settings.Secure.LOCATION_PROVIDERS_ALLOWED, "network,gps");
}

このコメントを見る

このソリューションにはWRITE_SETTINGSおよびWRITE_SECURE_SETTINGS権限が必要です。


@milind、ルート化されたデバイスがあると仮定すると、このコードを使用するにはどうすればよいですか?アプリのルート権限を取得しようとしましたが、役に立ちませんでした。「許可の拒否:安全な設定への書き込みにはandroid.permission.WRITE_SECURE_SETTINGSが必要です」
Android開発者

@androidこの投稿の最後の文を読んでください。この方法を使用するにandroid.permission.WRITE_SECURE_SETTINGSは、マニフェストの許可が必要です。
gobernador 2012

1
知っている 。私はすでにそれを追加しました。それはすでにマニフェストにあるにもかかわらずそれを私に伝えます。
Android開発者


ルート権限を取得されたデバイスであっても不可能ですか?
android開発者

2

たぶん、クラスの周りの反射トリックでandroid.server.LocationManagerService

また、メソッドがあります(API 8以降) android.provider.Settings.Secure.setLocationProviderEnabled


3
このSettings.Secureクラスは有望なようですが、android.permission.WRITE_SECURE_SETTINGSが必要であるというセキュリティ例外が発生し、この権限(およびWRITE_SETTINGSも)をマニフェストに追加してもエラーが発生し続けます。しかし、検索を続けるには良い方法のようです。ありがとう:)
maid450

WRITE_SECURE_SETTINGSしているの保護レベルsystemOrSignatureあなたは仕事にそれのために、そのアプリケーションのシステムアプリを作る必要があり、またこの回答に記載されています
フロー14

2

これは、が提供する最良のソリューションGoogle Developersです。初期化後、onCreateのonResumeでこのメソッドを呼び出すだけGoogleApiClientです。

private void updateMarkers() {
    if (mMap == null) {
        return;
    }

    if (mLocationPermissionGranted) {
        // Get the businesses and other points of interest located
        // nearest to the device's current location.
         mGoogleApiClient = new GoogleApiClient.Builder(this)
                .addApi(LocationServices.API).build();
        mGoogleApiClient.connect();
        LocationRequest locationRequest = LocationRequest.create();
        locationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
        locationRequest.setInterval(10000);
        locationRequest.setFastestInterval(10000 / 2);

        LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder().addLocationRequest(locationRequest);
        builder.setAlwaysShow(true);


        LocationSettingsRequest.Builder builder = new LocationSettingsRequest
                .Builder()
                .addLocationRequest(mLocationRequest);
        PendingResult<LocationSettingsResult> resultPendingResult = LocationServices
                .SettingsApi
                .checkLocationSettings(mGoogleApiClient, builder.build());

        resultPendingResult.setResultCallback(new ResultCallback<LocationSettingsResult>() {
            @Override
            public void onResult(@NonNull LocationSettingsResult locationSettingsResult) {
                final Status status = locationSettingsResult.getStatus();
                final LocationSettingsStates locationSettingsStates = locationSettingsResult.getLocationSettingsStates();
                switch (status.getStatusCode()) {
                    case LocationSettingsStatusCodes.SUCCESS:
                        // All location settings are satisfied. The client can
                        // initialize location requests here.

                        break;
                    case LocationSettingsStatusCodes.RESOLUTION_REQUIRED:
                        // Location settings are not satisfied, but this can be fixed
                        // by showing the user a dialog.


                        try {
                            // Show the dialog by calling startResolutionForResult(),
                            // and check the result in onActivityResult().
                            status.startResolutionForResult(
                                    MainActivity.this,
                                    PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION);
                        } catch (IntentSender.SendIntentException e) {
                            // Ignore the error.


                        }
                        break;
                    case LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE:
                        // Location settings are not satisfied. However, we have no way
                        // to fix the settings so we won't show the dialog.


                        break;
                }

            }
        });


        @SuppressWarnings("MissingPermission")
        PendingResult<PlaceLikelihoodBuffer> result = Places.PlaceDetectionApi
                .getCurrentPlace(mGoogleApiClient, null);
        result.setResultCallback(new ResultCallback<PlaceLikelihoodBuffer>() {
            @Override
            public void onResult(@NonNull PlaceLikelihoodBuffer likelyPlaces) {
                for (PlaceLikelihood placeLikelihood : likelyPlaces) {
                    // Add a marker for each place near the device's current location, with an
                    // info window showing place information.
                    String attributions = (String) placeLikelihood.getPlace().getAttributions();
                    String snippet = (String) placeLikelihood.getPlace().getAddress();
                    if (attributions != null) {
                        snippet = snippet + "\n" + attributions;
                    }

                    mMap.addMarker(new MarkerOptions()
                            .position(placeLikelihood.getPlace().getLatLng())
                            .title((String) placeLikelihood.getPlace().getName())
                            .snippet(snippet));
                }
                // Release the place likelihood buffer.
                likelyPlaces.release();
            }
        });
    } else {
        mMap.addMarker(new MarkerOptions()
                .position(mDefaultLocation)
                .title(getString(R.string.default_info_title))
                .snippet(getString(R.string.default_info_snippet)));
    }
}

注:このコード行Locationは、オンになっていない場合、ダイアログボックスを自動的に開きます。この行はGoogleマップでも使用されています

 status.startResolutionForResult(
 MainActivity.this,
 PERMISSIONS_REQUEST_ACCESS_FINE_LOCATION);

mLocationPermissionGrantedとはですか?
b devloper 2017

これは、場所に対する権限が付与されているかどうかを確認するためのものです。これはrun time許可された許可です。
AMAN SINGH 2017

ロリポップ前のデバイスですでに許可を与えている場合は、値をtrueに設定するだけで処理することもできます
AMAN SINGH

2

このコードはROOTED電話で機能します:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        String[] cmds = {"cd /system/bin" ,"settings put secure location_providers_allowed +gps"};
        try {
            Process p = Runtime.getRuntime().exec("su");
            DataOutputStream os = new DataOutputStream(p.getOutputStream());
            for (String tmpCmd : cmds) {
                os.writeBytes(tmpCmd + "\n");
            }
            os.writeBytes("exit\n");
            os.flush();
        }
        catch (IOException e){
            e.printStackTrace();
        }
    }
}

GPSをオフにする場合は、代わりにこのコマンドを使用できます

settings put secure location_providers_allowed -gps

次のコマンドを使用してネットワークの精度を切り替えることもできます。

settings put secure location_providers_allowed +network

オフにするには、以下を使用できます。

settings put secure location_providers_allowed -network

1

この質問が投稿されてから物事が変更されました。新しいGoogle Services APIを使用すると、GPSを有効にするようユーザーに促すことができます。

https://developers.google.com/places/android-api/current-place

マニフェストでACCESS_FINE_LOCATION権限をリクエストする必要があります。

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

このビデオも見てください:

https://www.youtube.com/watch?v=F0Kh_RnSM0w


ありがとう。しかし、Google Play開発者サービス7は古いAndroidバージョンで使用できますか?(API
14-23

1

これは私のために働きます。

この質問(https://stackoverflow.com/a/42556648/11211963)のRj0078の回答よりも簡単ですが、それも機能します。

次のようなダイアログが表示されます。

ここに画像の説明を入力してください

(Kotlinで記述)

    googleApiClient = GoogleApiClient.Builder(context!!)
        .addApi(LocationServices.API).build()
    googleApiClient!!.connect()
    locationRequest = LocationRequest.create()
    locationRequest!!.priority = LocationRequest.PRIORITY_HIGH_ACCURACY
    locationRequest!!.interval = 30 * 1000.toLong()
    locationRequest!!.fastestInterval = 5 * 1000.toLong()

    val builder = LocationSettingsRequest.Builder()
        .addLocationRequest(locationRequest!!)
    builder.setAlwaysShow(true)

    result =
       LocationServices.SettingsApi.checkLocationSettings(googleApiClient, builder.build())
    result!!.setResultCallback { result ->
        val status: Status = result.status
        when (status.statusCode) {
            LocationSettingsStatusCodes.SUCCESS -> {
               // Do something
            }
            LocationSettingsStatusCodes.RESOLUTION_REQUIRED ->
                try {
                    startResolutionForResult(),
                    status.startResolutionForResult(
                        activity,
                        REQUEST_LOCATION
                    )
                } catch (e: SendIntentException) {
                }
            LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE -> {
                // Do something
            }
        }
    }

0

あなただけ削除する必要がありますLocationListenerからLocationManager

manager.removeUpdates(listener);

-1

シンプルでアクセスしやすいこのコードを使用します。

権限:

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

このコードに従って、プログラムでGPSにアクセスします。

LocationManager locationManager ;
 boolean GpsStatus ;


            GPSStatus();

            if(GpsStatus == true)
            {
                textview.setText("Your Location Services Is Enabled");
            }else
                {textview.setText("Your Location Services Is Disabled");}

            Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
            startActivity(intent);


    public void GPSStatus(){
    locationManager = (LocationManager)context.getSystemService(Context.LOCATION_SERVICE);
    GpsStatus = locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER);
} 
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.