当前位置: 首页>>代码示例>>C#>>正文


C# PointClass.Project方法代码示例

本文整理汇总了C#中PointClass.Project方法的典型用法代码示例。如果您正苦于以下问题:C# PointClass.Project方法的具体用法?C# PointClass.Project怎么用?C# PointClass.Project使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在PointClass的用法示例。


在下文中一共展示了PointClass.Project方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: getGeoPoint

 /// <summary>
 /// 坐标系转换-----投影坐标系转WGS84
 /// </summary>
 /// <param name="x">x坐标</param>
 /// <param name="y">y坐标</param>
 /// <returns>转换后的IPoint</returns>
 public static IPoint getGeoPoint(double x, double y)
 {
     IPoint pProjPoint = new PointClass();
     pProjPoint.PutCoords(x, y);
     ISpatialReferenceFactory pSRF = new SpatialReferenceEnvironmentClass();
     pProjPoint.SpatialReference = pSRF.CreateProjectedCoordinateSystem((int)(esriSRProjCSType.esriSRProjCS_WGS1984UTM_31N));
     pProjPoint.Project(pSRF.CreateGeographicCoordinateSystem((int)(esriSRGeoCSType.esriSRGeoCS_WGS1984)));
     return pProjPoint;      //此时为经纬度点
 }
开发者ID:BNU-Chen,项目名称:3DGlobe,代码行数:15,代码来源:BaseGISTools.cs

示例2: DrawPoly

        /// <summary>
        ///     Draw the polygon contained within the properties.
        /// </summary>
        /// <param name="polyToBeDrawn">
        ///     The polygon to be drawn.
        /// </param>
        /// <param name="graphicContainer">
        ///     The graphic container.
        /// </param>
        private void DrawPoly(Properties polyToBeDrawn, IGraphicsContainer graphicContainer)
        {
            var poly = new PolygonClass();
            poly.Project(ArcMap.Document.ActiveView.Extent.SpatialReference);
            foreach (var pnt in polyToBeDrawn.Points)
            {
                var tempPoint = new PointClass();
                tempPoint.PutCoords(pnt.X, pnt.Y);
                tempPoint.SpatialReference = Jarvis.ProjectedCoordinateSystem;
                tempPoint.Project(ArcMap.Document.ActiveView.Extent.SpatialReference);
                poly.AddPoint(tempPoint);
            }

            IElement elm = new PolygonElementClass();
            elm.Geometry = poly;

            graphicContainer.AddElement(elm, 0);
        }
开发者ID:DigitalGlobe,项目名称:DGConnect-ESRI,代码行数:27,代码来源:GbdDockableWindow.cs

示例3: CreateStop

		// Creates Stop by Stop Point, Index and Description and adds it to Stops collection
		private void CreateStop(SMRouter objRouter, string strAddress, string strCity, string strState, string strCode, SMStopsCollection objStopsCol, int nID)
		{

			// geocode point
			IPoint objPoint = new PointClass();
			objPoint = GeocodeAddress(strAddress, strCity, strState, strCode);

			if (objPoint.IsEmpty)
					throw new Exception("Cannot geocode address.");

			// project point
			objPoint.Project(m_objSpatialReference);

			// create and initialize router point    
			SMRouterPoint objRouterPoint = null;
			objRouterPoint = new SMRouterPointClass();

			objRouterPoint.X = objPoint.X;
			objRouterPoint.Y = objPoint.Y;

			// create flag    
			ISMFlagCreator2 objFlagCreator2 = null;
			objFlagCreator2 = objRouter.FlagCreator as ISMFlagCreator2;
			if (objFlagCreator2 != null)
					objFlagCreator2.SearchTolerance = 5;

			SMFlag objFlag = null;
			objFlag = objRouter.FlagCreator.CreateFlag(objRouterPoint);

			// create and initialize stop    
			SMStop objStop = null;
			objStop = new SMStop();
			objStop.StopID = nID;
			objStop.Duration = 0;
			objStop.Flag = objFlag;
			objStop.Description = GetAddressString(strAddress, strCity, strState, strCode);

			objStopsCol.Add(objStop);
		}
