- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我使用 gms.location.LocationListener(Google Play 服务)获取用户的位置。它工作正常,但我想检测用户何时禁用或启用他/她的 GPS。如图所示。
当我打开/关闭位置时,没有调用任何方法。当我切换应用程序并返回到我的应用程序时,将调用此方法:
但我需要在用户打开/关闭位置时调用该事件,而我列出的这些事件不会被调用。
注意:使用 Android API,我可以使用 onProviderEnabled 和 onProviderDisabled 获取这些事件我的问题是,在我使用 GoogleApiClient 后,这些事件不再被调用。见图 2 和 3。 在那之后 onProviderEnabled 和 onProviderDisabled 没有被很好地调用这是我想同时解决的另一个问题。
我的代码:
package facilito.codigo.app.dflores.com.myapplicationcf;
import android.content.Context;
import android.content.Intent;
import android.content.IntentSender;
import android.content.SharedPreferences;
import android.location.Location;
import com.google.android.gms.common.GooglePlayServicesUtil;
import com.google.android.gms.location.LocationListener;//android.location.LocationListener;
import android.location.LocationManager;
import android.os.AsyncTask;
import android.support.design.widget.Snackbar;
import android.support.v4.app.FragmentActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import com.google.android.gms.common.ConnectionResult;
import com.google.android.gms.common.api.GoogleApiClient;
import com.google.android.gms.common.api.PendingResult;
import com.google.android.gms.common.api.ResultCallback;
import com.google.android.gms.common.api.Status;
import com.google.android.gms.location.LocationRequest;
import com.google.android.gms.location.LocationServices;
import com.google.android.gms.location.LocationSettingsRequest;
import com.google.android.gms.location.LocationSettingsResult;
import com.google.android.gms.location.LocationSettingsStates;
import com.google.android.gms.location.LocationSettingsStatusCodes;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.Marker;
import com.google.android.gms.maps.model.MarkerOptions;
import com.google.android.gms.maps.model.PolygonOptions;
import org.json.JSONObject;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
import Beans.Usuario;
import Beans.Utiles;
public class Mapa extends FragmentActivity implements OnMapReadyCallback,
GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener,
LocationListener{
private GoogleMap mMap;
private double lat = 0.0;
private double lon = 0.0;
PolygonOptions comunidad = new PolygonOptions();
protected GoogleApiClient mGoogleApiClient;
LocationRequest mLocationRequest;
Location mLastLocation;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_mapa);
if (mGoogleApiClient == null) {
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.addApi(LocationServices.API)
.build();
}
createLocationRequest();
LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder().addLocationRequest(mLocationRequest);
PendingResult<LocationSettingsResult> 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.
Log.d("BUHOO", "case success :::::::::::>>>>>>>>>>>");
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().
Log.d("BUHOO", "case RESOLUTION_REQUIRED :::::::::::>>>>>>>>>>>");
status.startResolutionForResult(Mapa.this, 1000);
} catch (IntentSender.SendIntentException e) {
// Ignore the error.
}
break;
case LocationSettingsStatusCodes.SETTINGS_CHANGE_UNAVAILABLE:
Log.d("BUHOO", "case 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;
}
}
});
SharedPreferences pref = getSharedPreferences("BUHOO_APP", MODE_PRIVATE);
Usuario usuario = new Usuario(pref.getInt("ID_USUARIO", 0), pref.getString("NOMBRE_USUARIO", null));
int idComu = pref.getInt("ID_COMUNIDAD", 0);
String server = getResources().getString(R.string.ip_server);
String servicio = "http://"+server+"/buhoo/intranet/mi_comunidad/getComunidadByPersona_Service?id_persona="+usuario.getIdUsuario()+"&id_comunidad="+idComu;
Log.d("BUHOO", "servicioservicioservicio:::::: "+servicio);
new llamarServicio().execute(servicio);
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map);
mapFragment.getMapAsync(this);
}
protected void createLocationRequest() {
mLocationRequest = new LocationRequest();
mLocationRequest.setInterval(10000);
mLocationRequest.setFastestInterval(5000);
mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
}
@Override
public void onConnected(Bundle bundle) {
Log.d("BUHOO", ":::: onConnected ::::");
try {
mLastLocation = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiClient);
} catch(SecurityException e) {
StringWriter errors = new StringWriter();
e.printStackTrace(new PrintWriter(errors));
Log.d("BUHOO", " ERROR onLocationChanged "+errors.toString());
}
//if (mRequestingLocationUpdates) {
startLocationUpdates();
//}
}
@Override
public void onConnectionSuspended(int i) {
Log.d("BUHOO", ":::: onConnectionSuspended ::::");
}
protected void onStart() {
Log.d("BUHOO", ":::: onStart ::::");
mGoogleApiClient.connect();
super.onStart();
}
protected void onStop() {
Log.d("BUHOO", ":::: onStop ::::");
mGoogleApiClient.disconnect();
super.onStop();
}
@Override
protected void onPause() {
Log.d("BUHOO", ":::: onPause ::::");
super.onPause();
LocationServices.FusedLocationApi.removeLocationUpdates(mGoogleApiClient, this);
}
@Override
public void onResume() {
Log.d("BUHOO", ":::: onResume ::::");
super.onResume();
if (mGoogleApiClient.isConnected() /*&& !mRequestingLocationUpdates*/) {
startLocationUpdates();
}
}
protected void startLocationUpdates() {
try {
Log.d("BUHOO", ":::: startLocationUpdates ::::");
LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient, mLocationRequest, this);
} catch(SecurityException e) {
StringWriter errors = new StringWriter();
e.printStackTrace(new PrintWriter(errors));
Log.d("BUHOO", " ERROR onLocationChanged "+errors.toString());
}
}
@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
Log.d("BUHOO", ":::: onConnectionFailed ::::");
}
@Override
public void onLocationChanged(Location location) {
Log.d("BUHOO", "onLocationChanged:::::: "+location.getLatitude()+" longitud: "+location.getLongitude());
lat = location.getLatitude();
lon = location.getLongitude();
onMapReady(mMap);
}
/*
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
}
@Override
public void onProviderEnabled(String provider) {
Log.d("BUHOO", ":::: onProviderEnabled ::::");
}
@Override
public void onProviderDisabled(String provider) {
Log.d("BUHOO", ":::: onProviderDisabled ::::");
}*/
private class llamarServicio extends AsyncTask<String, Void, String> {
Utiles utiles = new Utiles();
protected String doInBackground(String... urls) {
return utiles.readJSONFeed(urls[0]);
}
protected void onPostExecute(String result) {
try {
Log.d("BUHOO", "result:::::: "+result);
JSONObject mainResponseObject = new JSONObject(result);
try {
String error = mainResponseObject.getString("error");
if("0".equals(error)) {
JSONObject polyObj = new JSONObject(mainResponseObject.getString("poligono"));
String puntos = polyObj.getString("puntos");
List<String> puntosList = Arrays.asList(puntos.split(","));
for(Iterator it = puntosList.iterator(); it.hasNext(); ) {
String str = (String) it.next();
String[] latlon = str.split(" ");
double lati = Double.parseDouble(latlon[0].replaceAll("\"", ""));
double longi = Double.parseDouble(latlon[1].replaceAll("\"", ""));
comunidad.add(new LatLng(lati, longi));
//Log.d("BUHOO", "lati:::::: "+lati+" ... "+longi);
}
Log.d("BUHOO"," onPostExecute cantidad latlongs: "+comunidad.getPoints().size());
onMapReady(mMap);
} else {
Log.d("CREATION", " ---- error inesperdo: " );
}
} catch (Exception e) {
e.printStackTrace();
StringWriter errors = new StringWriter();
e.printStackTrace(new PrintWriter(errors));
Log.d("CREATION", "tratando el JSON: "+errors.toString());
}
} catch (Exception e) {
StringWriter errors = new StringWriter();
e.printStackTrace(new PrintWriter(errors));
Log.d("CREATION", "errorrrr onPostExecute: "+errors.toString());
}
}
}
/**
* Manipulates the map once available.
* This callback is triggered when the map is ready to be used.
* This is where we can add markers or lines, add listeners or move the camera. In this case,
* we just add a marker near Sydney, Australia.
* If Google Play services is not installed on the device, the user will be prompted to install
* it inside the SupportMapFragment. This method will only be triggered once the user has
* installed Google Play services and returned to the app.
*/
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
// Add a marker in Sydney and move the camera
if(lat != 0.0 && lon != 0.0) {
LatLng myPos = new LatLng(lat, lon);
mMap.clear();
mMap.getUiSettings().setZoomControlsEnabled(true);
mMap.getUiSettings().setCompassEnabled(true);
mMap.getUiSettings().setMyLocationButtonEnabled(true);
mMap.getUiSettings().setZoomGesturesEnabled(true);
mMap.getUiSettings().setMapToolbarEnabled(true);
mMap.addMarker(new MarkerOptions().position(myPos).title("MI POSICION ACTUAL"));
float zoomLevel = 17; //This goes up to 21
//Polygon polygon = mMap.addPolygon(comunidad);
Log.d("BUHOO"," PINTANDO MAPA cantidad latlongs: "+comunidad.getPoints().size());
if(comunidad.getPoints().size() > 0) {
mMap.addPolygon(comunidad/*.fillColor(Color.BLUE)*/);
}
mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(myPos, zoomLevel));
} else {
LatLng sydney = new LatLng(-34, 151);
mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
Log.d("BUHOO", "PINTO SYDNEY");
}
}
public static class GPSCheck extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
LocationManager locationManager = (LocationManager) context.getSystemService(context.LOCATION_SERVICE);
if(locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)) {
Log.d("BUHOO", " :D IS ON!!!!!!!!!!!!!!!!!!!");
} else {
Log.d("BUHOO", " :( GPS TURNED OFF !!!!!!!!!!!!!!!!!!!");
}
}
}
}
最佳答案
您可以通过设置一个广播接收器来实现此目的,该接收器会在您设备的 GPS 打开/关闭时触发
步骤:
<强>1。首先创建一个扩展 BroadcastReceiver 的类 GPS
public class GPSCheck extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
LocationManager locationManager = (LocationManager) context.getSystemService(context.LOCATION_SERVICE);
if(locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER))
{
}
else
{
Toast.makeText(context, "Please switch on the GPS", Toast.LENGTH_LONG).show();
}
}
}
<强>2。然后在你的 AndroidManifest.xml 文件中提到这个类
<receiver android:name="com.yourpackagename.example.GPSCheck" >
<intent-filter>
<action android:name="android.location.PROVIDERS_CHANGED" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
<强>3。不要忘记也添加此权限
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
关于android - 如何检测用户是否禁用 GPS(Android - Play 服务),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35496339/
我有一个 GSM/GPS 单元连接到一个微 Controller ,它们之间的通信工作正常。我能够获取 GPS 并将其发送到微 Controller ,但有时设备在建筑物内,所以我无法真正获取当前的
它显示,错误指出“没有符合条件的应用安装设备” 设备规范如下, 型号:联想A369i Android 操作系统版本:4.2.2 我在 android mainfest 文件中执行以下权限
我有一个 Adafruit FONA 3G/GPS 模块 ( American Version )。我已经可以使用蜂窝功能,但 GPS 功能却遇到了困难。我尝试过无源和有源天线。 这是 SIM5320
今天在将我的应用程序上传到市场时,我发现它仅适用于具有 GPS 的设备,因此不包括某些平板电脑。 我的应用程序中的 GPS 是可选的。是否可以为有和没有 GPS 的设备发布一个应用程序,或者我需要制作
在 Monodroid 中,我正在尝试访问 GPS 服务。我只需要一个位置对象。 这一行报错: _locationManager.RequestLocationUpdates(LocationMana
我是 GPS 世界的新手。我需要知道如何使用 DGPS 进行后处理。我在网上找到了关于 DGPS、后处理等的定义,但是,找不到关于如何实际进行 DGPS 后处理的明确步骤。在搜索提供商时,我发现 CO
我有一系列 gps 值,每个值包含:timestamp, latitude, longitude, n_sats, gps_speed, gps_direction, ... ( NMEA data
抱歉,如果这是错误的“堆栈”。我找不到更合适的。 我为我的狗买了一个 GPS 追踪器,它附带订阅、一张 SIM 卡和一个开发不佳的应用程序。 我已取消订阅并想使用该设备将位置信息发送到我自己的服务器。
有没有一种在线方法可以用来获取 Google map 上两点之间路线上的所有 gps 点?即,如果我给出起点和终点,我需要获取该特定路线上的所有 GPS 点。 最佳答案 除了数据的所有者之外,每个人都
我正在尝试从 GPS 跟踪设备转换 GPS 数据。该公司提供了协议(protocol)手册,但不清楚。我能够从我从设备收到的数据包中解码的大部分数据。通信是通过 TCP/IP 进行的。我在解码经度和纬
我想从 GPS 坐标中获取城市名称。我可以使用 Google API 获取 GPS 点的详细信息 http://maps.googleapis.com/maps/api/geocode/output?
我做了一个 .gpx 文件来模拟 IOS 模拟器上的路线,现在我想模拟水平精度我该怎么做? 以下是我的 .gpx 文件的摘录: //how add horizontal accuracy
我有两个 GPS 坐标 例如(Lat1, Long1) 和 (Lat2,Long2) 谁能帮我找到这两点之间的角度。 值应为 0-360 度。 最佳答案 取自 this以前的SO帖子: float d
我正在为一个小类项目寻找 GPS。我们想要尽可能小的 GPS,我们真正需要它做的就是在我们轮询时为我们提供经度和纬度值。 我尝试查看 sparkfun,但由于我们之前没有真正使用过这种类型的硬件,因此
我正在处理 GPS 数据,每秒获取值并在 map 上显示当前位置。问题在于,有时(特别是当精度较低时)这些值变化很大,使得当前位置在 map 中的远距离点之间“跳跃”。 我想知道一些足够简单的方法来避
我正在创建一个请求用户位置的 BREW 应用程序。 如果手机无法获取位置,我想显示错误。 在确定手机不太可能获得 GPS 定位之前,我应该等待回调多久? 最佳答案 当需要冷启动时,接收器必须下载全套星
我有一辆安装了跟踪器的车辆。该设备具有 GPS 系统、3 轴加速度计、3 轴磁力计和陀螺仪。是否可以通过车辆在斜坡或山坡上向后滚动的程度来确定。使用 gps 角度不是一种选择,因为为短距离向后移动提供
我们计划编写一个软件,每 5 秒左右跟踪一次汽车的 GPS 位置、GPS 信号强度、加速度计(X、Y、Z)和陀螺仪(X、Y、Z)。并将数据发送到服务器进行后期处理。服务器将确定哪些道路上有汽车。所以这
这是我的问题:智能手机会向我的服务器发送一些 gps 坐标(纬度、经度、高度),我必须将这些坐标与存储在数据库中的地址进行比较,以查看智能手机和服务器之间的距离地址。为了进行实际比较,我还需要获取此地
HTML5 浏览器可以检索计算机的 gps 位置。 http://diveintohtml5.ep.io/geolocation.html 我想创建一个伪造 GPS 设备的应用程序,但我无法在任何地方
我是一名优秀的程序员,十分优秀!