AE读取CAD图层包括注记

本文介绍了一种通过遍历特征类容器中的特征类,并将它们加载到数据库的方法。该方法涉及读取不同类型的地理要素(如点、线、面),并针对每种类型进行特定的操作,例如为点要素提取坐标等。
        public override void FillDatabase(Teigha.DatabaseServices.Database pDb)
        {
            IFeatureClassContainer pFeatureClassContainer = pCADFeatureDataset as IFeatureClassContainer;
            IEnumFeatureClass pEnumFeatureClass = pFeatureClassContainer.Classes;
            IFeatureClass pFeatureClass = pEnumFeatureClass.Next();
           
            while (pFeatureClass != null)
            {               
                LoadLayer(pFeatureClass, pDb);
                Debug.WriteLine(pFeatureClass.FeatureType.ToString() + "-" + pFeatureClass.AliasName + "-" + pFeatureClass.ShapeType.ToString());
                pFeatureClass = pEnumFeatureClass.Next();
            }
        }
        private void LoadLayer(IFeatureClass pFeatureClass, Teigha.DatabaseServices.Database pDb)
        {

            int indx = pFeatureClass.FindField("Layer");
            int idxColor = pFeatureClass.FindField("Color");
            int idxText = pFeatureClass.FindField("TxtMemo");
            int idxHandle = pFeatureClass.FindField("Handle");
           
            pCursor = pFeatureClass.Search(null, false);
            IFeature pFeature2 = pCursor.NextFeature();
            //写入点线
          
          if (pFeatureClass.FeatureType == esriFeatureType.esriFTCoverageAnnotation)
                {
                    while (pFeature2 != null)
                    {
                        string geoName = "C_" + pFeature2.get_Value(indx).ToString();
                        string sAnnotation = pFeature2.get_Value(idxText).ToString();
                        IPoint pPoint = pFeature2.Shape as IPoint;
                        double x = 0, y = 0;
                        pPoint.QueryCoords(out x, out y);
                        Point3d pt = new Point3d(x, y, 0);
                        addTextEnt(modelSpaceId, pt, pt, sAnnotation, 2, TextHorizontalMode.TextLeft, TextVerticalMode.TextTop, LayerNames[geoName], ttfStyleId);
                        pFeature2 = pCursor.NextFeature();
                    }
                }
                else
                {
                    if (pFeatureClass.ShapeType == esriGeometryType.esriGeometryPoint)
                    {
                        while (pFeature2 != null)
                        {
                            IPoint pt = pFeature2.Shape as IPoint;
                            pFeature2 = pCursor.NextFeature();
                        }
                    }
                    else if (pFeatureClass.ShapeType == esriGeometryType.esriGeometryPolyline)
                    {
                        short shtColor = 1;
                        while ((pFeature2 = pCursor.NextFeature()) != null)
                        {
                            string geoName = "C_" + pFeature2.get_Value(indx).ToString();
                        }
                    }
                    else if (pFeatureClass.ShapeType == esriGeometryType.esriGeometryPolygon)
                    {
                        short shtColor = 1;
                        while ((pFeature2 = pCursor.NextFeature()) != null)
                        {
                            string geoName = "C_" + pFeature2.get_Value(indx).ToString();                           
                        }
                    }
            }
           System.Runtime.InteropServices.Marshal.ReleaseComObject(pCursor);
            pCursor = null;
        }
    }


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值