RouteQuery QML Type
The RouteQuery type is used to provide query parameters to a RouteModel. More...
| Import Statement: | import QtLocation 5.12 | 
| Since: | QtLocation 5.5 | 
Properties
- excludedAreas : list<georectangle>
- extraParameters : VariantMap
- featureTypes : QList<FeatureType>
- maneuverDetail : enumeration
- numberAlternativeRoutes : int
- routeOptimizations : enumeration
- segmentDetail : enumeration
- travelModes : enumeration
- waypoints : list<coordinate>
Methods
- void addExcludedArea(georectangle)
- void addWaypoint(coordinate)
- void clearExcludedAreas()
- void clearWaypoints()
- FeatureWeight featureWeight(FeatureType featureType)
- void removeExcludedArea(georectangle)
- void removeWaypoint(coordinate)
- void resetFeatureWeights()
- void setFeatureWeight(FeatureType, FeatureWeight)
- list<Waypoint> waypointObjects()
Detailed Description
A RouteQuery is used to pack all the parameters necessary to make a request to a routing service, which can then populate the contents of a RouteModel.
These parameters describe key details of the route, such as waypoints to pass through, excludedAreas to avoid, the travelModes in use, as well as detailed preferences on how to optimize the route and what features to prefer or avoid along the path (such as toll roads, highways, etc).
RouteQuery objects are used exclusively to fill out the value of a RouteModel's query property, which can then begin the retrieval process to populate the model.
Some plugins might allow or require specific parameters to operate. In order to specify these plugin-specific parameters, MapParameter elements can be nested inside a RouteQuery.
Example Usage
The following snipped shows an incomplete example of creating a RouteQuery object and setting it as the value of a RouteModel's query property.
 RouteQuery {
     id: aQuery
 }
 RouteModel {
     query: aQuery
     autoUpdate: false
 }
