如何在地理围栏中获得停留时间?

时间:2018-07-10 21:59:13

标签: geolocation android-geofence

简单问题需要简单答案。 如何在特定地理围栏中跟踪停留时间。 当我在Enter时使用“触发”添加地理围栏时,离开该地理围栏时会自动收到触发器。基本上,我需要记住进入地理围栏和离开该地理围栏的时间,这样我就可以减去离开进入时间并获得持续时间。但是我认为做到这一点并不容易。那么还有其他想法或建议如何有效解决该问题吗? 谢谢

1 个答案:

答案 0 :(得分:0)

我找到了解决此问题的一种方法。为了确定地理围栏的停留时间,我必须获取用户触发地理围栏的时间,然后使用这种数学方法来计算用户是否离开地理围栏

 Handler handler = new Handler();
    getCurrentLatLng();
    final Runnable myRunnable = new Runnable() {
        public void run() {
            GeofenceFinished myFinishedGeofence = db.getGeofenceFinishedByID("Finished" + id);
            if (!isUserInRegion(latitude, longitude, myLatLng.latitude, myLatLng.longitude, rd)
                    || myFinishedGeofence == null) {
                String time = convertTime(endTime - startTime);
                // get the finishedGeofence and set the duration of stay time
                if (myFinishedGeofence != null)
                    setDurationOfStay("Finished" + id, time, getCurrentTime(System.currentTimeMillis()));
                Toast.makeText(mContext, "Finish to determine duration of stay of " + myFinishedGeofence.getAddress(), Toast.LENGTH_SHORT).show();
                handler.removeCallbacks(this);
            } else {
                getCurrentLatLng();
                endTime += Constants.DELAY;
                handler.postDelayed(this, Constants.DELAY);
            }
        }

        private void setDurationOfStay(String geofenceid, String time, String endTime) {
            if (db == null) db = GeofenceDatabaseHelper.getInstance(mContext);
            if (!db.setDurationOfFinishedGeofence(geofenceid, time, endTime)) {
                Log.i("setDurationOfStay", "fail");
            }
        }
    };
    handler.postDelayed(myRunnable, Constants.DELAY);

private boolean isUserInRegion(double firstLat, double firstLog, double curLat, double curLog, float radius) {
    double distance = calculateDistance(firstLat, firstLog, curLat, curLog);
    return distance <= radius;
}

要计算用户与地理围栏中心的距离,我需要将当前的纬度和经度转换为米,因此可以使用参数equation for circle

进行计算。

所以我从github使用这种方法

    // https://github.com/mgavaghan/geodesy
private double calculateDistance(double firstLat, double firstLog, double curLat, double curLog) {
    GeodeticCalculator geoCalc = new GeodeticCalculator();
    Ellipsoid reference = Ellipsoid.WGS84;
    GlobalPosition pointA = new GlobalPosition(firstLat, firstLog, 0.0); // Point A
    GlobalPosition userPos = new GlobalPosition(curLat, curLog, 0.0); // Point B
    // Distance between Point A and Point B
    double distance = geoCalc.calculateGeodeticCurve(reference, userPos, pointA).getEllipsoidalDistance();
    return distance;
}

希望它可以帮助某人:D