距离计算bug android

时间:2017-01-21 13:21:18

标签: android android-location

嗨,我一直在做应用程序来计算旅行的距离和速度。获得速度和距离的所有功能都很好,但是在测试过程中,我看到了只有在速度为19 Km / h时才能测量距离的错误

有人会知道为什么会这样吗?

由于

//initialize location listener
    locationListener = new LocationListener() {
        @Override
        public void onLocationChanged(Location location) {
            getSpeed(location);
            getDistance(location);
        }

        @Override
        public void onStatusChanged(String s, int i, Bundle bundle) {

        }

        @Override
        public void onProviderEnabled(String s) {

        }

        @Override
        public void onProviderDisabled(String s) {
        }

        //get the speed from the given location updates
        public void getSpeed(Location location) {
            currentSpeed = (location.getSpeed() * 3600 / 1000);
            String convertedSpeed = String.format("%.2f", currentSpeed);
            speedTxt.setText(convertedSpeed + "Km/h");
        }

        private void getDistance(Location location) {

            //to capture current location and keep as starting position of person
            if (pLat == 500.0 && pLng == 500.0 ){
                pLat = location.getLatitude();
                pLng = location.getLongitude();
            }

            if (cLat == 500.0 && cLng == 500.0){
                cLat = location.getLatitude();
                cLng=location.getLongitude();
            }

            //to check is the person has changed location
            if (pLat != cLat && pLng != cLng) {
                pLat = cLat;
                pLng = cLng;
            }

            //update the current location
            cLat = location.getLatitude();
            cLng = location.getLongitude();

            //call the calculation method
            distance += getDistanceBetweenGeoPoints(cLat, cLng, pLat, pLng);
            String convertedDistance = String.format("%.2f", distance);
            distanceTxt.setText(" " + convertedDistance);
        }

        public double getDistanceBetweenGeoPoints(Double cLat, Double cLng, Double pLat, Double pLng) {
            // CALCULATE DISTANCE BETWEEN TWO POINTS
            double earthRadius = 6367; //meters
            double dLat = Math.toRadians(cLat - pLat);
            double dLng = Math.toRadians(cLng - pLng);
            double a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
                    Math.cos(Math.toRadians(cLat)) * Math.cos(Math.toRadians(pLat)) *
                            Math.sin(dLng / 2) * Math.sin(dLng / 2);
            double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
            double dist = (double) (earthRadius * c);
            dist = Math.round(dist * 100) / 100.0;

            return dist;
        }
    };

2 个答案:

答案 0 :(得分:1)

由于此行,您的getDistanceBetweenGeoPoints函数将准确返回0以查找位置的小差异:

pressed

尝试将总距离四舍五入用于GetDistance()中的显示目的:

dist = Math.round(dist * 100) / 100.0;

答案 1 :(得分:0)

private void getDistance(Location location) {

    //to capture current location and keep as starting position of person
    if (pLat == 500.0 && pLng == 500.0) {
        pLat = location.getLatitude();
        pLng = location.getLongitude();
    }

    if (cLat == 500.0 && cLng == 500.0) {
        cLat = location.getLatitude();
        cLng = location.getLongitude();
    }

    //to check is the person has changed location
    if (pLat != cLat && pLng != cLng) {
        pLat = cLat;
        pLng = cLng;
    }

    //update the current location
    cLat = location.getLatitude();
    cLng = location.getLongitude();

    //call the calculation method
    distance += getDistanceBetweenGeoPoints(cLat, cLng, pLat, pLng);
    //String convertedDistance = String.format("%.2f", distance);
    String convertedDistance = String.format("%.2f", Math.round(distance * 100) / 100.0);
    distanceTxt.setText(" " + convertedDistance);
}

public double getDistanceBetweenGeoPoints(Double cLat, Double cLng, Double pLat, Double pLng) {
    // CALCULATE DISTANCE BETWEEN TWO POINTS
    double earthRadius = 6367; //meters
    double dLat = Math.toRadians(cLat - pLat);
    double dLng = Math.toRadians(cLng - pLng);
    double a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
            Math.cos(Math.toRadians(cLat)) * Math.cos(Math.toRadians(pLat)) *
                    Math.sin(dLng / 2) * Math.sin(dLng / 2);
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
    double dist = (double) (earthRadius * c);
    //dist = Math.round(dist * 100) / 100.0;

    return dist;
}