为线要素增加高程值(Z值)

原创 2008年10月02日 00:28:00

编译通过,但还未调试:

//为线要素增加高程值(Z值)
void CAsongGISView::LineAddZvalue(IMapPtr ipMap, IQueryFilterPtr ipFilter)
{
 LONG count(0);
 HRESULT hr;

 ipMap->get_LayerCount(&count);
 for(int i = 0; i<count; i++)
    {
  ILayerPtr ipCurrentLayer;
  IGeoFeatureLayerPtr ipGeoFeat;

  ipMap->get_Layer(i,&ipCurrentLayer);
  hr = ipCurrentLayer->QueryInterface(IID_IGeoFeatureLayer,(LPVOID*)&ipGeoFeat);
  
  if(FAILED(hr))
  {
   AfxMessageBox("所打开的对象不是图形要素!");
   return;
  }
  else
        {
   IFeatureLayerPtr ipFeatureLayer(ipCurrentLayer);
   IFeatureClassPtr ipFeatureClass;

   ipFeatureLayer->get_FeatureClass(&ipFeatureClass);
            IDatasetPtr ipDataset(ipFeatureClass);

            if (ipDataset != NULL)
            {
    IWorkspacePtr  ipWork;
    ipDataset->get_Workspace(&ipWork);

    IWorkspaceEditPtr ipWorkspaceEdit(ipWork);

    VARIANT_BOOL vbIsBeginEdited;
    ipWorkspaceEdit->IsBeingEdited(&vbIsBeginEdited);
                if (!vbIsBeginEdited)
    {
     ipWorkspaceEdit->StartEditing(VARIANT_TRUE);
                    ipWorkspaceEdit->StartEditOperation();
                    ipWorkspaceEdit->EnableUndoRedo();//true;
                    IFeatureLayerPtr ipEditFeatureLayer(ipCurrentLayer);

     long lSHAPE;
     long lng_strSurH;
     long lng_endSurH(0);

     IFeatureClassPtr ipFeatCls;
     IFieldsPtr  ipFields;
     IFieldPtr  ipField;


     ipEditFeatureLayer->get_FeatureClass(&ipFeatCls);
     ipFeatCls->get_Fields(&ipFields);
     ipFields->FindField(CComBSTR("SHAPE"),&lSHAPE);

     ipFields->FindField(CComBSTR("Elevation"),&lng_strSurH);
     //ipFields->FindField(CComBSTR("END_H"),&lng_endSurH);
                   
     if (!(lng_strSurH == -1 || lng_endSurH == -1))
                    {
      esriGeometryType shpType;
      ipFeatCls->get_ShapeType(&shpType);
      if (shpType == esriGeometryLine || shpType == esriGeometryPolyline)
                        {
       long    RecNumber;
                            IFeatureCursorPtr ipCursor;
                            IFeaturePtr   ipFeature;

       ipFeatCls->FeatureCount(ipFilter,&RecNumber);
       ipEditFeatureLayer->Search(ipFilter, VARIANT_TRUE,&ipCursor);
       ipCursor->NextFeature(&ipFeature);

                            while (ipFeature != NULL)
       {
        IGeometryPtr ipGeom;
        ipFeature->get_Shape(&ipGeom);
                                IZAwarePtr  ipNewZaware(ipGeom);

        ipNewZaware->put_ZAware(VARIANT_TRUE);
                                IPointCollectionPtr ipPointCollection(ipGeom);
                                   
        //给第一个点及最后一个点加Z值
                                IPointPtr ipGeo_TempPoint;
        long  ptCount;
        double  dblZ;
        VARIANT  vdblValue;

        ipPointCollection->get_PointCount(&ptCount);
        ipPointCollection->get_Point(0,&ipGeo_TempPoint);
        ipFeature->get_Value(lng_strSurH,&vdblValue);
                                dblZ = vdblValue.dblVal;
        ipGeo_TempPoint->put_Z(dblZ);

                                ipPointCollection->UpdatePoint(0, ipGeo_TempPoint);                             
        ipPointCollection->get_Point(ptCount-1,&ipGeo_TempPoint);

        ipFeature->Store();
                                ipCursor->NextFeature(&ipFeature);
       }
      }
     }
                    ipWorkspaceEdit->StopEditOperation();
                    ipWorkspaceEdit->StopEditing(VARIANT_TRUE);
    }
   }
  }
 }
}

