How to move marker on the Google Map like Ola app

前端 未结 3 967
日久生厌
日久生厌 2021-01-03 17:15

I am working on app the like Ola cabs. When the user drags map the a view transparent view appears with marker moving and when the user stops dragging the we have to centre

3条回答
  •  心在旅途
    2021-01-03 17:57

    I have achieved this kind of things in two apps which are related with live tracking of vahicle.

    There are some requirements that I have used:

    1. App having Always location usage permission with proper battery usage message.
    2. Used Socket connection on both end. Driver & Customer. For that Socket.io is used. Same is configured in Web.
    3. Trigged location service at every 2 sec, so that I can handle battery usage.
    4. Every 2 sec, send data to socket and socket listener can use that data to show car on map.
    5. Car icon in 90 degree rotate(car indicate to move on right side)

    Most important thing is that Driver latitude and longitude should with correct for showing car movement on the map. gmsMarker location consider as old value and newLocation value is current location.

    let preLoc = CLLocation.init(latitude: self.gmsMarker.position.latitude, longitude: self.gmsMarker.position.longitude)
    let curLoc = CLLocation.init(latitude: newLocation.latitude, longitude: newLocation.longitude)
    let changeInLocation = preLoc.distance(from: curLoc)
    if changeInLocation > 5{
        let degree = self.DegreeBearing(preLoc, curLoc)
        if degree > 5{
            self.gmsMarker.rotation = degree
        }
    }
    

    Below four function will calculate your travel direction and based on that car will show correct on road with moving.

    func DegreeBearing(_ A:CLLocation,_ B:CLLocation)-> Double{
        var dlon = self.ToRad(degrees: B.coordinate.longitude - A.coordinate.longitude)
        let dPhi = log(tan(self.ToRad(degrees: B.coordinate.latitude) / 2 + M_PI / 4) / tan(self.ToRad(degrees: A.coordinate.latitude) / 2 + M_PI / 4))
        if  abs(dlon) > M_PI{
            dlon = (dlon > 0) ? (dlon - 2*M_PI) : (2*M_PI + dlon)
        }
        return self.ToBearing(radians: atan2(dlon, dPhi))
    }
    
    func ToRad(degrees:Double) -> Double{
        return degrees*(M_PI/180)
    }
    
    func ToBearing(radians:Double)-> Double{
        return (ToDegrees(radians: radians) + 360).truncatingRemainder(dividingBy: 360)
    }
    
    func ToDegrees(radians:Double)->Double{
        return radians * 180 / M_PI
    }
    

    For Customer side, just show marker with whatever data you received from Driver side as self.gmsMarker.rotation value.

提交回复
热议问题