Я пытаюсь представить маршрут между количеством точек на статической карте, используя закодированную полилинию.Код для этого находится в функции getStaticMapAddress, определенной следующим образом:
def getStaticMapAddress(self, route):
destUser = DestUser(self.destination)
route += [destUser]
attempts = 0
while attempts < 10:
try:
encodedPolyline = self.encodePolyLine(route)
break
except googlemaps.GoogleMapsError:
print "Error. Try again"
attempts += 1
url = "http://maps.google.com/maps/api/staticmap?zoom="+encodedPolyline[1]+"&sensor=false&size=400x400&markers="
i=0
while i<len(route):
url += str(route[i].location.lat)+","+str(route[i].location.lng)
i=i+1
if i < len(route):
url += "|"
url += "&path=color:0xff0000ff|weight:5|enc:"+encodedPolyline[0]
return url
Маршрут представлен в виде списка объектов User (из которых DestUser является подклассом).Метод self.encodePolyLine () определяется следующим образом:
def encodePolyLine(self, route):
routePairs = []
destUser = DestUser(self.destination)
route += [destUser]
i=0
while (i < len(route)-1):
# GET ALL TURNING POINTS FOR EACH POINT ON ROUTE, THEN PUT THEM
# IN PAIRS AND SEND THEM TO glineenc.encode_pairs()
for step in gmaps.directions(gmaps.latlng_to_address(route[i].location.lat, route[i].location.lng), gmaps.latlng_to_address(route[i+1].location.lat, route[i+1].location.lng))['Directions']['Routes'][0]['Steps']:
routePairs += [(step['Point']['coordinates'][0], step['Point']['coordinates'][1])]
i=i+1
return glineenc.encode_pairs(routePairs)
Этот модуль glineenc относится к здесь и принимает список пар координат, возвращая пару, содержащую строку закодированной строкии закодированная строка, представляющая максимальный уровень масштабирования, чтобы можно было увидеть все точки.Итак, у меня есть маршрут, пролегающий между Брайтоном, Лондоном, Бристолем и Манчестером, по которому я прошел эту функцию.Следующий URL был выводом:
http://maps.google.com/maps/api/staticmap?zoom=B@@@@@?@AA@AA??A@@A@A@?@@@@@@@@B?@@@@@A@@@@@@?B@@AABABA@@@@@@@B&sensor=false&size=400x400&markers=50.8202008,-0.1324898|51.447341,-0.0761212|51.4608947,-2.5884312|53.4778853,-2.2308146|53.4778853,-2.2308146&path=color:0xff0000ff|weight:5|enc:b|XqvduHm@cDcMhAfAfFrc@{BlJgDqHaZkEy[vsKiwp@ciHahd@}nEwoK_KqB_QmoIpAyBw@Mv_BqxDmC`EasCvAeFuuAwi@_Rq|DuVnYgPdXyHvIcBcSgElgBkqBzKgh@`xD_cAzBpBvNM{HsHh]wNfbCzOxpCrUjeD_`Ahi@pItyGdXj`D_PjctLa}BzhH~nFn\dPfe@bObv@dC`i@fS_HrFk@~AmAzDsW_Ak_CmiAkuGy_GvxDctEolnBcpdEhtPc}Srp~AcvsCi_a@clJakR`]kiCr]opDtRcW}JhVcV_EmDaDhFkCc@
Если вы посмотрите это, вы увидите, что что-то пошло не так.Я не уверен, что именно произошло, но я заметил, что новый маршрут, по-видимому, является проекцией правильного маршрута, если он отражен с использованием экватора и меридиана в качестве линий симметрии.Не уверен, почему он это сделал, но это все, что я вижу в качестве возможной причины проблемы.Есть идеи?