private void TestForm_Load(object sender, EventArgs e) { label1.Text = "Drag vertex of the polygon. Hold Shift key and release mouse button to have the vertex snapping to the line."; winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-97.755, 30.319, -97.7266, 30.3018); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); string fileName1 = @"..\..\data\polygon.txt"; StreamReader sr1 = new StreamReader(fileName1); string fileName2 = @"..\..\data\line.txt"; StreamReader sr2 = new StreamReader(fileName2); //DragtInteractiveOverlay for setting the PointStyles of the control points and dragged points. DragInteractiveOverlayAdvanced dragInteractiveOverlay = new DragInteractiveOverlayAdvanced(); dragInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("Polygon", new Feature(BaseShape.CreateShapeFromWellKnownData(sr1.ReadLine()))); //Sets the PointStyle for the non dragged control points. dragInteractiveOverlay.ControlPointStyle = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.PaleGoldenrod), new GeoPen(GeoColor.StandardColors.Black), 8); //Sets the PointStyle for the dragged control points. dragInteractiveOverlay.DraggedControlPointStyle = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.Green), new GeoPen(GeoColor.StandardColors.DarkGreen, 2), 10); //Sets the PointStyle for the dragged control points when shit key pressed. dragInteractiveOverlay.DraggedControlPointStyleWithShiftKey = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.Red), new GeoPen(GeoColor.StandardColors.Orange, 2), 10); //LineShape snapping feature. LineShape snappingLineShape = (LineShape)BaseShape.CreateShapeFromWellKnownData(sr2.ReadLine()); dragInteractiveOverlay.SnappingFeature = new Feature(snappingLineShape); dragInteractiveOverlay.CanAddVertex = false; dragInteractiveOverlay.CanDrag = false; dragInteractiveOverlay.CanRemoveVertex = false; dragInteractiveOverlay.CanResize = false; dragInteractiveOverlay.CanRotate = false; dragInteractiveOverlay.CalculateAllControlPoints(); winformsMap1.EditOverlay = dragInteractiveOverlay; //Regular InMemoryFeatureLayer for displaying line snapping feature. InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer(); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultLineStyle = LineStyles.CreateSimpleLineStyle(GeoColor.StandardColors.Red, 4, true); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; inMemoryFeatureLayer.InternalFeatures.Add(new Feature(snappingLineShape)); LayerOverlay layerOverlay = new LayerOverlay(); layerOverlay.Layers.Add(inMemoryFeatureLayer); winformsMap1.Overlays.Add(layerOverlay); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { //Sets timers properties. timer.Interval = 800; timer.Tick += new EventHandler(timer_Tick); winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-97.7591, 30.3126, -97.7317, 30.2964); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //InMemoryFeatureLayer for vehicle. InMemoryFeatureLayer carLayer = new InMemoryFeatureLayer(); carLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.PointType = PointType.Bitmap; carLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.Image = new GeoImage(@"..\..\data\sedan.png"); carLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.RotationAngle = 45; carLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; carLayer.InternalFeatures.Add("Car", new Feature(new PointShape())); LayerOverlay vehicleOverlay = new LayerOverlay(); vehicleOverlay.Layers.Add("CarLayer", carLayer); winformsMap1.Overlays.Add("VehicleOverlay", vehicleOverlay); //InMemoryFeatureLayer for Tolerance RectangleShape. (Displayed for the purpose of the project. It does not need to be displayed for a real world application) InMemoryFeatureLayer toleranceLayer = new InMemoryFeatureLayer(); toleranceLayer.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle = AreaStyles.CreateSimpleAreaStyle(GeoColor.StandardColors.Transparent, GeoColor.StandardColors.Green, 2); toleranceLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; //Uses a Rectangle 60% smaller than the current extent of the map for the tolerance. RectangleShape toleranceRectangleShape = new RectangleShape(winformsMap1.CurrentExtent.UpperLeftPoint, winformsMap1.CurrentExtent.LowerRightPoint); toleranceRectangleShape.ScaleDown(60); toleranceLayer.InternalFeatures.Add("Tolerance", new Feature(toleranceRectangleShape)); LayerOverlay toleranceOverlay = new LayerOverlay(); toleranceOverlay.Layers.Add("ToleranceLayer", toleranceLayer); winformsMap1.Overlays.Add("ToleranceOverlay", toleranceOverlay); winformsMap1.Refresh(); timer.Start(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-96.8122, 37.3795, -96.3571, 37.1264); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //InMemoryFeatureLayer for the dams. InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer(); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = new PointStyle(new GeoImage(@"..\..\Data\dam_L_32x32.png")); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.462, 37.185, "Dam 21")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.563, 37.188, "Dam 22")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.570, 37.208, "Dam 23")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.558, 37.217, "Dam 24")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.475, 37.245, "Dam 26")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.445, 37.247, "Dam 27")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.573, 37.248, "Dam 31")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.453, 37.275, "Dam 28")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.78333, 37.28167, "Elk City Lake")); inMemoryFeatureLayer.InternalFeatures.Add(new Feature(-96.493, 37.307, "Dam 32")); //InMemoryFeatureLayer for the searching point. InMemoryFeatureLayer inMemoryFeatureLayer2 = new InMemoryFeatureLayer(); inMemoryFeatureLayer2.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = PointStyles.CreateSimplePointStyle(PointSymbolType.Circle, GeoColor.SimpleColors.Red, 12); inMemoryFeatureLayer2.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; inMemoryFeatureLayer2.InternalFeatures.Add(new Feature(-96.5566, 37.2717)); //InMemoryFeatureLayer for the selected dams. InMemoryFeatureLayer highlightInMemoryFeatureLayer = new InMemoryFeatureLayer(); highlightInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = PointStyles.CreateSimplePointStyle(PointSymbolType.Circle, GeoColor.FromArgb(100, GeoColor.SimpleColors.Red), 14); highlightInMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; LayerOverlay layerOverlay = new LayerOverlay(); layerOverlay.Layers.Add(inMemoryFeatureLayer); layerOverlay.Layers.Add(inMemoryFeatureLayer2); layerOverlay.Layers.Add(highlightInMemoryFeatureLayer); winformsMap1.Overlays.Add(layerOverlay); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { label1.Text = "Left click to track line. Right click to remove last vertex."; winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-95.2957, 38.9791, -95.2397, 38.9452); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-110.136, 23.0523, -109.6883, 22.7859); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //Display the countries02 shapefile. ShapeFileFeatureLayer Layer1 = new ShapeFileFeatureLayer(@"../../data/countries02.shp"); Layer1.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle = AreaStyles.CreateSimpleAreaStyle(GeoColor.StandardColors.Transparent, GeoColor.StandardColors.Black, 2); Layer1.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; LayerOverlay layerOverlay = new LayerOverlay(); layerOverlay.Layers.Add(Layer1); winformsMap1.Overlays.Add(layerOverlay); //Gets the feature for Mexico for the EditInteractiveOverlay. Layer1.Open(); Collection <Feature> features = Layer1.QueryTools.GetFeaturesByColumnValue("ISO_3DIGIT", "MEX"); Layer1.Close(); //EditInteractiveOverlay for doing editing such as resizing, rotating, dragging, adding vertex and moving vertex. EditInteractiveOverlay editOverlay = winformsMap1.EditOverlay; editOverlay.EditShapesLayer.Open(); editOverlay.EditShapesLayer.EditTools.BeginTransaction(); //Clears and add the Mexico feature to EditInteractiveOverlay editOverlay.EditShapesLayer.InternalFeatures.Clear(); editOverlay.EditShapesLayer.EditTools.Add(features[0]); TransactionResult result = editOverlay.EditShapesLayer.EditTools.CommitTransaction(); editOverlay.EditShapesLayer.BuildIndex(); editOverlay.EditShapesLayer.Close(); //Shows the control points for dragging, resizing and rotating the polygon feature as a whole. //Also shows the vertices to be dragged and add new vertex. editOverlay.CalculateAllControlPoints(); //Builds the spatial index for better performance while doing any of those operations. editOverlay.ExistingControlPointsLayer.BuildIndex(); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-96.8531, 33.1084, -96.8461, 33.106); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); LineShape lineShape = new LineShape(); lineShape.Vertices.Add(new Vertex(-96.8511, 33.1089)); lineShape.Vertices.Add(new Vertex(-96.8504, 33.108)); lineShape.Vertices.Add(new Vertex(-96.85, 33.1077)); lineShape.Vertices.Add(new Vertex(-96.8498, 33.1076)); lineShape.Vertices.Add(new Vertex(-96.8482, 33.1076)); LineShape lineShape2 = new LineShape(); lineShape2.Vertices.Add(new Vertex(-96.8497, 33.1084)); lineShape2.Vertices.Add(new Vertex(-96.8506, 33.1072)); //MapShapeLayer to display the three features (line to split, splitting line and intersection point). MapShapeLayer mapShapeLayer = new MapShapeLayer(); //For the line to split. MapShape lineMapShape1 = new MapShape(new Feature(lineShape)); lineMapShape1.ZoomLevels.ZoomLevel01.DefaultLineStyle = LineStyles.CreateSimpleLineStyle(GeoColor.StandardColors.Green, 2, true); lineMapShape1.ZoomLevels.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; mapShapeLayer.MapShapes.Add("Line1", lineMapShape1); //For the splitting line. MapShape lineMapShape2 = new MapShape(new Feature(lineShape2)); lineMapShape2.ZoomLevels.ZoomLevel01.DefaultLineStyle = LineStyles.CreateSimpleLineStyle(GeoColor.StandardColors.Red, 1, true); lineMapShape2.ZoomLevels.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; mapShapeLayer.MapShapes.Add("Line2", lineMapShape2); LayerOverlay layerOverlay = new LayerOverlay(); layerOverlay.Layers.Add(mapShapeLayer); winformsMap1.Overlays.Add(layerOverlay); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.Meter; winformsMap1.CurrentExtent = new RectangleShape(-14103004, 6452457, -7162636, 2497428); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); worldMapKitDesktopOverlay.Projection = WorldMapKitProjection.SphericalMercator; winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //Sets the ZoomLevelSnapping to none to allow having the map at the exact scale desired. winformsMap1.ZoomLevelSnapping = ZoomLevelSnappingMode.None; //Does not allow zooming in at a scale larger than 1:1000 winformsMap1.MinimumScale = 1000; winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { //Sets timer properties timer.Interval = 750; timer.Tick += new EventHandler(timer_Tick); winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-97.7591, 30.3126, -97.7317, 30.2964); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //Adds the inMemoryFeatureLayer for car icon and label. InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer(); //Adds column to InMemoryFeatureLayer. inMemoryFeatureLayer.Open(); inMemoryFeatureLayer.Columns.Add(new FeatureSourceColumn("VehiclePosition")); inMemoryFeatureLayer.Close(); //Sets PointStyle and TextStyle for the InMemoryFeatureLayer. inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.PointType = PointType.Bitmap; inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultTextStyle = TextStyles.CreateSimpleTextStyle("VehiclePosition", "Arial", 8, DrawingFontStyles.Bold, GeoColor.StandardColors.Black, 20, 0); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultTextStyle.Mask = new AreaStyle(new GeoPen(GeoColor.StandardColors.DarkGray, 1), new GeoSolidBrush(GeoColor.FromArgb(150, GeoColor.StandardColors.LightGoldenrodYellow))); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; //Adds the Feature for the car. inMemoryFeatureLayer.InternalFeatures.Add("Car", new Feature(new PointShape())); LayerOverlay dynamicOverlay = new LayerOverlay(); dynamicOverlay.Layers.Add("CarLayer", inMemoryFeatureLayer); winformsMap1.Overlays.Add("DynamicOverlay", dynamicOverlay); winformsMap1.Refresh(); timer.Start(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.Meter; winformsMap1.CurrentExtent = new RectangleShape(-10778878, 3909451, -10775821, 3907529); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); worldMapKitDesktopOverlay.Projection = WorldMapKitProjection.SphericalMercator; winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //We set the lineStyle for TrackShapeLayer as the Increment Line Style. CustomIncrementLineStyle incrementLineStyle = new CustomIncrementLineStyle(); winformsMap1.TrackOverlay.TrackShapeLayer.ZoomLevelSet.ZoomLevel01.DefaultLineStyle = incrementLineStyle; winformsMap1.TrackOverlay.TrackShapeLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; winformsMap1.TrackOverlay.TrackMode = TrackMode.Line; winformsMap1.Refresh(); }
private void MDIParent1_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-125, 47, -67, 25); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer(); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = PointStyles.CreateSimpleCircleStyle(GeoColor.StandardColors.Red, 12, GeoColor.StandardColors.Black, 2); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; LayerOverlay layerOverlay = new LayerOverlay(); layerOverlay.Layers.Add("Point", inMemoryFeatureLayer); winformsMap1.Overlays.Add("PointOverlay", layerOverlay); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-98.9883, 33.6736, -95.4177, 31.5258); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //Shapefile of counties ShapeFileFeatureLayer shapeFileFeatureLayer = new ShapeFileFeatureLayer(@"../../data/Counties.shp"); shapeFileFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle = AreaStyles.CreateSimpleAreaStyle(GeoColor.StandardColors.Transparent, GeoColor.StandardColors.DarkGray, 2); shapeFileFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; LayerOverlay layerOverlay = new LayerOverlay(); layerOverlay.Layers.Add("CountiesLayer", shapeFileFeatureLayer); winformsMap1.Overlays.Add("LayerOverlay", layerOverlay); //Mode Track Polygon and sets event when ending tracking polygon winformsMap1.TrackOverlay.TrackMode = TrackMode.Polygon; winformsMap1.TrackOverlay.TrackEnded += new EventHandler <TrackEndedTrackInteractiveOverlayEventArgs>(trackOverlay_TrackEnded); //InMemoryFeatureLayer for showing the result InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer(); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle = AreaStyles.CreateSimpleAreaStyle(GeoColor.FromArgb(150, GeoColor.StandardColors.Red)); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; LayerOverlay dynamicOverlay = new LayerOverlay(); dynamicOverlay.Layers.Add("DynamicLayer", inMemoryFeatureLayer); winformsMap1.Overlays.Add("DynamicOverlay", dynamicOverlay); winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-97.7591, 30.3126, -97.7317, 30.2964); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); string fileName1 = @"..\..\data\polygon.txt"; StreamReader sr1 = new StreamReader(fileName1); string fileName2 = @"..\..\data\line.txt"; StreamReader sr2 = new StreamReader(fileName2); //DragtInteractiveOverlay for setting the PointStyles of the control points and dragged points. DragInteractiveOverlay dragInteractiveOverlay = new DragInteractiveOverlay(); dragInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("Polygon", new Feature(BaseShape.CreateShapeFromWellKnownData(sr1.ReadLine()))); dragInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("MultiLine", new Feature(BaseShape.CreateShapeFromWellKnownData(sr2.ReadLine()))); //Sets the PointStyle for the non dragged control points. dragInteractiveOverlay.ControlPointStyle = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.PaleGoldenrod), new GeoPen(GeoColor.StandardColors.Black), 8); //Sets the PointStyle for the dragged control points. dragInteractiveOverlay.DraggedControlPointStyle = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.Red), new GeoPen(GeoColor.StandardColors.Orange, 2), 10); dragInteractiveOverlay.CanAddVertex = false; dragInteractiveOverlay.CanDrag = false; dragInteractiveOverlay.CanRemoveVertex = false; dragInteractiveOverlay.CanResize = false; dragInteractiveOverlay.CanRotate = false; dragInteractiveOverlay.CalculateAllControlPoints(); winformsMap1.EditOverlay = dragInteractiveOverlay; winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-95.3094, 38.9749, -95.2528, 38.9406); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //EditInteractiveOverlay used because it already has the logic for dragging. EditInteractiveOverlay editInteractiveOverlay = new EditInteractiveOverlay(); //Sets the property IsActive for DragControlPointsLayer to false so that the control point (as four arrows) is not visible. editInteractiveOverlay.DragControlPointsLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.IsActive = false; editInteractiveOverlay.DragControlPointsLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; //Sets the property IsActive for all the Styles of EditShapesLayer because we are using a ValueStyle instead. editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.IsActive = false; editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultLineStyle.IsActive = false; editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle.IsActive = false; //ValueStyle used for displaying the feature according to the value of the column "Type" for displaying with a flag or unknown icon. ValueStyle valueStyle = new ValueStyle(); valueStyle.ColumnName = "Type"; PointStyle carPointStyle = new PointStyle(new GeoImage(@"..\..\Data\locale.png")); carPointStyle.PointType = PointType.Bitmap; PointStyle busPointStyle = new PointStyle(new GeoImage(@"..\..\Data\unknown.png")); busPointStyle.PointType = PointType.Bitmap; valueStyle.ValueItems.Add(new ValueItem("Flag", carPointStyle)); valueStyle.ValueItems.Add(new ValueItem("Unknown", busPointStyle)); editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.CustomStyles.Add(valueStyle); editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; editInteractiveOverlay.EditShapesLayer.Open(); editInteractiveOverlay.EditShapesLayer.Columns.Add(new FeatureSourceColumn("Type")); editInteractiveOverlay.EditShapesLayer.Close(); Feature carFeature = new Feature(new PointShape(-95.2809, 38.9544)); carFeature.ColumnValues["Type"] = "Flag"; Feature busFeature = new Feature(new PointShape(-95.3019, 38.9578)); busFeature.ColumnValues["Type"] = "Unknown"; editInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("Flag", carFeature); editInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("Unknown", busFeature); //Sets the properties of EditInteractiveOverlay to have the appropriate behavior. //Make sure CanDrag is set to true. editInteractiveOverlay.CanAddVertex = false; editInteractiveOverlay.CanDrag = true; editInteractiveOverlay.CanRemoveVertex = false; editInteractiveOverlay.CanResize = false; editInteractiveOverlay.CanRotate = false; editInteractiveOverlay.CalculateAllControlPoints(); winformsMap1.EditOverlay = editInteractiveOverlay; winformsMap1.Refresh(); //We disable the double click modes in order to not have second effect behavior //of the map when adding or removing an icon by double clicking winformsMap1.ExtentOverlay.DoubleLeftClickMode = MapDoubleLeftClickMode.Disabled; winformsMap1.ExtentOverlay.DoubleRightClickMode = MapDoubleRightClickMode.Disabled; }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-95.2982, 38.9632, -95.2843, 38.955); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //InMemoryFeatureLayer for the two reference points en red. InMemoryFeatureLayer pointLayer = new InMemoryFeatureLayer(); pointLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle = PointStyles.CreateSimpleCircleStyle(GeoColor.StandardColors.Red, 12, GeoColor.StandardColors.Black); pointLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; Feature feature1 = new Feature(new PointShape(-95.2949, 38.957)); Feature feature2 = new Feature(new PointShape(-95.2883, 38.957)); pointLayer.InternalFeatures.Add(feature1); pointLayer.InternalFeatures.Add(feature2); LayerOverlay pointOverlay = new LayerOverlay(); pointOverlay.Layers.Add("PointLayer", pointLayer); winformsMap1.Overlays.Add("PointOverlay", pointOverlay); //-------------------------------------------------- //Collection of PointShapes for the GPS locations. GPSlocations.Add(new PointShape(-95.2946, 38.9602)); GPSlocations.Add(new PointShape(-95.2928, 38.9602)); GPSlocations.Add(new PointShape(-95.2903, 38.9602)); GPSlocations.Add(new PointShape(-95.2883, 38.9602)); GPSlocations.Add(new PointShape(-95.2883, 38.9587)); GPSlocations.Add(new PointShape(-95.2883, 38.957)); GPSlocations.Add(new PointShape(-95.2897, 38.957)); GPSlocations.Add(new PointShape(-95.2918, 38.957)); GPSlocations.Add(new PointShape(-95.2934, 38.957)); GPSlocations.Add(new PointShape(-95.2947, 38.957)); GPSlocations.Add(new PointShape(-95.2946, 38.9582)); GPSlocations.Add(new PointShape(-95.2946, 38.9593)); InMemoryFeatureLayer vehicleLayer = new InMemoryFeatureLayer(); vehicleLayer.Open(); vehicleLayer.Columns.Add(new FeatureSourceColumn("DETECT", "string", 3)); vehicleLayer.Close(); // Draw features based on values ValueStyle valueStyle = new ValueStyle(); valueStyle.ColumnName = "DETECT"; valueStyle.ValueItems.Add(new ValueItem("No", new PointStyle(new GeoImage(@"..\..\Data\Top.png")))); valueStyle.ValueItems.Add(new ValueItem("yes", new PointStyle(new GeoImage(@"..\..\Data\Top2.png")))); vehicleLayer.ZoomLevelSet.ZoomLevel01.CustomStyles.Add(valueStyle); vehicleLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; Feature GPSfeature = new Feature(GPSlocations[0]); GPSfeature.ColumnValues.Add("DETECT", "No"); vehicleLayer.InternalFeatures.Add("GPSFeature1", GPSfeature); LayerOverlay vehicleOverlay = new LayerOverlay(); vehicleOverlay.Layers.Add("VehicleLayer", vehicleLayer); winformsMap1.Overlays.Add("VehicleOverlay", vehicleOverlay); //Sets timer properties timer.Interval = 1500; timer.Tick += new EventHandler(timer_Tick); winformsMap1.Refresh(); timer.Start(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-97.7591, 30.3126, -97.7317, 30.2964); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); //EditInteractiveOverlay used because it already have the logic for dragging. EditInteractiveOverlay editInteractiveOverlay = new EditInteractiveOverlay(); //Sets the property IsActive for DragControlPointsLayer to false so that the control point (as four arrows) is not visible. editInteractiveOverlay.DragControlPointsLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.IsActive = false; editInteractiveOverlay.DragControlPointsLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; //Sets the property IsActive for all the Styles of EditShapesLayer because we are using a ValueStyle instead. editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultPointStyle.IsActive = false; editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultLineStyle.IsActive = false; editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle.IsActive = false; //ValueStyle used for displaying the feature according to the value of the column "Type" for displaying with a bus or car icon. ValueStyle valueStyle = new ValueStyle(); valueStyle.ColumnName = "Type"; PointStyle carPointStyle = new PointStyle(new GeoImage(@"..\..\Data\car_normal.png")); carPointStyle.PointType = PointType.Bitmap; PointStyle busPointStyle = new PointStyle(new GeoImage(@"..\..\Data\bus_normal.png")); busPointStyle.PointType = PointType.Bitmap; valueStyle.ValueItems.Add(new ValueItem("Car", carPointStyle)); valueStyle.ValueItems.Add(new ValueItem("Bus", busPointStyle)); editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.CustomStyles.Add(valueStyle); editInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; editInteractiveOverlay.EditShapesLayer.Open(); editInteractiveOverlay.EditShapesLayer.Columns.Add(new FeatureSourceColumn("Type")); editInteractiveOverlay.EditShapesLayer.Close(); Feature carFeature = new Feature(new PointShape(-97.7507, 30.3092)); carFeature.ColumnValues["Type"] = "Car"; Feature busFeature = new Feature(new PointShape(-97.7428, 30.3053)); busFeature.ColumnValues["Type"] = "Bus"; editInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("Car", carFeature); editInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("Bus", busFeature); //Sets the properties of EditInteractiveOverlay to have the appropriate behavior. //Make sure CanDrag is set to true. editInteractiveOverlay.CanAddVertex = false; editInteractiveOverlay.CanDrag = true; editInteractiveOverlay.CanRemoveVertex = false; editInteractiveOverlay.CanResize = false; editInteractiveOverlay.CanRotate = false; editInteractiveOverlay.CalculateAllControlPoints(); winformsMap1.EditOverlay = editInteractiveOverlay; winformsMap1.Refresh(); }
private void TestForm_Load(object sender, EventArgs e) { winformsMap1.MapUnit = GeographyUnit.DecimalDegree; winformsMap1.CurrentExtent = new RectangleShape(-97.7591, 30.3126, -97.7317, 30.2964); winformsMap1.BackgroundOverlay.BackgroundBrush = new GeoSolidBrush(GeoColor.FromArgb(255, 198, 255, 255)); //Displays the World Map Kit as a background. ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay worldMapKitDesktopOverlay = new ThinkGeo.MapSuite.DesktopEdition.WorldMapKitWmsDesktopOverlay(); winformsMap1.Overlays.Add(worldMapKitDesktopOverlay); string fileName1 = @"..\..\data\polygon.txt"; StreamReader sr1 = new StreamReader(fileName1); string fileName2 = @"..\..\data\line.txt"; StreamReader sr2 = new StreamReader(fileName2); //DragtInteractiveOverlay for setting the PointStyles of the control points and dragged points. DragInteractiveOverlay dragInteractiveOverlay = new DragInteractiveOverlay(); dragInteractiveOverlay.ReferenceShape = BaseShape.CreateShapeFromWellKnownData(sr1.ReadLine()); dragInteractiveOverlay.EditShapesLayer.InternalFeatures.Add("MultiLine", new Feature(BaseShape.CreateShapeFromWellKnownData(sr2.ReadLine()))); //Sets the PointStyle for the non dragged control points. dragInteractiveOverlay.ControlPointStyle = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.PaleGoldenrod), new GeoPen(GeoColor.StandardColors.Black), 8); //Sets the PointStyle for the dragged control points. dragInteractiveOverlay.DraggedControlPointStyle = new PointStyle(PointSymbolType.Circle, new GeoSolidBrush(GeoColor.StandardColors.Red), new GeoPen(GeoColor.StandardColors.Orange, 2), 10); // Add the point feature and specify text style. dragInteractiveOverlay.EditShapesLayer.ZoomLevelSet.ZoomLevel01.DefaultTextStyle = new TextStyle("LabelColumn", new GeoFont("Arial", 12), new GeoSolidBrush(GeoColor.SimpleColors.Black)); dragInteractiveOverlay.CanAddVertex = false; dragInteractiveOverlay.CanDrag = false; dragInteractiveOverlay.CanRemoveVertex = false; dragInteractiveOverlay.CanResize = false; dragInteractiveOverlay.CanRotate = false; dragInteractiveOverlay.CalculateAllControlPoints(); winformsMap1.EditOverlay = dragInteractiveOverlay; //InMemoryFeatureLayer for the geometry of the reference shape InMemoryFeatureLayer inMemoryFeatureLayer = new InMemoryFeatureLayer(); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.DefaultAreaStyle = AreaStyles.CreateSimpleAreaStyle(GeoColor.StandardColors.Red, GeoColor.StandardColors.Black); inMemoryFeatureLayer.ZoomLevelSet.ZoomLevel01.ApplyUntilZoomLevel = ApplyUntilZoomLevel.Level20; Feature newFeature = new Feature(dragInteractiveOverlay.ReferenceShape); inMemoryFeatureLayer.Open(); inMemoryFeatureLayer.EditTools.BeginTransaction(); inMemoryFeatureLayer.EditTools.Add(newFeature); inMemoryFeatureLayer.EditTools.CommitTransaction(); inMemoryFeatureLayer.Close(); LayerOverlay referenceOverlay = new LayerOverlay(); referenceOverlay.Layers.Add("Reference", inMemoryFeatureLayer); winformsMap1.Overlays.Add(referenceOverlay); winformsMap1.Refresh(); }