Get direction (compass) with two longitude/latitude points

前端 未结 4 1799
遥遥无期
遥遥无期 2020-12-02 12:19

I\'m working on a "compass" for a mobile-device. I have the following points:

point 1 (current location): Latitude = 47.2246, Longitude = 8.8257
poi         


        
相关标签:
4条回答
  • 2020-12-02 13:03

    I found some useful gps coordinates formula in math here. For this case, here my solution

     private double getDirection(double lat1, double lng1, double lat2, double lng2) {
    
        double PI = Math.PI;
        double dTeta = Math.log(Math.tan((lat2/2)+(PI/4))/Math.tan((lat1/2)+(PI/4)));
        double dLon = Math.abs(lng1-lng2);
        double teta = Math.atan2(dLon,dTeta);
        double direction = Math.round(Math.toDegrees(teta));
        return direction; //direction in degree
    
    }
    
    0 讨论(0)
  • 2020-12-02 13:09

    I couldn't understand your solution well, calculating the slope worked for me. To modify on efwjames's and your answer. This should do -

    import math
    def getDegrees(lat1, lon1, lat2, lon2,head):
        dLat = math.radians(lat2-lat1)
        dLon = math.radians(lon2-lon1)
        bearing = math.degrees(math.atan2(dLon, dLat))
        return head-bearing
    
    0 讨论(0)
  • 2020-12-02 13:13

    You'd need to calculate an Euclidean vector between your start point and end point, then calculate its angle (let's say relative to positive X) which would be the angle you want to rotate your arrow by.

    0 讨论(0)
  • 2020-12-02 13:26

    O forgot to say I found the answer eventually. The application is to determine compass direction of a transit vehicle and its destination. Essentially, fancy math for acquiring curvature of Earth, finding an angle/compass reading, and then matching that angle with a generic compass value. You could of course just keep the compassReading and apply that as an amount of rotation for your image. Please note this is an averaged determination of the vehicle direction to the end point (bus station) meaning it can't know what the road is doing (so this probably best applies to airplanes or roller derby).

    //example obj data containing lat and lng points
    //stop location - the radii end point
    endpoint.lat = 44.9631;
    endpoint.lng = -93.2492;
    
    //bus location from the southeast - the circle center
    startpoint.lat = 44.95517;
    startpoint.lng = -93.2427;
    
    function vehicleBearing(endpoint, startpoint) {
        endpoint.lat = x1;
        endpoint.lng = y1;
        startpoint.lat = x2;
        startpoint.lng = y2;
    
        var radians = getAtan2((y1 - y2), (x1 - x2));
    
        function getAtan2(y, x) {
            return Math.atan2(y, x);
        };
    
        var compassReading = radians * (180 / Math.PI);
    
        var coordNames = ["N", "NE", "E", "SE", "S", "SW", "W", "NW", "N"];
        var coordIndex = Math.round(compassReading / 45);
        if (coordIndex < 0) {
            coordIndex = coordIndex + 8
        };
    
        return coordNames[coordIndex]; // returns the coordinate value
    }
    

    ie: vehicleBearing(mybus, busstation) might return "NW" means its travelling northwesterly

    0 讨论(0)
提交回复
热议问题