IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

QGeoRouteRequest Class

The QGeoRouteRequest class represents the parameters and restrictions which define a request for routing information.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

QGeoRouteRequest Class

  • Header: QGeoRouteRequest

  • qmake: QT += location

  • Group: QGeoRouteRequest is part of QtLocation-routing

I. Detailed Description

The default state of a QGeoRouteRequest instance will result in a request for basic route segment and navigation maneuvers describing the fastest route by car which covers the given waypoints.

There may be significant variation in the features supported by different providers of routing information, or even in the features supported by the same provider if different levels of authorization are used.

There are several functions in QGeoRoutingManager which can be used to check which features are supported with the current provider and authorization level.

I-1. See Also

II. Member Type Documentation

 

II-1. enum QGeoRouteRequest::FeatureType

flags QGeoRouteRequest::FeatureTypes

Defines a feature which is important to the planning of a route.

These values will be used in combination with QGeoRouteRequest::FeatureWeight to determine if they should or should not be part of the route.

Constant

Value

Description

QGeoRouteRequest::NoFeature

0x00000000

Used by QGeoRoutingManager::supportedFeatureTypes() to indicate that no features will be taken into account when planning the route.

QGeoRouteRequest::TollFeature

0x00000001

Consdier tollways when planning the route.

QGeoRouteRequest::HighwayFeature

0x00000002

Consider highways when planning the route.

QGeoRouteRequest::PublicTransitFeature

0x00000004

Consider public transit when planning the route.

QGeoRouteRequest::FerryFeature

0x00000008

Consider ferries when planning the route.

QGeoRouteRequest::TunnelFeature

0x00000010

Consider tunnels when planning the route.

QGeoRouteRequest::DirtRoadFeature

0x00000020

Consider dirt roads when planning the route.

QGeoRouteRequest::ParksFeature

0x00000040

Consider parks when planning the route.

QGeoRouteRequest::MotorPoolLaneFeature

0x00000080

Consider motor pool lanes when planning the route.

QGeoRouteRequest::TrafficFeature

0x00000100

Consider the current traffic situation when planning the route. Since QtLocation 5.10

The FeatureTypes type is a typedef for QFlags<FeatureType>. It stores an OR combination of FeatureType values.

II-2. enum QGeoRouteRequest::FeatureWeight

flags QGeoRouteRequest::FeatureWeights

Defines the weight to associate with a feature during the planning of a route.

These values will be used in combination with QGeoRouteRequest::Feature to determine if they should or should not be part of the route.

Constant

Value

Description

QGeoRouteRequest::NeutralFeatureWeight

0x00000000

The presence or absence of the feature will not affect the planning of the route.

QGeoRouteRequest::PreferFeatureWeight

0x00000001

Routes which contain the feature will be preferred over those that do not.

QGeoRouteRequest::RequireFeatureWeight

0x00000002

Only routes which contain the feature will be considered, otherwise no route will be returned.

QGeoRouteRequest::AvoidFeatureWeight

0x00000004

Routes which do not contain the feature will be preferred over those that do.

QGeoRouteRequest::DisallowFeatureWeight

0x00000008

Only routes which do not contain the feature will be considered, otherwise no route will be returned.

The FeatureWeights type is a typedef for QFlags<FeatureWeight>. It stores an OR combination of FeatureWeight values.

II-3. enum QGeoRouteRequest::ManeuverDetail

flags QGeoRouteRequest::ManeuverDetails

Defines the amount of maneuver information that should be included with the route.

Constant

Value

Description

QGeoRouteRequest::NoManeuvers

0x0000

No maneuvers should be included with the route.

QGeoRouteRequest::BasicManeuvers

0x0001

Basic manevuers will be included with the route. This will include QGeoManeuver::instructionText().

The ManeuverDetails type is a typedef for QFlags<ManeuverDetail>. It stores an OR combination of ManeuverDetail values.

II-4. enum QGeoRouteRequest::RouteOptimization

flags QGeoRouteRequest::RouteOptimizations

Defines the type of optimization which is applied to the planning of the route.

