Map Your Apps: Listing 2.

Drawing an arc using a Bezier curve.

private void DrawCurve(Location start, Location finish)
{
  MapPolyline curve = new MapPolyline();
  curve.Stroke = new SolidColorBrush(Colors.Magenta);
  curve.StrokeThickness = 3.0;
  curve.StrokeDashArray = new DoubleCollection(new double[] { 5, 2 });
  curve.Opacity = 1.0;

  LocationCollection coll = new LocationCollection();

  // Compute control point
  Point p1 = myMap.LocationToViewportPoint(start);
  Point p2 = myMap.LocationToViewportPoint(finish);

  double boundingBoxHalfWidth = (p2.X - p1.X) / 2.0;
  double boundingBoxHalfHeight = (p1.Y - p2.Y) / 2.0;

  double centerX = (p1.X + p2.X) / 2.0;
  double centerY = (p1.Y + p2.Y) / 2.0;

  double xScale = 1.0;
  double yScale = 1.0;

  double controlX = centerX - (xScale * boundingBoxHalfWidth);
  double controlY = centerY - (yScale * boundingBoxHalfHeight);

  Point controlPt = new Point(controlX, controlY);
  Location controlLoc = myMap.ViewportPointToLocation(controlPt);

  // Compute intermediate Locations using the control point
  int numSegments = 31;
  doublet Delta = 1.0 / numSegments;
  for (double t = 0.0; t <= 1.0; t += tDelta) // Danger!
  {
    // x coordinate (longitudes)
    double a = (1.0 - t) * (1.0 - t) * start.Longitude;
    double b = 2.0 * (1.0 - t) * t * controlLoc.Longitude;
    double c = t * t * finish.Longitude;
    double Blon = a + b + c;

    // y coordinate (latitudes)
    a = (1.0 - t) * (1.0 - t) * start.Latitude;
    b = 2.0 * (1.0 - t) * t * controlLoc.Latitude;
    c = t * t * finish.Latitude;
    double Blat = a + b + c;

    coll.Add(new Location(Blat, Blon));
  }

  curve.Locations = coll;
  myMap.Children.Add(curve);
}

About the Author

Dr. James McCaffrey works for Microsoft Research in Redmond, Wash. He has worked on several Microsoft products including Azure and Bing. James can be reached at [email protected].

comments powered by Disqus

Featured

  • ML.NET Improves Object Detection

    Microsoft improved the object detection capabilities of its ML.NET machine learning framework for .NET developers, adding the ability to train custom models with Model Builder in Visual Studio.

  • More Improvements for VS Code's New Python Language Server

    Microsoft announced more improvements for the new Python language server for Visual Studio Code, Pylance, specializing in rich type information.

  • Death of the Dev Machine?

    Here's a takeaway from this week's Ignite 2020 event: An advanced Azure cloud portends the death of the traditional, high-powered dev machine packed with computing, memory and storage components.

  • COVID-19 Is Ignite 2020's Elephant in the Room: 'Frankly, It Sucks'

    As in all things of our new reality, there was no escaping the drastic changes in routine caused by the COVID-19 pandemic during Microsoft's big Ignite 2020 developer/IT pro conference, this week shifted to an online-only event after drawing tens of thousands of in-person attendees in years past.

  • Visual Studio 2019 v16.8 Preview Update Adds Codespaces

    To coincide with the Microsoft Ignite 2020 IT pro/developer event, the Visual Studio dev team shipped a new update, Visual Studio 2019 v16.8 Preview 3.1, with the main attraction being support for cloud-hosted Codespaces, now in a limited beta.

Upcoming Events