User Tools

Site Tools


source_code_serviceseditionsample_offsetpointatrightangle_cs_100323.zip

Source Code ServicesEditionSample OffsetPointAtRightAngle CS 100323.zip

Program.cs

 using System;  
 using System.Collections.Generic;  
 using System.Linq;  
 using System.Windows.Forms;  
 
 namespace MovePointAtRightAngle  
 {  
     static class Program  
     {  
         /// <summary>  
         /// The main entry point for the application.  
         /// </summary>  
         [STAThread]  
         static void Main()  
         {  
             Application.EnableVisualStyles();  
             Application.SetCompatibleTextRenderingDefault(false);  
             Application.Run(new TestForm());  
         }  
     }  
 }  
 

TestForm.cs

 using System;  
 using System.IO;  
 using System.Drawing;  
 using System.Windows.Forms;  
 using ThinkGeo.MapSuite.Core;  
 using System.Collections.ObjectModel;  
 
 namespace MovePointAtRightAngle  
 {  
     public partial class TestForm : Form  
     {  
         private MapEngine mapEngine = new MapEngine();  
         private Bitmap bitmap = null;  
         InMemoryFeatureLayer segmentInMemoryFeatureLayer = null;  
         InMemoryFeatureLayer pointInMemoryFeatureLayer = null;  
 
         public TestForm()  
         {  
             InitializeComponent();  
         }  
 
         private void TestForm_Load(object sender, EventArgs e)  
         {  
             // Set the full extent and the background color.  
             mapEngine.CurrentExtent = ExtentHelper.GetDrawingExtent(new RectangleShape(0, 10, 10, 0), Map.Width, Map.Height);  
             mapEngine.BackgroundFillBrush = new GeoSolidBrush(GeoColor.StandardColors.White);  
 
             // Reads WKT from files and creates MultiLineShape from WKT (Well Known Text).  
             StreamReader SR = File.OpenText(@"..\..\Data\MultiLineShape_WKT.txt");  
             string S;  
             S = SR.ReadLine();  
             MultilineShape multiLineShape = new MultilineShape(S);  
 
             //Add the dynamic layer with the full line as MultiLineShape  to the MapEngine.  
             InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer();  
             Feature feature = new Feature(multiLineShape);  
             inMemoryFeatureLayer.InternalFeatures.Add("fullLine", feature);  
             inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultLineStyle = LineStyles.Interstate3;  
             inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20;  
             mapEngine.DynamicLayers.Add(inMemoryFeatureLayer);  
 
             //Shows the total length of the full line.  
             lblTotalLength.Text = "The total length of the line is "  + Math.Round(multiLineShape.GetLength(GeographyUnit.Meter,DistanceUnit.Meter),2) + " meters";  
 
             //Adds the dynamic layer for the line segment that will be used for the result of the dynamic segmentation.  
             segmentInMemoryFeatureLayer = new InMemoryFeatureLayer();  
             mapEngine.DynamicLayers.Add("segmentLayer",segmentInMemoryFeatureLayer);  
 
             //Adds the dynamic layer for the start vertex of the full line.  
             PointShape startPointShape = new PointShape(multiLineShape.Lines[0].Vertices[0]);  
            InMemoryFeatureLayer vertexInMemoryFeatureLayer = new InMemoryFeatureLayer();  
             Feature startFeature = new Feature(startPointShape);  
             vertexInMemoryFeatureLayer.InternalFeatures.Add("vertexFeatures", startFeature);  
             vertexInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = PointStyles.CreateSimpleTriangleStyle(GeoColor.SimpleColors.Red, 10);  
             vertexInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20;  
             mapEngine.DynamicLayers.Add(vertexInMemoryFeatureLayer);  
 
             //Add the dynamic layer for the start, end and offset points of the line segment.  
             pointInMemoryFeatureLayer = new InMemoryFeatureLayer();  
             pointInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = PointStyles.CreateSimpleCircleStyle(GeoColor.StandardColors.Red, 9, GeoColor.StandardColors.Black, 1);  
             pointInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20;  
             mapEngine.DynamicLayers.Add("Points",pointInMemoryFeatureLayer);  
 
             DrawImage();  
         }  
 
         private void btnFind_Click(object sender, EventArgs e)  
         {  
             //Gets the line segment from start distance and length and display the result in dynamic layer.  
             double startDistance = Convert.ToDouble(txtBoxDistanceFromStart.Text);  
             double Distance = Convert.ToDouble(txtBoxSegmentLength.Text);  
             InMemoryFeatureLayer inMemoryFeatureLayer = (InMemoryFeatureLayer)mapEngine.DynamicLayers[0];  
             MultilineShape multiLineShape = (MultilineShape)inMemoryFeatureLayer.InternalFeatures[0].GetShape();  
 
             //Calls GetLineOnLine passing the starting vertex, the start distance, the distance length, the map unit and the returning unit.  
             MultilineShape segmentMultiLineShape = (MultilineShape)multiLineShape.GetLineOnALine(StartingPoint.FirstPoint, startDistance, Distance, GeographyUnit.Meter, DistanceUnit.Meter);  
 
             //Makes sure to clear any previous result.  
             segmentInMemoryFeatureLayer.InternalFeatures.Clear();  
 
             //Gets the feature for GetLineOnLine method to put in the InMemoryFeatureLayer for displaying in yellow.  
             Feature segmentFeature = new Feature(segmentMultiLineShape);  
             segmentInMemoryFeatureLayer.InternalFeatures.Add("segmentFeature", segmentFeature);  
             segmentInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultLineStyle = LineStyles.CreateSimpleLineStyle(GeoColor.SimpleColors.Yellow, 4, true);  
             segmentInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20;  
 
             //Gets the point features  
             pointInMemoryFeatureLayer.InternalFeatures.Clear();  
             PointShape pointShape1 = new PointShape(segmentMultiLineShape.Lines[0].Vertices[0]);  
             pointInMemoryFeatureLayer.InternalFeatures.Add(new Feature(pointShape1));  
             int count = segmentMultiLineShape.Lines[0].Vertices.Count - 1;  
             PointShape pointShape2 = new PointShape(segmentMultiLineShape.Lines[0].Vertices[count]);  
             pointInMemoryFeatureLayer.InternalFeatures.Add(new Feature(pointShape2));  
 
             //Offsets the points at right angle from the line segment.  
             double Angle1 = GetAngleFromTwoVertices(segmentMultiLineShape.Lines[0].Vertices[0], segmentMultiLineShape.Lines[0].Vertices[1]);  
             double Angle2 = GetAngleFromTwoVertices(segmentMultiLineShape.Lines[0].Vertices[count|- 1], segmentMultiLineShape.Lines[0].Vertices[count]);  
 
             double offsetAngle1a = Angle1;  
             double offsetAngle1b = GetReverseAngle(Angle1);  
             double offsetAngle2a = Angle2;  
             double offsetAngle2b = GetReverseAngle(Angle2);  
 
             PointShape offsetPointShape1a = (PointShape)pointShape1.CloneDeep();  
             PointShape offsetPointShape1b = (PointShape)pointShape1.CloneDeep();  
             PointShape offsetPointShape2a = (PointShape)pointShape2.CloneDeep();  
             PointShape offsetPointShape2b = (PointShape)pointShape2.CloneDeep();  
 
             offsetPointShape1a.TranslateByDegree(0.5, offsetAngle1a);  
             offsetPointShape1b.TranslateByDegree(0.5, offsetAngle1b);  
             offsetPointShape2a.TranslateByDegree(0.5, offsetAngle2a);  
             offsetPointShape2b.TranslateByDegree(0.5, offsetAngle2b);  
 
             pointInMemoryFeatureLayer.InternalFeatures.Add(new Feature(offsetPointShape1a));  
             pointInMemoryFeatureLayer.InternalFeatures.Add(new Feature(offsetPointShape1b));  
             pointInMemoryFeatureLayer.InternalFeatures.Add(new Feature(offsetPointShape2a));  
             pointInMemoryFeatureLayer.InternalFeatures.Add(new Feature(offsetPointShape2b));  
 
             DrawImage();  
         }  
 
         private double GetAngleFromTwoVertices(Vertex fromVertex, Vertex toVertex)  
         {  
             double alpha = 0;  
 
             if (fromVertex.X != toVertex.X)  
             {  
                 double tangentAlpha = (fromVertex.Y - toVertex.Y) / (toVertex.X - fromVertex.X);  
                 alpha = Math.Atan(tangentAlpha) * 180 / Math.PI;  
                 if (alpha < 0) { alpha += 360; }  
             }  
             else  
             {  
                 alpha = (fromVertex.Y > toVertex.Y) ? 90 : 270;  
             }  
 
             return alpha;  
         }  
 
         private double GetReverseAngle(double Angle)  
         {  
             double result = Angle + 180;  
             if (result > 360)  
             {  
                 result = result - 360;  
             }  
             return result;  
         }  
 
         private void DrawImage()  
         {  
             if (bitmap != null) { bitmap.Dispose(); }  
             bitmap = new Bitmap(Map.Width, Map.Height);  
             mapEngine.OpenAllLayers();  
             mapEngine.DrawDynamicLayers(bitmap, GeographyUnit.Meter);  
             mapEngine.CloseAllLayers();  
             Map.Image = bitmap;  
         }  
 
         private void ToolBar_ButtonClick(object sender, ToolBarButtonClickEventArgs e)  
         {  
             switch (e.Button.Tag.ToString())  
             {  
                 case "Zoom In":  
                     mapEngine.CurrentExtent.ScaleDown(50);  
                     break;  
                 case "Zoom Out":  
                     mapEngine.CurrentExtent.ScaleUp(50);  
                     break;  
                 case "Full Extent":  
                     mapEngine.CurrentExtent = ExtentHelper.GetDrawingExtent(new RectangleShape(-180.0, 83.0, 180.0, -90.0), Map.Width, Map.Height);  
                     break;  
                 case "Pan Left":  
                     mapEngine.CurrentExtent = ExtentHelper.Pan(mapEngine.CurrentExtent, PanDirection.Left, 20);  
                     break;  
                 case "Pan Right":  
                     mapEngine.CurrentExtent = ExtentHelper.Pan(mapEngine.CurrentExtent, PanDirection.Right, 20);  
                     break;  
                 case "Pan Up":  
                     mapEngine.CurrentExtent = ExtentHelper.Pan(mapEngine.CurrentExtent, PanDirection.Up, 20);  
                     break;  
                 case "Pan Down":  
                     mapEngine.CurrentExtent = ExtentHelper.Pan(mapEngine.CurrentExtent, PanDirection.Down, 20);  
                     break;  
                 default:  
                     break;  
             }  
             DrawImage();  
         }  
 
         private void btnClose_Click(object sender, EventArgs e)  
         {  
             this.Close();  
         }  
 
 
     }  
 }  
 
source_code_serviceseditionsample_offsetpointatrightangle_cs_100323.zip.txt · Last modified: 2015/09/08 05:35 by admin