Creating Curved Lines in Google Maps
Sometimes you don’t want to zig and zag, you want to leap
data:image/s3,"s3://crabby-images/8efa7/8efa74983c5996eb2bafda2a74251817aa3d85cb" alt=""
Difficulty: easy | medium | hard.
If you don’t know, Google Maps now costs a lot of money when you use Google Directions APIs to draw a route from location A to location B.
And nowadays, some companies are converting the real route to a straight line as Uber did, or curved lines as Deliveree did.
So, I think this article will be helpful for all of you who:
- Want to create a new style to draw a route.
- Don’t want to lose money, feeding it into Google Maps’ pocket.
What’s the Solution to Draw a Curved Line?
If you want to draw a straight line to connect point A to point B, you need to know point A coordinates and point B coordinates.
OK. With a curved line, it combines many, many tiny points that are combined with straight lines. So, the main solution is to find each point’s coordinates on that curved line.
Let’s name these points like in the image below.
data:image/s3,"s3://crabby-images/cc734/cc7344997d3f9e7a7b7d1b30ca74c9d07eb2d696" alt=""
Firstly, create an initial path with:
data:image/s3,"s3://crabby-images/d5af7/d5af718c0d1735238104ade91c15b62855045073" alt=""
Step 1. Calculate SE
data:image/s3,"s3://crabby-images/6a49f/6a49f3c7576e9823d6d12afa4a7abcfb81d30b30" alt=""
Google Maps supports us to get the distance between two points on the map with the GMSGeometryDistance
function (unit is meters).
Step 2. Define a suitable number for the angle
We must choose a suitable number for the angle. If the angle is too large, O (central point) can be very far away from S or E, and the curved line will look like a straight line instead.
My suggestion is less than Pi /2. The smaller the angle is, the more the curved line can be curved.
Step 3. Calculate MO
Because we must also know the radius, let’s calculate the radius and MO with formulas.
data:image/s3,"s3://crabby-images/85bce/85bceb526701c89f40ffff2e6f9d83e2d236f463" alt=""
Here are some lines of code to help you calculate R and MO:
data:image/s3,"s3://crabby-images/6c106/6c1065c276960bc3d4aec4cb650a0a5b4412020c" alt=""
Step 4. Calculate O’s coordinates
Google Maps supports us:
GMSGeometryHeading
Returns the initial heading (degrees clockwise of north) at from
on the shortest path to to
.
The returned value is in the range [0, 360).
And:
GMSGeometryOffset
Returns the destination coordinates when starting at from
with initial heading
, traveling distance
in meters along a great circle arc, on the earth.
The resulting longitude is in the range [-180, 180).
We’ll combine GMSGeometryHeading
and GMSGeometryOffset
to find M’s coordinate.
Heading from start location to end location:
data:image/s3,"s3://crabby-images/74d04/74d0477a8eb85fbd09d8e236622afa6cb2553cd6" alt=""
Because S, M, and E are on the same line, we can find M’s coordinates with:
data:image/s3,"s3://crabby-images/f1540/f1540285b05828f48b2154cb5175254077b75b1a" alt=""
Next, find O’s coordinates.
There’ll be two coordinates for O, as in the image below, we have the blue O and the red O. For simplification, we can choose one.
data:image/s3,"s3://crabby-images/48250/48250c0b6677bc72c1cee0d6643fd926ecde852d" alt=""
For me, I want to choose a direction with the formula that is based on S longitude and E longitude.
data:image/s3,"s3://crabby-images/54d75/54d756d59bd6fe028f8388629e2f0a0fcaf87bd2" alt=""
Now, we have O’s coordinates with:
data:image/s3,"s3://crabby-images/7a667/7a66755c4d060b978003f4abd5b3e18ad69e0212" alt=""
Step 5. Find each location on the curved line with different angles (a1, a2, …an)
Now, this is the main part of drawing the curved line. You need to split the angle into n smaller angle, then combine with R-radius and O’s coordinates to find each point’s coordinates on the curved line.
In my example, the curved line needs to have 100 main points.
Here is my code to define each location on the curved line. Calculate each location’s coordinates and add them to the initial path we created above.
data:image/s3,"s3://crabby-images/297a7/297a7564cdd80e6455d8c519bc43474ce6c970e3" alt=""
Step 6. Convert GMSMutablePath to GMSPolyline
data:image/s3,"s3://crabby-images/7d9d3/7d9d3c4b60f1999c1c103f50dce44f055950afab" alt=""
I converted GMSMutablePath
to GMSPolyline
and added it into a map view, as well as set the stroke width and stroke color.
Yep, just that. Now we have all the code needed to draw a curved line.
data:image/s3,"s3://crabby-images/5fe08/5fe08d74632554d2dc46d84a6406e41cffbccccd" alt=""
Now, run it, I’ll try to draw a curved line from London to Cambridge and customize it, let’s see what the result is.
data:image/s3,"s3://crabby-images/b999a/b999a9a672751e57383359f1a2b3bb4c9d8d385c" alt=""