开发者ID:Esri,项目名称:arcobjects-sdk-community-samples,代码行数:40,代码来源:RoutingForm.cs

示例4: get_ErrorPoint

        protected IPoint get_ErrorPoint(IGeometry shape)
        {
            IPoint theErrorPoint;

            if (shape is IArea)
            {
                try
                {
                    theErrorPoint = ((IArea)shape).LabelPoint;
                }
                catch (Exception)
                {
                    theErrorPoint = ((IArea)shape).Centroid;
                }
            }
            else if (shape is ICurve)
            {
                ICurve theCurve = (ICurve)shape;
                theErrorPoint = new PointClass();
                theErrorPoint.Project(shape.SpatialReference);
                theCurve.QueryPoint(esriSegmentExtension.esriNoExtension, 0.5, true, theErrorPoint);
            }
            else if (shape is IPointCollection)
                theErrorPoint = ((IPointCollection)shape).get_Point(0);
            else if (shape is IPoint)
                theErrorPoint = (IPoint)shape;
            else
            {
                theErrorPoint = new PointClass();
                theErrorPoint.PutCoords(0, 0);
            }

            theErrorPoint.Project(SpatialReferenceHelper.GeographicReference);

            return theErrorPoint;
        }
开发者ID:EAWCS1,项目名称:SUITT,代码行数:36,代码来源:BaseTest.cs

示例5: ConstructLine

 private ILine ConstructLine(double x1, double y1, double x2, double y2)
 {
     IPoint p1 = new PointClass();
     p1.PutCoords(x1, y1);
     p1.Project(SpatialReferenceHelper.BCAlbersSpatialReference);
     IPoint p2 = new PointClass();
     p2.PutCoords(x2, y2);
     p2.Project(SpatialReferenceHelper.BCAlbersSpatialReference);
     ILine theReturn = new LineClass();
     theReturn.PutCoords(p1, p2);
     theReturn.Project(SpatialReferenceHelper.BCAlbersSpatialReference);
     return theReturn;
 }
开发者ID:EAWCS1,项目名称:SUITT,代码行数:13,代码来源:GeometryGap.cs

示例6: XY2JWD

 public static IPoint XY2JWD(double x, double y, int gcsType, int pcsType)
 {
     try
     {
         IPoint point = new PointClass();
         point.PutCoords(x, y);
         ISpatialReferenceFactory factory = new SpatialReferenceEnvironmentClass();
         point.SpatialReference = factory.CreateProjectedCoordinateSystem(pcsType);
         point.Project(factory.CreateGeographicCoordinateSystem(gcsType));
         return point;
     }
     catch
     {
         return null;
     }
 }
开发者ID:ismethr,项目名称:gas-geological-map,代码行数:16,代码来源:SpatialReferenceHelper.cs