Constant

Value

Description

QGeoRouteRequest::ShortestRoute

0x0001

Minimize the length of the journey.

QGeoRouteRequest::FastestRoute

0x0002

Minimize the traveling time for the journey.

QGeoRouteRequest::MostEconomicRoute

0x0004

Minimize the cost of the journey.

QGeoRouteRequest::MostScenicRoute

0x0008

Maximize the scenic potential of the journey.

The RouteOptimizations type is a typedef for QFlags<RouteOptimization>. It stores an OR combination of RouteOptimization values.

II-5. enum QGeoRouteRequest::SegmentDetail

flags QGeoRouteRequest::SegmentDetails

Defines the amount of route segment information that should be included with the route.

Constant

Value

Description

QGeoRouteRequest::NoSegmentData

0x0000

No segment data should be included with the route. A route requested with this level of segment detail will initialize QGeoRouteSegment::path() as a straight line between the positions of the previous and next QGeoManeuver instances.

QGeoRouteRequest::BasicSegmentData

0x0001

Basic segment data will be included with the route. This will include QGeoRouteSegment::path().

The SegmentDetails type is a typedef for QFlags<SegmentDetail>. It stores an OR combination of SegmentDetail values.

II-6. enum QGeoRouteRequest::TravelMode

flags QGeoRouteRequest::TravelModes

Defines modes of travel to be used for a route.

Constant

Value

Description

QGeoRouteRequest::CarTravel

0x0001

The route will be optimized for someone who is driving a car.

QGeoRouteRequest::PedestrianTravel

0x0002

The route will be optimized for someone who is walking.

QGeoRouteRequest::BicycleTravel

0x0004

The route will be optimized for someone who is riding a bicycle.

QGeoRouteRequest::PublicTransitTravel

0x0008

The route will be optimized for someone who is making use of public transit.

QGeoRouteRequest::TruckTravel

0x0010

The route will be optimized for someone who is driving a truck.

The TravelModes type is a typedef for QFlags<TravelMode>. It stores an OR combination of TravelMode values.

III. Member Function Documentation

 

III-1. [explicit] QGeoRouteRequest::QGeoRouteRequest(const QList<QGeoCoordinate> &waypoints = QList<QGeoCoordinate>())

Constructs a request to calculate a route through the coordinates waypoints.

The route will traverse the objects of waypoints in order.

III-2. QGeoRouteRequest::QGeoRouteRequest(const QGeoCoordinate &origin, const QGeoCoordinate &destination)

Constructs a request to calculate a route between origin and destination.

III-3. QGeoRouteRequest::QGeoRouteRequest(const QGeoRouteRequest &other)

Constructs a route request object from the contents of other.

III-4. QGeoRouteRequest::~QGeoRouteRequest()

Destroys the request.

III-5. QDateTime QGeoRouteRequest::departureTime() const

Returns the departure time in the request.

III-5-1. See Also

See also setDepartureTime()

III-6. QList<QGeoRectangle> QGeoRouteRequest::excludeAreas() const

Returns areas the route must not cross.

III-6-1. See Also

See also setExcludeAreas()

III-7. QList<QGeoRouteRequest::FeatureType> QGeoRouteRequest::featureTypes() const

Returns the list of features that will be considered when planning the route. Features with a weight of NeutralFeatureWeight will not be returned.

III-8. QGeoRouteRequest::FeatureWeight QGeoRouteRequest::featureWeight(QGeoRouteRequest::FeatureType featureType) const

Returns the weight assigned to featureType in the planning of the route.

If no feature weight has been specified for featureType then NeutralFeatureWeight will be returned.

III-8-1. See Also

See also setFeatureWeight()

III-9. QGeoRouteRequest::ManeuverDetail QGeoRouteRequest::maneuverDetail() const

Returns the level of detail which will be used in the representation of routing maneuvers.

III-9-1. See Also

See also setManeuverDetail()

III-10. int QGeoRouteRequest::numberAlternativeRoutes() const

Returns the number of alternative routes which will be requested.

III-10-1. See Also

