乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 53|回复: 3

请问如何获取当前图的所有图层?

[复制链接]

16

主题

48

帖子

1

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
112
发表于 2011-8-29 11:51:00 | 显示全部楼层 |阅读模式
Database db = Autodesk..ApplicationServices.Application.DocumentManager.MdiActiveDocument.Database;
          Transaction trans = db.TransactionManager.StartTransaction();
          try
          {
              BlockTable bt = (BlockTable)(trans.GetObject(db.BlockTableId, OpenMode.ForWrite));
              BlockTableRecord btr = (BlockTableRecord)trans.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite);
              //Create the block reference...use the return from CreateEmployeeDefinition directly!
              BlockReference br = new BlockReference(pStart, CreatePolePedDefinition(pCellName));
              br.LayerId = CreateLayer(pLayerName);
              ObjectId newBtrId = btr.AppendEntity(br); //Add the reference to ModelSpace
              trans.AddNewlyCreatedDBObject(br, true); //Let the transaction know about it
              DBObject obj = trans.GetObject(newBtrId, OpenMode.ForWrite);
              XDataDispose.AddRegAppTableRecord("xlentComms");
              ResultBuffer rb = new ResultBuffer(
                  new TypedValue(1001, "xlentComms"),
                  new TypedValue(1000, pMslink + "," + pEntityNo)
                );
             obj.XData = rb;
             rb.Dispose();
             trans.Commit(); // Commit is always required to indicate success.
             Editor ed = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Editor;
             //db.SaveAs(ed.Document.Name, null);
             db.SaveAs(ed.Document.Name, true, DwgVersion.Current, db.SecurityParameters);
          }
现在要获取当前图中所有pLayerName
回复

使用道具 举报

75

主题

306

帖子

10

银币

中流砥柱

Rank: 25

铜币
606
发表于 2011-8-29 13:48:00 | 显示全部楼层
  1. Function GetLayers() As String()
  2.       
  3.         Using Trans As Transaction = DB.TransactionManager.StartTransaction
  4.             Dim LayT As LayerTable = Trans.GetObject(DB.LayerTableId, OpenMode.ForRead)
  5.             Dim ID As ObjectId, LayTR As LayerTableRecord, Lays As New List(Of String)
  6.             For Each ID In LayT
  7.                 LayTR = Trans.GetObject(ID, OpenMode.ForRead)
  8.                 Lays.Add(LayTR.Name)
  9.             Next
  10.             Trans.Commit()
  11.             GetLayers = Lays.ToArray
  12.         End Using
  13.     End Function
回复

使用道具 举报

13

主题

39

帖子

2

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
91
发表于 2011-8-29 16:38:00 | 显示全部楼层
Database db = HostApplicationServices.WorkingDatabase;
             List list = new List();
             using (Transaction trans = db.TransactionManager.StartTransaction())
             {
                 LayerTable layertable = (LayerTable)trans.GetObject(db.LayerTableId,
OpenMode.ForWrite);  //得到所有的层表
                 if (layertable != null)
                 {
                     foreach (ObjectId id in layertable)   //遍历层表
                     {
                          LayerTableRecord tr=trans.GetObject(id,OpenMode.ForRead)
                     as LayerTableRecord;   //获得层表记录
                          list.Add(tr);   //将所有的图层放入一个集合中
                     }
                  
                 }
          }     
     希望能帮到你!!!
回复

使用道具 举报

16

主题

48

帖子

1

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
112
发表于 2011-8-29 16:40:00 | 显示全部楼层
谢谢!
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-6-29 19:00 , Processed in 0.283356 second(s), 61 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表