/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
/*
* Do not modify this file. This file is generated from the location-2020-11-19.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.LocationService.Model
{
///
/// Contains the calculated route's details for each path between a pair of positions.
/// The number of legs returned corresponds to one fewer than the total number of positions
/// in the request.
///
///
///
/// For example, a route with a departure position and destination position returns one
/// leg with the positions snapped
/// to a nearby road:
///
/// -
///
/// The
StartPosition
is the departure position.
///
/// -
///
/// The
EndPosition
is the destination position.
///
///
///
/// A route with a waypoint between the departure and destination position returns two
/// legs with the positions snapped to a nearby road:
///
/// -
///
/// Leg 1: The
StartPosition
is the departure position . The EndPosition
/// is the waypoint positon.
///
/// -
///
/// Leg 2: The
StartPosition
is the waypoint position. The EndPosition
/// is the destination position.
///
///
///
public partial class Leg
{
private double? _distance;
private double? _durationSeconds;
private List _endPosition = new List();
private LegGeometry _geometry;
private List _startPosition = new List();
private List _steps = new List();
///
/// Gets and sets the property Distance.
///
/// The distance between the leg's StartPosition
and EndPosition
/// along a calculated route.
///
/// -
///
/// The default measurement is
Kilometers
unless the request specifies a
/// DistanceUnit
of Miles
.
///
///
///
[AWSProperty(Required=true, Min=0)]
public double Distance
{
get { return this._distance.GetValueOrDefault(); }
set { this._distance = value; }
}
// Check to see if Distance property is set
internal bool IsSetDistance()
{
return this._distance.HasValue;
}
///
/// Gets and sets the property DurationSeconds.
///
/// The estimated travel time between the leg's StartPosition
and EndPosition
.
/// The travel mode and departure time that you specify in the request determines the
/// calculated time.
///
///
[AWSProperty(Required=true, Min=0)]
public double DurationSeconds
{
get { return this._durationSeconds.GetValueOrDefault(); }
set { this._durationSeconds = value; }
}
// Check to see if DurationSeconds property is set
internal bool IsSetDurationSeconds()
{
return this._durationSeconds.HasValue;
}
///
/// Gets and sets the property EndPosition.
///
/// The terminating position of the leg. Follows the format [longitude,latitude]
.
///
///
///
/// If the EndPosition
isn't located on a road, it's snapped
/// to a nearby road.
///
///
///
[AWSProperty(Required=true, Sensitive=true, Min=2, Max=2)]
public List EndPosition
{
get { return this._endPosition; }
set { this._endPosition = value; }
}
// Check to see if EndPosition property is set
internal bool IsSetEndPosition()
{
return this._endPosition != null && this._endPosition.Count > 0;
}
///
/// Gets and sets the property Geometry.
///
/// Contains the calculated route's path as a linestring geometry.
///
///
public LegGeometry Geometry
{
get { return this._geometry; }
set { this._geometry = value; }
}
// Check to see if Geometry property is set
internal bool IsSetGeometry()
{
return this._geometry != null;
}
///
/// Gets and sets the property StartPosition.
///
/// The starting position of the leg. Follows the format [longitude,latitude]
.
///
///
///
/// If the StartPosition
isn't located on a road, it's snapped
/// to a nearby road.
///
///
///
[AWSProperty(Required=true, Sensitive=true, Min=2, Max=2)]
public List StartPosition
{
get { return this._startPosition; }
set { this._startPosition = value; }
}
// Check to see if StartPosition property is set
internal bool IsSetStartPosition()
{
return this._startPosition != null && this._startPosition.Count > 0;
}
///
/// Gets and sets the property Steps.
///
/// Contains a list of steps, which represent subsections of a leg. Each step provides
/// instructions for how to move to the next step in the leg such as the step's start
/// position, end position, travel distance, travel duration, and geometry offset.
///
///
[AWSProperty(Required=true)]
public List Steps
{
get { return this._steps; }
set { this._steps = value; }
}
// Check to see if Steps property is set
internal bool IsSetSteps()
{
return this._steps != null && this._steps.Count > 0;
}
}
}