III-11. QGeoRouteRequest::RouteOptimizations QGeoRouteRequest::routeOptimization() const

Returns the optimization criteria which this request specifies should be used while planning the route.

III-11-1. See Also

III-12. QGeoRouteRequest::SegmentDetail QGeoRouteRequest::segmentDetail() const

Returns the level of detail which will be used in the representation of routing segments.

III-12-1. See Also

See also setSegmentDetail()

III-13. void QGeoRouteRequest::setDepartureTime(const QDateTime &departureTime)

Sets the departure time departureTime for the route calculation. This information can be used by the backend to calculate a faster route, for example, by avoiding traffic congestion during rush hour.

The default value is an invalid QDateTime.

III-13-1. See Also

See also departureTime()

III-14. void QGeoRouteRequest::setExcludeAreas(const QList<QGeoRectangle> &areas)

Sets areas as excluded areas that the route must not cross.

III-14-1. See Also

See also excludeAreas()

III-15. void QGeoRouteRequest::setFeatureWeight(QGeoRouteRequest::FeatureType featureType, QGeoRouteRequest::FeatureWeight featureWeight)

Assigns the weight featureWeight to the feature featureType during the planning of the route.

By default all features are assigned a weight of NeutralFeatureWeight.

It is impossible to assign a weight to QGeoRouteRequest::NoFeature.

III-15-1. See Also

See also featureWeight()

III-16. void QGeoRouteRequest::setManeuverDetail(QGeoRouteRequest::ManeuverDetail maneuverDetail)

Sets the level of detail to use when representing routing maneuvers to maneuverDetail.

The default value is QGeoRouteRequest::BasicManeuvers.

III-16-1. See Also

See also maneuverDetail()

III-17. void QGeoRouteRequest::setNumberAlternativeRoutes(int alternatives)

Sets the number of alternative routes to request to alternatives. If alternatives is negative the number of alternative routes is set to 0.

The default value is 0.

III-17-1. See Also

III-18. void QGeoRouteRequest::setRouteOptimization(QGeoRouteRequest::RouteOptimizations optimization)

Sets the optimization criteria to use while planning the route to optimization.

The default value is QGeoRouteRequest::FastestRoute.

III-18-1. See Also

See also routeOptimization()

III-19. void QGeoRouteRequest::setSegmentDetail(QGeoRouteRequest::SegmentDetail segmentDetail)

Sets the level of detail to use when representing routing segments to segmentDetail.

III-19-1. See Also

See also segmentDetail()

III-20. void QGeoRouteRequest::setTravelModes(QGeoRouteRequest::TravelModes travelModes)

Sets the travel modes which should be considered during the planning of the route to travelModes.

The default value is QGeoRouteRequest::CarTravel.

III-20-1. See Also

See also travelModes()

III-21. void QGeoRouteRequest::setWaypoints(const QList<QGeoCoordinate> &waypoints)

Sets waypoints as the waypoints that the route should pass through.

The waypoints should be given in order from origin to destination.

This request will be invalid until the waypoints have been set to a list containing two or more coordinates.

III-21-1. See Also

See also waypoints()

III-22. QGeoRouteRequest::TravelModes QGeoRouteRequest::travelModes() const

Returns the travel modes which this request specifies should be considered during the planning of the route.

III-22-1. See Also

See also setTravelModes()

III-23. QList<QGeoCoordinate> QGeoRouteRequest::waypoints() const

Returns the waypoints that the route will pass through.

III-23-1. See Also

See also setWaypoints()

III-24. QGeoRouteRequest &QGeoRouteRequest::operator=(const QGeoRouteRequest &other)

Assigns other to this route request object and then returns a reference to this route request object.

IV. Related Non-Members

 

IV-1. bool operator!=(const QGeoRouteRequest &lhs, const QGeoRouteRequest &rhs)

Returns whether the route requests lhs and rhs are not equal.

IV-2. bool operator==(const QGeoRouteRequest &lhs, const QGeoRouteRequest &rhs)

Returns whether the route requests lhs and rhs are equal.

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+