For a more complete example, see the documentation for the RouteModel type, and the Mapviewer example.
See also RouteModel.
Property Documentation
| excludedAreas : list<georectangle> | 
Areas that the route must not cross.
Excluded areas can be set as part of the RouteQuery type declaration or dynamically with the functions provided.
See also addExcludedArea, removeExcludedArea, and clearExcludedAreas.
The route query extra parameters. This property is read only. If the query is defined by the user, these can be set by using MapParameters. If the route query comes from the engine via signals, the query is intended to be read-only.
This property was introduced in Qt 5.11.
List of features that will be considered when planning the route. Features with a weight of NeutralFeatureWeight will not be returned.
- RouteQuery.NoFeature - No features will be taken into account when planning the route
- RouteQuery.TollFeature - Consider tollways when planning the route
- RouteQuery.HighwayFeature - Consider highways when planning the route
- RouteQuery.PublicTransitFeature - Consider public transit when planning the route
- RouteQuery.FerryFeature - Consider ferries when planning the route
- RouteQuery.TunnelFeature - Consider tunnels when planning the route
- RouteQuery.DirtRoadFeature - Consider dirt roads when planning the route
- RouteQuery.ParksFeature - Consider parks when planning the route
- RouteQuery.MotorPoolLaneFeature - Consider motor pool lanes when planning the route
- RouteQuery.TrafficFeature - Consider traffic when planning the route
See also setFeatureWeight and featureWeight.
| maneuverDetail : enumeration | 
The level of detail which will be used in the representation of routing maneuvers.
| Constant | Description | 
|---|---|
| RouteQuery.NoManeuvers | No maneuvers should be included with the route | 
| RouteQuery.BasicManeuvers | Basic maneuvers will be included with the route | 
The default value is RouteQuery.BasicManeuvers.
| numberAlternativeRoutes : int | 
The number of alternative routes requested when requesting routes. The default value is 0.
| routeOptimizations : enumeration | 
The route optimizations which should be considered during the planning of the route. Values can be combined with OR ('|') -operator.
| Constant | Description | 
|---|---|
| RouteQuery.ShortestRoute | Minimize the length of the journey | 
| RouteQuery.FastestRoute | Minimize the traveling time for the journey | 
| RouteQuery.MostEconomicRoute | Minimize the cost of the journey | 
| RouteQuery.MostScenicRoute | Maximize the scenic potential of the journey | 
The default value is RouteQuery.FastestRoute.
| segmentDetail : enumeration | 
The level of detail which will be used in the representation of routing segments.
| Constant | Description | 
|---|---|
| RouteQuery.NoSegmentData | No segment data should be included with the route | 
| RouteQuery.BasicSegmentData | Basic segment data will be included with the route | 
The default value is RouteQuery.BasicSegmentData.
| travelModes : enumeration | 
The travel modes which should be considered during the planning of the route. Values can be combined with OR ('|') -operator.
| Constant | Description | 
|---|---|
| RouteQuery.CarTravel | The route will be optimized for someone who is driving a car | 
| RouteQuery.PedestrianTravel | The route will be optimized for someone who is walking | 
| RouteQuery.BicycleTravel | The route will be optimized for someone who is riding a bicycle | 
| RouteQuery.PublicTransit | Travel The route will be optimized for someone who is making use of public transit | 
| RouteQuery.TruckTravel | The route will be optimized for someone who is driving a truck | 
The default value is RouteQuery.CarTravel.
| waypoints : list<coordinate> | 
The coordinates of the waypoints for the desired route. The waypoints should be given in order from origin to destination. Two or more coordinates are needed.
Waypoints can be set as part of the RouteQuery type declaration or dynamically with the functions provided.
When setting this property to a list of waypoints, each waypoint can be either a coordinate or a Waypoint, interchangeably. If a coordinate is passed, it will be internally converted to a Waypoint.
This property, however, always contains a list of coordinates.
See also waypointObjects, addWaypoint, removeWaypoint, and clearWaypoints.
Method Documentation
Adds the given area to excluded areas (areas that the route must not cross). Same area can only be added once.
See also removeExcludedArea and clearExcludedAreas.
Appends a coordinate to the list of waypoints. Same coordinate can be set multiple times. The coordinate argument can be a coordinate or a Waypoint. If a coordinate is used, it will be internally converted to a Waypoint.
See also removeWaypoint and clearWaypoints.
Clears all excluded areas (areas that the route must not cross).
See also addExcludedArea and removeExcludedArea.
Clears all waypoints.
See also removeWaypoint and addWaypoint.
Gets the weight for the featureType.
See also featureTypes, setFeatureWeight, and resetFeatureWeights.
Removes the given area to excluded areas (areas that the route must not cross).
See also addExcludedArea and clearExcludedAreas.
Removes the given from the list of waypoints. In case same coordinate appears multiple times, the most recently added coordinate instance is removed.
See also addWaypoint and clearWaypoints.
Resets all feature weights to their default state (NeutralFeatureWeight).
See also featureTypes, setFeatureWeight, and featureWeight.
Defines the weight to associate with a feature during the planning of a route.
Following lists the possible feature weights:
| Constant | Description | 
|---|---|
| RouteQuery.NeutralFeatureWeight | The presence or absence of the feature will not affect the planning of the route | 
| RouteQuery.PreferFeatureWeight | Routes which contain the feature will be preferred over those that do not | 
| RouteQuery.RequireFeatureWeight | Only routes which contain the feature will be considered, otherwise no route will be returned | 
| RouteQuery.AvoidFeatureWeight | Routes which do not contain the feature will be preferred over those that do | 
| RouteQuery.DisallowFeatureWeight | Only routes which do not contain the feature will be considered, otherwise no route will be returned | 
See also featureTypes, resetFeatureWeights, and featureWeight.
This method can be used to retrieve the list of Waypoint objects relative to RouteQuery::waypoints.
See also waypointObjects, addWaypoint, removeWaypoint, and clearWaypoints.