计划明天调试一下,可能还有很多需要改动的地方。

在ArcEngine中创建带高程Z值的点和线图层

管线和其附属物的坐标数据都是带有Z值的 而且有些情况下,一个管段的两个端点的x,y值一模一样(垂直的管段) 这样的线,在直接生成shape图层的时候,就会产生问题,特别是 使用ArcSDE的C ...
  • NickWar
  • NickWar
  • 2010年07月21日 15:10
  • 6775

AE线要素编辑

1、高亮显示节点 [csharp] view plaincopy //高亮显示节点和端点           public void HighLigh...
  • u012016149
  • u012016149
  • 2015年04月07日 11:35
  • 779

为等高线添加高程值标注,如何做出掩膜的效果

首先我们科普一下掩膜的知识,掩膜是利用遮盖或隐藏要素的视觉处理技术来增强地图表现力的一种手段,让地图更加清晰,经常用来处理多个图层由于叠放而出现压盖冲突的情况。掩膜实质是包含一些多边形要素的要素类,生...
  • qq_18461229
  • qq_18461229
  • 2017年07月17日 16:44
  • 318

QGis(三)查询矢量图层的要素属性字段值

当加载一个矢量图层后,如果要查看每个要素的属性
  • tszhangjunqiao
  • tszhangjunqiao
  • 2014年08月13日 15:17
  • 4288

C#使用GDAL计算某点的高程值

1.本人使用的是GDAL1.9.1,可以在http://download.osgeo.org/gdal/下载。 2.下载后解压到你所需要的位置如“C:\gdal-1.9.1”,可以修改以后的安装路径也...
  • du_peiduo
  • du_peiduo
  • 2013年12月25日 10:38
  • 2428

在ArcMap中如何将离高程点最近距离的数字赋给高程点

参与城市规划项目中,通常我们需要对项目的地形进行分析,经常会遇到一些尴尬的事,就是甲方发来的地形图是极其不规范。例如地形数据不规范,标准的地形图应该是高程点和注记组成块参照,并且点选块参照有标高信息。...
  • GIS_BT
  • GIS_BT
  • 2017年03月16日 00:05
  • 657

DEM提取一定高程值范围像元

最近在做水文分析,需要提取一定高程一下的像元,但是碰到个问题。 如果直接利用栅格计算器来提取,系统自动赋值。比如“DEM” 那么该怎么做呢? 做了很久发现了这么一个问题,原始DEM是没有...
  • Scarlett_OHara
  • Scarlett_OHara
  • 2015年12月14日 22:10
  • 2164

ArcGIS教程:3D 折线要素

面要素是一个 GIS 对象,其地理制图表达(一系列的 x 和 y 坐标对)作为其属性(或字段)之一存储在数据库的行中。某些线要素(例如地铁线)还需要包含 z 值或高度,以在 3D 空间对自身进行正确定...
  • u010687924
  • u010687924
  • 2015年04月30日 11:33
  • 627

统计_z值

z值
  • Young_Gy
  • Young_Gy
  • 2015年09月11日 10:59
  • 3754

白话空间统计之四:P值和Z值(上):零假设

本来今天想要讲讲软件操作的,后来发现好像还有好几个重要的指标没有说,干脆等全部说完在讲操作吧,否则操作出来的结果会发现大量的“不明觉厉”。     首先是空间统计里面很神秘的两个值:P值和Z...
  • allenlu2008
  • allenlu2008
  • 2015年07月30日 16:33
  • 8550
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:为线要素增加高程值(Z值)
举报原因:
原因补充:

(最多只允许输入30个字)