本文整理匯總了Python中django.contrib.gis.geos.LineString.project方法的典型用法代碼示例。如果您正苦於以下問題:Python LineString.project方法的具體用法?Python LineString.project怎麽用?Python LineString.project使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類django.contrib.gis.geos.LineString
的用法示例。
在下文中一共展示了LineString.project方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: crossovers
# 需要導入模塊: from django.contrib.gis.geos import LineString [as 別名]
# 或者: from django.contrib.gis.geos.LineString import project [as 別名]
#.........這裏部分代碼省略.........
else:
idx1 = idx1 - 1
#If current linestring is not made exclusively of crossovers, check
# if next one is.
elif len(lines[idx+1].coords) == 2 and idx+1 != len(lines)-1:
idx2 = idx+2
while idx2 < len(lines):
if idx2 == len(lines)-1 or len(lines[idx2].coords) > 2:
point1 = Point(lines[idx].coords[-2])
point2 = Point(lines[idx2].coords[1])
#break loop
break
else:
idx2 += 1
else:
point1 = Point(lines[idx].coords[-2])
point2 = Point(lines[idx+1].coords[1])
#Find the change in x/y in order to determine slope
change_x = point1[0] - point2[0]
change_y = point1[1] - point2[1]
#Check if the change in x is zero
if change_x == 0:
slope = None
else:
slope = change_y/change_x
#Create a new line object from the two points adjacent to the
# crossover.
newline = LineString(point1,point2)
#Find the crossover point/interpolate the gps time.
crossover = Point(lines[idx].coords[-1])
cross_pt = newline.interpolate(newline.project(crossover))
#Use crossover coordinates as keys for a dictionary storing gps
# times
if (crossover[0],crossover[1]) not in crossover_gps.keys():
crossover_gps[crossover[0],crossover[1]] = [cross_pt[2]]
else:
crossover_gps[crossover[0],crossover[1]].append(cross_pt[2])
#Use crossover coordinates as keys for a dictionary storing slopes
if (crossover[0],crossover[1]) not in crossover_slopes.keys():
crossover_slopes[crossover[0], crossover[1]] = [slope]
else:
crossover_slopes[crossover[0], crossover[1]].append(slope)
#Create a dictionary holding both gps times and slopes.
crossovers = crossover_gps
for key in crossover_slopes:
crossovers[key].append(crossover_slopes[key][0])
crossovers[key].append(crossover_slopes[key][1])
del crossover_gps, crossover_slopes
#Extract self-intersecting crossovers information from above.
self_cross_pts = []
self_gps1 = []
self_gps2 = []
self_angles = []
for x,y in crossovers:
self_cross_pts.append(Point(x,y))
self_gps1.append(crossovers[x,y][0])
self_gps2.append(crossovers[x,y][1])
#Determine angle of intersection
slope1 = crossovers[x,y][2]