示例7: CreateWellsiteFeature

        // build the actual point feature and store it
        private void CreateWellsiteFeature()
        {
            IFeatureCursor pFeatureCursor = null;

            try
            {
                IFeatureClass pFeatureClass;
                IFields pFields;

                pFeatureClass = m_pFeatureLayerWellsOSDB.FeatureClass;

                // first deal with point creation
                IPoint pPoint = new PointClass();
                ISpatialReferenceFactory2 pSRF = new SpatialReferenceEnvironmentClass();

                double xcoord, ycoord;
                ISpatialReference pSR = null;

                if (txtUTMnorthing.ReadOnly == false)  //we'll use the UTM coordinates to validate the BCGS
                {
                    // create the correct UTM projected coordinate system (based on zone) - NAD 83 datum
                    pSR = pSRF.CreateSpatialReference(26900 + Convert.ToInt32(txtUTMzone.Text));

                    xcoord = Convert.ToDouble(txtUTMeasting.Text);
                    ycoord = Convert.ToDouble(txtUTMnorthing.Text);
                }
                else // we'll use the lat/lon coordinates to validate the BCGS
                {
                    pSR = pSRF.CreateSpatialReference(4269); //esriSRGeoCS_NAD1983

                    xcoord = Convert.ToDouble(txtLongitude.Text);
                    ycoord = Convert.ToDouble(txtLatitude.Text);

                    // make sure our xcoord is negative even if the user entered positive (for western hem)
                    if (xcoord > 0)
                        xcoord *= -1;

                    // make sure our ycoord is positive for northern hemisphere
                    if (ycoord < 0)
                        ycoord *= -1;

                }

                // assign coordinate info and SR
                pPoint.SpatialReference = pSR;
                pPoint.X = xcoord;
                pPoint.Y = ycoord;

                Debug.WriteLine("before project -> x,y = " + pPoint.X.ToString() + "," + pPoint.Y.ToString());

                // get SR of destination featureclass
                IGeoDataset pGeodataset = (IGeoDataset)pFeatureClass;

                // project point
                pPoint.Project(pGeodataset.SpatialReference);

                if (pPoint.IsEmpty == true)
                {
                    MessageBox.Show("The point coordinate failed to project.\n" +
                                    "Check that your coordinates are correct.", "SUITT Error");
                    return;
                }
                else
                {
                    Debug.WriteLine("after  project -> x,y = " + pPoint.X.ToString() + "," + pPoint.Y.ToString());
                }

                string correctMapSheet;
                if (BCGSCheck(txtBCGSMap.Text, pPoint, out correctMapSheet) == false)
                {
                    if (correctMapSheet.Length == 0)
                    {
                        // no result.. either a major error or the point does not fall inside
                        // any mapsheet polygon
                        MessageBox.Show("The point coordinate does not fall inside any BCGS map sheet", "SUITT");
                        return;
                    }
                    else
                    {
                        // point was not in the specified mapsheet polygon
                        MessageBox.Show("The point coordinate does not exist\n" +
                                        "within the specified BCGS map sheet.\n" +
                                        "The point cannot be added.\n\n" +
                                        "The correct sheet should be: " + correctMapSheet, "SUITT");
                        return;
                    }
                }

                // now do the insertion
                pFeatureCursor = pFeatureClass.Insert(false);

                IFeatureBuffer pFeatureBuffer = pFeatureClass.CreateFeatureBuffer();
                pFields = pFeatureCursor.Fields;

                pFeatureBuffer.set_Value(pFields.FindField("WELLSITE_SID"), Convert.ToDouble(txtWellsiteSID.Text));

                // write point
                pFeatureBuffer.Shape = pPoint;

//.........这里部分代码省略.........
开发者ID:EAWCS1,项目名称:SUITT,代码行数:101,代码来源:CreateWellSitePointForm.cs

示例8: CreatePoint

        private void CreatePoint(double x, double y)
        {
            IPoint pPoint = new PointClass();
            IMap pMap = axMapControl.Map;
            IActiveView pActiveView = pMap as IActiveView;
            IGraphicsContainer pGraphicsContainer;
            IElement pElement = new MarkerElementClass();

            pGraphicsContainer = (IGraphicsContainer)pActiveView;
            IFormattedTextSymbol pTextSymbol = new TextSymbolClass();
            IBalloonCallout pBalloonCallout = CreateBalloonCallout(x, y);
            IRgbColor pColor = new RgbColorClass();
            pColor.Red = 150;
            pColor.Green = 0;
            pColor.Blue = 0;
            pTextSymbol.Color = pColor;
            ITextBackground pTextBackground;
            pTextBackground = (ITextBackground)pBalloonCallout;
            //pTextSymbol.Background = pTextBackground;
            //((ITextElement)pElement).Symbol = pTextSymbol;
            //((ITextElement)pElement).Text = "测试";
            pPoint.X = x + 42;
            pPoint.Y = y + 42;

            pPoint.PutCoords(x, y);
            ISpatialReferenceFactory pSRF = new SpatialReferenceEnvironmentClass();
            pPoint.SpatialReference = pSRF.CreateProjectedCoordinateSystem(2414);
            pPoint.Project(pSRF.CreateGeographicCoordinateSystem((int)esriSRGeoCSType.esriSRGeoCS_Beijing1954));

            pElement.Geometry = pPoint;
            pGraphicsContainer.AddElement(pElement, 1);
            pActiveView.PartialRefresh(esriViewDrawPhase.esriViewGraphics, null, null);
        }
开发者ID:hijushen,项目名称:WindowDemo,代码行数:33,代码来源:Form1.cs

示例9: button5_Click

        private void button5_Click(object sender, EventArgs e)
        {
            IPoint pPoint = new PointClass();
            pPoint.X = 40;
            pPoint.Y = -101;

            ISpatialReferenceFactory pSRF = new SpatialReferenceEnvironmentClass();

            pPoint.SpatialReference = pSRF.CreateProjectedCoordinateSystem(4152);

            pPoint.Project(pSRF.CreateGeographicCoordinateSystem((int)esriSRGeoCSType.esriSRGeoCS_NAD1983HARN));

            GeoToGra(pPoint);

            esriUnits eu = new esriUnits();

            axMapControl.MapUnits = esriUnits.esriMeters;
        }
开发者ID:hijushen,项目名称:WindowDemo,代码行数:18,代码来源:Form1.cs

示例10: Execute

        public override int Execute(string logfileName)
        {
            this.InitLogging(logfileName);
            this.LogMessage(this.Name + " QA test execution started.");

            int currentOid = -1;

            try
            {
                this.LogMessage(this.Name + " Parameters:");
                for (int i = 0; i < this.ParameterCount; i++)
                    this.LogMessage(this.get_ParameterText(i) + ": " + this.get_ParameterValue(i));

                this.ClearErrors();

                // Check the search radius
                int idx = this.FindParameter("search-radius");
                DoubleParameterInfo theInfo = (DoubleParameterInfo)this._params[idx];
                double theSearchRadius = (double)theInfo.ParamValue;

                if (theSearchRadius <= 0)
                {
                    this.LogMessage("Zero or negative value passed as search radius for " + this.Name + ". Stopping.");
                    return -1;
                }

                // Check the cluster tolerance
                idx = this.FindParameter("cluster-tolerance");
                theInfo = (DoubleParameterInfo)this._params[idx];
                double theCluster = (double)theInfo.ParamValue;

                if (theCluster >= theSearchRadius)
                {
                    this.LogMessage("Cluster tolerance equal to or larger than search radius for " + this.Name + ". Stopping.");
                    return -1;
                }

                // Convert them to metres
                idx = this.FindParameter("search-units");
                UnitsParameterInfo theUnitsParam = (UnitsParameterInfo)this._params[idx];
                esriUnits theUnits = theUnitsParam.ParamValueInUnits;
                IUnitConverter theConverter = new UnitConverterClass();
                theSearchRadius = theConverter.ConvertUnits(theSearchRadius, theUnits, esriUnits.esriMeters);
                theCluster = theConverter.ConvertUnits(theCluster, theUnits, esriUnits.esriMeters);

                // Get the canDefer/canExcept params
                idx = this.FindParameter(ParameterInfo.PARAM_CANDEFER);
                bool canDefer = (bool)((ParameterInfo)this._params[idx]).ParamValue;
                idx = this.FindParameter(ParameterInfo.PARAM_CANEXCEPT);
                bool canExcept = (bool)((ParameterInfo)this._params[idx]).ParamValue;

                // Loop through the layers
                for (int i = 0; i < this.LayerCount - 1; i++)
                {
                    IFeatureLayer theLayer1 = this.get_Layer(i);
                    if (this.SupportsGeometryType(theLayer1.FeatureClass.ShapeType) == false)
                        continue;

                    // Index the points in theLayer1
                    IDataset theDataset1 = (IDataset)theLayer1.FeatureClass;
                    IGeoDataset theGeoDS = (IGeoDataset)theDataset1;
                    IEnvelope theAOI = theGeoDS.Extent;
                    if (theAOI == null || theAOI.IsEmpty)
                        continue;

                    theAOI.Project(SpatialReferenceHelper.BCAlbersSpatialReference);
                    double theCellsize = theAOI.Width / 100;
                    this.LogMessage("Indexing features in " + theDataset1.Name + ". Cellsize (m): " + theCellsize);
                    PointCollectionIndex theIndex = new PointCollectionIndex(theCellsize);

                    IFeatureCursor theFCursor1 = null;
                    if (this.ConstrainToSelection)
                    {
                        ICursor theCursor = null;
                        IFeatureSelection theFSel = (IFeatureSelection)theLayer1;
                        theFSel.SelectionSet.Search(null, true, out theCursor);
                        theFCursor1 = (IFeatureCursor)theCursor;
                    }
                    else
                    {
                        theFCursor1 = theLayer1.Search(null, true);
                    }

                    IFeature theFeature1 = theFCursor1.NextFeature();
                    while (theFeature1 != null)
                    {
                        if (theFeature1.Shape != null && theFeature1.Shape.IsEmpty == false)
                        {
                            IPointCollection thePtColl = (IPointCollection)theFeature1.Shape;
                            for (int k = 0; k < thePtColl.PointCount; k++)
                            {
                                theIndex.AddPoint(new IndexPoint(theFeature1.OID, k, thePtColl.get_Point(k)));
                            }
                        }

                        theFeature1 = theFCursor1.NextFeature();
                    }

                    // Release the cursor
                    Marshal.ReleaseComObject(theFCursor1);
//.........这里部分代码省略.........
开发者ID:EAWCS1,项目名称:SUITT,代码行数:101,代码来源:GeometryLinework.cs

示例11: panButton_Click

        private void panButton_Click(object sender, System.EventArgs e)
        {
            try
            {
                Conflict conflict = getSelected();
                if(ext != null && conflict != null && conflict.Shape != null)
                {
                    IEnvelope shEnv = new EnvelopeClass();
                    conflict.Shape.QueryEnvelope(shEnv);
                    IPoint pt = new PointClass();
                    pt.PutCoords( ((shEnv.XMax-shEnv.XMin)/2)+shEnv.XMin, ((shEnv.YMax-shEnv.YMin)/2)+shEnv.YMin);
                    pt.SpatialReference = conflict.Shape.SpatialReference;

                    IEnvelope current = ((IActiveView)this.ext.FocusMap).Extent;
                    pt.Project(current.SpatialReference);
                    current.CenterAt(pt);

                    //this.ext.FocusMap.AreaOfInterest = current;
                    ((IActiveView)this.ext.FocusMap).Extent = current;
                    ((IActiveView)this.ext.FocusMap).Refresh();
                }
            }
            catch(Exception ee)
            {
                Logger.Warn(ee);
                MessageBox.Show("An Unexpected Error Occured: "+ee.Message+"\n\tPlease Review the Log.",
                    "EXCEPTION", MessageBoxButtons.OK,
                    MessageBoxIcon.Error);
            }
        }
开发者ID:EAWCS1,项目名称:SUITT,代码行数:30,代码来源:FormConflicts.cs

示例12: btnZoomSelected_Click

        // zooms to features in the map that correspond to selected features in the list view
        private void btnZoomSelected_Click(object sender, System.EventArgs e)
        {
            try
            {
                IQueryFilter pQueryFilter = new QueryFilterClass();
                IFeatureClass pFeatureClass = m_pFeatureLayer.FeatureClass;

                // build array of selected OIDs
                string[] OID = new string[lvGPS.SelectedItems.Count];
                for(int x = 0; x < lvGPS.SelectedItems.Count; x++)
                {
                    OID[x] = lvGPS.SelectedItems[x].Text;
                }

                string OIDs = String.Join(",",OID);

                // build the whereclause
                string whereclause = pFeatureClass.OIDFieldName + " IN (" + OIDs + ")";

                Debug.WriteLine(whereclause);

                pQueryFilter.WhereClause = whereclause;

                // bind query filter resultant geometry into a geometry bag
                IEnumGeometryBind pEnumBind = new EnumFeatureGeometryClass();
                IGeometryFactory pGeomFactory = new GeometryEnvironmentClass();
                pEnumBind.BindGeometrySource(pQueryFilter,pFeatureClass);
                IGeometryBag pGeometryBag = (IGeometryBag)pGeomFactory.CreateGeometryFromEnumerator((IEnumGeometry)pEnumBind);
                IGeometryCollection pGeomCollection = (IGeometryCollection)pGeometryBag;

                // TODO:
                //IMxDocument pMxDoc = (IMxDocument)m_pApp.Document;
                IActiveView pActiveView = (IActiveView)m_pISDUTExt.FocusMap; //pMxDoc.FocusMap;
                //util.Utils.Release(pMxDoc);

                IEnvelope pEnv = pGeometryBag.Envelope;
                if(pGeomCollection.GeometryCount == 1)
                {
                    // if only one point the do a pan instead of a zoom

                    IPoint pPoint = new PointClass();
                    pPoint.PutCoords(pEnv.XMin,pEnv.YMin);

                    // get SR of featureclass
                    IGeoDataset pGeodataset = (IGeoDataset)m_pFeatureLayer.FeatureClass;

                    pPoint.SpatialReference = pGeodataset.SpatialReference;

                    // project point to match focus map SR

                    // TODO:
                    //pMxDoc = (IMxDocument)m_pApp.Document;
                    pPoint.Project(m_pISDUTExt.FocusMap.SpatialReference);// pMxDoc.FocusMap.SpatialReference);
                    //util.Utils.Release(pMxDoc);

                    IEnvelope pPanEnv = pActiveView.Extent;
                    pPanEnv.CenterAt(pPoint);
                    pActiveView.Extent = pPanEnv;
                }
                else
                {
                    pEnv.Expand(1.1,1.1,true);
                    pActiveView.Extent = pEnv;
                }

                pActiveView.Refresh();
            }
            catch(Exception ex)
            {
                util.Logger.Write(" Descrip  : Zooms to features on the map the correspond with items selected in the list view." +
                                "\n Message  : " + ex.Message +
                                "\n StackTrc : " + ex.StackTrace,util.Logger.LogLevel.Debug);

                MessageBox.Show(ex.Message + "\n" + ex.StackTrace);
                Debug.WriteLine(ex.Message + "\n" + ex.StackTrace);
            }

            //lvGPS.Focus();
        }
开发者ID:EAWCS1,项目名称:SUITT,代码行数:80,代码来源:GPSManageForm.cs

示例13: MakeTxtFileOfJSONElevationResponses


//.........这里部分代码省略.........

            //return;

            Type factoryType = Type.GetTypeFromProgID("esriGeometry.SpatialReferenceEnvironment");
            System.Object obj = Activator.CreateInstance(factoryType);
            ISpatialReferenceFactory spatialReferenceFactory = obj as ISpatialReferenceFactory;
            ISpatialReference spatRef = spatialReferenceFactory.CreateGeographicCoordinateSystem(4326);
            //ISpatialReference existingSpatRef = geomCol.get_Geometry(0).SpatialReference;
            ISpatialReference existingSpatRef = startWaypoint.ShapeCopy.SpatialReference;
            /*IFeature trailFe = feCur.NextFeature();
            ISpatialReference existingSpatRef = null;
            while (trailFe != null)
            {
                geomCol.AddGeometry(trailFe.ShapeCopy);
                if(existingSpatRef == null)
                {
                    existingSpatRef = trailFe.ShapeCopy.SpatialReference;
                }
                trailFe = feCur.NextFeature();
            }*/
            IPointCollection newPolyline = new PolylineClass();
            ((IGeometry)newPolyline).SpatialReference = startWaypoint.ShapeCopy.SpatialReference;
            HashSet<string> points = new HashSet<string>();
            for(int i = 0 ; i < geomCol.GeometryCount; i++)
            {
                IPointCollection geomPntCol = geomCol.get_Geometry(i) as IPointCollection;
                for (int j = 0; j < geomPntCol.PointCount; j++ )
                {
                    IPoint pnt = geomPntCol.get_Point(j);
                    string pntString = pnt.X + "," + pnt.Y;
                    if(points.Contains(pntString) == false)
                    {
                        points.Add(pntString);
                        pnt.SpatialReference = startWaypoint.ShapeCopy.SpatialReference;
                        newPolyline.AddPoint(pnt);
                    }
                }

            }
            IPolyline fullTrail = newPolyline as IPolyline;
            fullTrail.SpatialReference = startWaypoint.ShapeCopy.SpatialReference;
            //ITopologicalOperator unionedPolyline = new PolylineClass();
            //unionedPolyline.ConstructUnion(geomCol as IEnumGeometry);
            //IPolyline fullTrail = unionedPolyline as IPolyline;
            Marshal.FinalReleaseComObject(feCur);
            IFeature fromPoint = waypointFC.GetFeature(Convert.ToInt16( startWaypointOID));
            IProximityOperator proxOp = fromPoint.ShapeCopy as IProximityOperator;
            double fromPointDist = proxOp.ReturnDistance(fullTrail.FromPoint);
            if (proxOp.ReturnDistance(fullTrail.ToPoint) == 0)
            {
                fullTrail.ReverseOrientation();
            }
            int dividePointIndex = 1;
            List<IPoint> pointsOnTrail = new List<IPoint>();
            double totalDistance = 0;
            while(dividePointIndex * distanceBetweenPoints < fullTrail.Length)
            {
                IPoint outPoint = new PointClass();
                fullTrail.QueryPoint(esriSegmentExtension.esriNoExtension, dividePointIndex * distanceBetweenPoints, false, outPoint);
                outPoint.SpatialReference = existingSpatRef;
                outPoint.Project(spatRef);
                pointsOnTrail.Add(outPoint);
                dividePointIndex++;
            }
            StringBuilder sb = new StringBuilder();
            List<string> locationStrings = new List<string>();
            int locationPointsInStringBuilder = 0;
            for (int i = 0; i < pointsOnTrail.Count; i++)
            {
                if(sb.Length > 0)
                {
                    sb.Append("|");
                }
                sb.Append(pointsOnTrail[i].Y);
                sb.Append(",");
                sb.Append(pointsOnTrail[i].X);
                locationPointsInStringBuilder++;
                if (locationPointsInStringBuilder > 33)
                {
                    locationStrings.Add(sb.ToString());
                    sb = new StringBuilder();
                    locationPointsInStringBuilder = 0;
                }
            }
            locationStrings.Add(sb.ToString());
            //FileStream fsw = File.OpenWrite(@"c:\temp\SectionAElevations.txt");
            int counter = 0;
            foreach(string locString in locationStrings)
            {
                counter++;
                //FileStream fsw = File.OpenWrite(@"c:\temp\SectionAElevations.txt");
                string address = "https://maps.googleapis.com/maps/api/elevation/json?locations=" + locString + "&key=AIzaSyBJlaYSBeJkYl_G2tInjNJBYmjJhaSulLA";
                System.Threading.Thread.Sleep(1000);
                string reply = client.DownloadString(address);
                File.AppendAllText(@"c:\temp\Section" + sectionName + "Elevations.txt", reply + Environment.NewLine);
            }

            //        https://maps.googleapis.com/maps/api/elevation/json?locations=39.7391536,-104.9847034|36.455556,-116.866667&key=AIzaSyC2WxuR5N1TKk5rfFrFQSd_IwMlg3TvVnM
            //string address = @"https://maps.googleapis.com/maps/api/elevation/json?path=" + path +  "&samples=" + samples + "&key=AIzaSyC2WxuR5N1TKk5rfFrFQSd_IwMlg3TvVnM";
        }
开发者ID:RiverTaig,项目名称:GDT,代码行数:101,代码来源:btnCreateElevationPoints.cs

示例14: OnClick

        protected override void OnClick()
        {
            int beginingDistance = 1485480;//distanc for the first point in this section

            MakeTxtFileOfJSONElevationResponses();
            //return;
            string trailName = "GDT";
            string section = "G";
            IFeatureClass trailFC = null;
            IFeatureClass elevationFC = null;
            IFeatureClass waypointFC = null;
            GetFeatureClasses(ref trailFC, ref elevationFC, ref waypointFC);
            IWorkspaceEdit wse = (IWorkspaceEdit)(elevationFC as IDataset).Workspace;
            wse.StartEditing(false);
            wse.StartEditOperation();
            Type factoryType = Type.GetTypeFromProgID("esriGeometry.SpatialReferenceEnvironment");
            System.Object obj = Activator.CreateInstance(factoryType);
            ISpatialReferenceFactory spatialReferenceFactory = obj as ISpatialReferenceFactory;
            ISpatialReference spatRef = spatialReferenceFactory.CreateGeographicCoordinateSystem(4326);
            ISpatialReference spatRefWGS = spatialReferenceFactory.CreateProjectedCoordinateSystem(3857);

            string fullText = File.ReadAllText(@"c:\temp\section'" + section + "'elevations.txt");
            string[] split = new string[1];
            split[0] = Environment.NewLine;
            string[] results = fullText.Split(split, StringSplitOptions.None);
            double dat = 0;
            foreach (string json in results)
            {
                RootObject root = JsonConvert.DeserializeObject<RootObject>(json);
                if (root != null)
                {
                    foreach (Result result in root.results)
                    {
                        double elevation = result.elevation;
                        double lat = result.location.lat;
                        double lng = result.location.lng;
                        double resolotuion = result.resolution;
                        IPoint pnt = new PointClass();
                        pnt.SpatialReference = spatRef;
                        pnt.PutCoords(lng, lat);
                        pnt.Project(spatRefWGS);
                        IFeature newFeature = elevationFC.CreateFeature();
                        newFeature.Shape = pnt;
                        newFeature.set_Value(newFeature.Fields.FindField("ELEVATION"), elevation);
                        newFeature.set_Value(newFeature.Fields.FindField("LAT"), lat);
                        newFeature.set_Value(newFeature.Fields.FindField("LNG"), lng);
                        newFeature.set_Value(newFeature.Fields.FindField("RESOLUTION"), resolotuion);
                        newFeature.set_Value(newFeature.Fields.FindField("TRAILNAME"), trailName);
                        newFeature.set_Value(newFeature.Fields.FindField("SECTION"), section);
                        double dat2 = beginingDistance + dat;
                        newFeature.set_Value(newFeature.Fields.FindField("DISTANCEALONGTRAIL"), dat2);
                        newFeature.Store();
                        dat = dat + 10;
                    }
                }
            }

            wse.StopEditOperation();
            wse.StopEditing(true);
        }
开发者ID:RiverTaig,项目名称:GDT,代码行数:60,代码来源:btnCreateElevationPoints.cs

示例15: DisplayAgentLocation

		private void DisplayAgentLocation(AGENT_IN_FIELD agent)
		{
			//Create a point and get the IPoint interface
			IPoint point = new PointClass();
			//Set the points x and y coordinates
			point.PutCoords(agent.Longitude, agent.Latitude);
			//Set the points spatial reference - WHERE the point is coming FROM
			point.SpatialReference = m_GeographicCoordinateSystem;
			//Project the point onto the displays current spatial reference - WHERE the point is going TO
			point.Project(m_ProjectedCoordinateSystem);

			//Create a marker element and get the IElement interface
			IElement element = new MarkerElementClass();
			//Set the elements geometry
			element.Geometry = point;

			//QI for the IMarkerElement interface from the IElement interface
			IMarkerElement markerElement = (IMarkerElement) element;
			//Set the marker symbol
			markerElement.Symbol = GetMarkerSymbol(agent.Located);

			//QI for the IElementProperties interface from the IMarkerElement interface
			IElementProperties elementProperties = (IElementProperties) markerElement;
			elementProperties.Name = agent.Located.ToString();

			//Add the element to the graphics container
			m_GraphicsContainer.AddElement(element, 0);
		}
开发者ID:Esri,项目名称:arcobjects-sdk-community-samples,代码行数:28,代码来源:GeoEvents.cs


注:本文中的PointClass.Project方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。