Как отобразить текущее местоположение одного пользователя для другого на карте Google в Android Studio?

Я разрабатываю приложение, используя карту Google, я хочу показать текущее местоположение драйвера его администратору. Как показать текущее местоположение водителя его администратору? Как отследить текущее местоположение драйвера и отобразить его администратору?

Следующий код показывает только текущее местоположение драйвера. В этом, как я могу показать текущее местоположение этого драйвера его администратору?

 //java code
    public class LocationActivity extends FragmentActivity implements
            com.google.android.gms.location.LocationListener,
            GoogleApiClient.ConnectionCallbacks,
            GoogleApiClient.OnConnectionFailedListener {

        private static final String TAG = "LocationActivity";
        private static final long INTERVAL = 1000 * 60 * 1; //1 minute
        private static final long FASTEST_INTERVAL = 1000 * 60 * 1; // 1 minute

        private static final float SMALLEST_DISPLACEMENT = 0.25F; //quarter of a meter
        Button btnFusedLocation;
        TextView tvLocation;
        LocationRequest mLocationRequest;
        GoogleApiClient mGoogleApiClient;
        Location mCurrentLocation;
        String mLastUpdateTime;
        GoogleMap googleMap;

        private double longitude;
        private double latitude;
        private ArrayList<LatLng> points; //added
        Polyline line; //added

        protected void createLocationRequest() {
            mLocationRequest = new LocationRequest();
            mLocationRequest.setInterval(INTERVAL);
            mLocationRequest.setFastestInterval(FASTEST_INTERVAL);
            mLocationRequest.setSmallestDisplacement(SMALLEST_DISPLACEMENT); //added
            mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
        }
        /*
        protected void createLocationRequest() {
            mLocationRequest = new LocationRequest();
            mLocationRequest.setInterval(INTERVAL);
            mLocationRequest.setFastestInterval(FASTEST_INTERVAL);
            mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
        }  */

        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            Log.d(TAG, "onCreate ...............................");

            points = new ArrayList<LatLng>();
            //show error dialog if GoolglePlayServices not available
            if (!isGooglePlayServicesAvailable()) {
                finish();
            }
            createLocationRequest();
            mGoogleApiClient = new GoogleApiClient.Builder(this)
                    .addApi(LocationServices.API)
                    .addConnectionCallbacks(this)
                    .addOnConnectionFailedListener(this)
                    .build();

            setContentView(R.layout.activity_location_google_map);
            SupportMapFragment fm = (SupportMapFragment) getSupportFragmentManager()
                    .findFragmentById(R.id.map);
            googleMap = fm.getMap();
            googleMap.getUiSettings().setZoomControlsEnabled(true);

        /*    if (getIntent().getExtras() != null) {
                final Bundle bundle = getIntent().getBundleExtra("LOCATION");
                latitude = bundle.getDouble("LATITUDE");
                longitude = bundle.getDouble("LONGITUDE");  */

        }

        @Override
        public void onStart() {
            super.onStart();
            Log.d(TAG, "onStart fired ..............");
            mGoogleApiClient.connect();
        }

        @Override
        public void onStop() {
            super.onStop();
            Log.d(TAG, "onStop fired ..............");
            mGoogleApiClient.disconnect();
            Log.d(TAG, "isConnected ...............: " + mGoogleApiClient.isConnected());
        }

        private boolean isGooglePlayServicesAvailable() {
            int status = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
            if (ConnectionResult.SUCCESS == status) {
                return true;
            } else {
                GooglePlayServicesUtil.getErrorDialog(status, this, 0).show();
                return false;
            }
        }

        @Override
        public void onConnected(Bundle bundle) {
            Log.d(TAG, "onConnected - isConnected ...............: " + mGoogleApiClient.isConnected());
            startLocationUpdates();
        }

        protected void startLocationUpdates() {
            PendingResult<Status> pendingResult = LocationServices.FusedLocationApi.requestLocationUpdates(
                    mGoogleApiClient, mLocationRequest, this);
            Log.d(TAG, "Location update started ..............: ");
        }

        @Override
        public void onConnectionSuspended(int i) {

        }

        @Override
        public void onConnectionFailed(ConnectionResult connectionResult) {
            Log.d(TAG, "Connection failed: " + connectionResult.toString());
        }

        @Override
        public void onLocationChanged(Location location) {
            Log.d(TAG, "Firing onLocationChanged..............................................");
            mCurrentLocation = location;
            mLastUpdateTime = DateFormat.getTimeInstance().format(new Date());
            addMarker();

            longitude = location.getLongitude();
            latitude = location.getLatitude();
            LatLng latLng = new LatLng(latitude, longitude); //you already have this
            points.add(latLng); //added
            redrawLine();
        }

        private void addMarker() {
            MarkerOptions options = new MarkerOptions();

            // following four lines requires 'Google Maps Android API Utility Library'
            // https://developers.google.com/maps/documentation/android/utility/
            // I have used this to display the time as title for location markers
            // you can safely comment the following four lines but for this info
            IconGenerator iconFactory = new IconGenerator(this);
            iconFactory.setStyle(IconGenerator.STYLE_PURPLE);
            options.icon(BitmapDescriptorFactory.fromBitmap(iconFactory.makeIcon(mLastUpdateTime)));
            options.anchor(iconFactory.getAnchorU(), iconFactory.getAnchorV());

            LatLng currentLatLng = new LatLng(mCurrentLocation.getLatitude(), mCurrentLocation.getLongitude());
            options.position(currentLatLng);
            Marker mapMarker = googleMap.addMarker(options);
            long atTime = mCurrentLocation.getTime();
            mLastUpdateTime = DateFormat.getTimeInstance().format(new Date(atTime));
            mapMarker.setTitle(mLastUpdateTime);
            Log.d(TAG, "Marker added.............................");
            googleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(currentLatLng,
                    13));
            Log.d(TAG, "Zoom done.............................");
        }

        @Override
        protected void onPause() {
            super.onPause();
            stopLocationUpdates();
        }

        protected void stopLocationUpdates() {
            LocationServices.FusedLocationApi.removeLocationUpdates(
                    mGoogleApiClient, this);
            Log.d(TAG, "Location update stopped .......................");
        }

        @Override
        public void onResume() {
            super.onResume();
            if (mGoogleApiClient.isConnected()) {
                startLocationUpdates();
                Log.d(TAG, "Location update resumed .....................");
            }
        }

       // for map line
       private void redrawLine(){

           googleMap.clear();  //clears all Markers and Polylines
           PolylineOptions options = new PolylineOptions().width(5).color(Color.BLUE).geodesic(true);
           for (int i = 0; i < points.size(); i++) {
               LatLng point = points.get(i);
               options.add(point);
           }
           addMarker(); //add Marker in current position
           line = googleMap.addPolyline(options); //add Polyline

       }

    }

1 ответ

Это может быть одним из решений
1. Получить текущее местоположение пользователя и обновить его на своем сервере.
2. Используйте Firebase для вашего внутреннего сервера. Это облегчает многие вещи. Сохраните местоположение пользователя в firebase.
3. В админ-панели получить местоположение пользователя из firebase.
Вы можете использовать уведомления, чтобы уведомить администратора о текущем местоположении пользователя после того, как пользователь обновил его в firebase.

Другие вопросы по тегам