• C#操作CAD-读取和修改数据


    我们操作cad最主要的目的就是读取和修改或者删除数据,因为内容较多,在此我们先讲一下基础,后续慢慢讲解。

    1、cad数据读取和修改前都要进行锁定操作,以避免一个文档被多个用户修改而发生冲突。

    Database db = HostApplicationServices.WorkingDatabase; //当前数据库 
                using (Transaction tr = db.TransactionManager.StartTransaction()) //using,自动调用Dispose方法
                { 
                    //处理过程
                    tr.Commit(); 
                    //事务提交
                }

    2、我们在处理过程中输入自己想要的代码就可以正常操作了,要不然会报错的。

    然后我们就要进行图形数据的读取了,但是因为内容太多,所以会后续更新,在此简单附上一个在屏幕上选择单个实体的代码。

    public static Entity Select(string word)
            {
                Document doc = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument;
                Database db = doc.Database; Editor ed = doc.Editor;
                Entity entity null;
                PromptEntityResult ent = ed.GetEntity(word);
                if (ent.Status == PromptStatus.OK)
                {
                    using (Transaction transaction = db.TransactionManager.StartTransaction())
                    {
                        entity = (Entity)transaction.GetObject(ent.ObjectId, OpenMode.ForWrite, true);
                        transaction.Commit();
                    }
                }
                return entity;
            }

    3、我们读取的数据一般都是多个,所以要进行遍历筛选处理。

    using (Transaction trans = db.TransactionManager.StartTransaction())
                {
                    foreach (DBObject ob in texts)
                    {
                        DBText text = (DBText)transaction.GetObject(ob.ObjectId, OpenMode.ForWrite, true);
                        ………………………………操作内容
                    }
                    trans.Commit();
                }
    身是菩提树,心如明镜台,时时勤拂拭,勿使惹尘埃。
  • 相关阅读:
    Flask_之使用过程中出现的异常
    GO-学习之golang 自动下载所有依赖包
    数据库-Oracle如何将clob数据以字符串打印出来
    数据库-Oracle条件判断语句
    python框架Django汇总
    每日一模块_os及subprocess模块【执行系统命令】
    每日一模块-sftp的使用
    python并发编程-队列MQ的学习
    python高效配置-响应code枚举类设计
    git-使用大全
  • 原文地址:https://www.cnblogs.com/birdofparadise/p/6919390.html
Copyright © 2020-2023  润新知