- QGIS Python Programming Cookbook
- Joel Lawhead
- 243字
- 2021-07-23 19:48:54
Measuring the distance along a line sample
In this recipe, we'll measure the distance along a line with multiple vertices.
Getting ready
For this recipe, we'll use a line shapefile with two features. You can download the shapefile as a .ZIP
file from https://geospatialpython.googlecode.com/svn/paths.zip
Unzip the shapefile into a directory named qgis_data/shapes
within your root or home directory.
How to do it...
The steps for this recipe are fairly straightforward. We'll extract the geometry from the first line feature and pass it to the measurement object, as shown here:
- First, we must load the QGIS constants library:
from qgis.core import QGis
- Load the line layer:
lyr = QgsVectorLayer("/qgis_data/shapes/paths.shp", "Route", "ogr")
- Grab the features:
fts = lyr.getFeatures()
- Get the first feature:
route = fts.next()
- Create the measurement object instance:
d = QgsDistanceArea()
- Then, we must configure the QgsDistanceArea object to use the ellipsoidal mode for accurate measurements in meters:
d.setEllipsoidalMode(True)
- Pass the line's geometry to the
measureLine
method:m = d.measureLine(route.geometry().asPolyline())
- Convert the measurement output to miles:
d.convertMeasurement(m, QGis.Meters, QGis.NauticalMiles, False)
Ensure that your output looks similar to the following:
(2314126.583384674, 7)
How it works...
The QgsDistanceArea object can perform any type of measurement, based on the method you call. When you convert the measurement from meters (represented by 0) to miles (identified by the number 7), you will get a tuple with the measurement in miles and the unit identifier. The QGIS API documentation shows the values for all the unit constants
- Power Up Your PowToon Studio Project
- 控糖控脂健康餐
- 無代碼編程:用云表搭建企業數字化管理平臺
- 算法精粹:經典計算機科學問題的Java實現
- Python測試開發入門與實踐
- Mastering Python Scripting for System Administrators
- Python高級編程
- 碼上行動:用ChatGPT學會Python編程
- Integrating Facebook iOS SDK with Your Application
- Go語言精進之路:從新手到高手的編程思想、方法和技巧(2)
- OpenGL Data Visualization Cookbook
- Java語言程序設計教程
- ExtJS Web應用程序開發指南第2版
- 黑莓(BlackBerry)開發從入門到精通
- 微信公眾平臺開發最佳實踐