c#cad 创建-圆(二)

运行环境 vs2022 c# cad2016 调试成功

一、代码说明

这段代码是一个AutoCAD插件,用于在模型空间中创建一个圆形。

首先,我们需要定义一个命令类CreateCircleCommand,并在命名空间CreateCircleInCad中声明。

在CreateCircleCommand类中,我们使用了CommandMethod特性,将该方法定义为一个命令。命令的名称为"CreateCircle"。

在CreateCircleCommand方法中,我们首先通过Application.DocumentManager.MdiActiveDocument获取当前文档,然后通过doc.Database获取数据库对象,通过doc.Editor获取编辑器对象。

接着,我们通过数据库的事务管理器创建一个事务,并通过事务来打开块表(BlockTable)。然后,通过块表的ModelSpace获取模型空间的块表记录(BlockTableRecord)。

接下来,我们定义了一个Point3d对象作为圆心位置,坐标为(0,0,0),以及一个double类型变量作为圆的半径,半径为5。

接着,我们使用事务来操作模型空间。首先,我们创建了一个Circle对象,并将其添加到模型空间的块表记录中。然后,通过事务的AddNewlyCreatedDBObject方法将该对象从事务中添加到数据库中。

最后,我们使用编辑器对象的WriteMessage方法来输出一条信息,表示圆已被创建。

总体来说,这段代码的作用是在AutoCAD模型空间中创建一个半径为5的圆。

二、完整代码

cs 复制代码
using Autodesk.AutoCAD.Runtime;
using Autodesk.AutoCAD.ApplicationServices;
using Autodesk.AutoCAD.EditorInput;
using Autodesk.AutoCAD.DatabaseServices;
using Autodesk.AutoCAD.Geometry;

[assembly: CommandClass(typeof(CreateCircleInCad.CreateCircleCommand))]

namespace CreateCircleInCad
{
    public class CreateCircleCommand
    {
        [CommandMethod("CreateCircle")]
        public void CreateCircleCommand()
        {
            Document doc = Application.DocumentManager.MdiActiveDocument;
            Database db = doc.Database;
            Editor ed = doc.Editor;
            Transaction tr = db.TransactionManager.StartTransaction();
            BlockTable bt = tr.GetObject(db.BlockTableId, OpenMode.ForRead) as BlockTable;
            BlockTableRecord btr = tr.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite) as BlockTableRecord;
            Point3d centerPoint = new Point3d(0, 0, 0); // 圆心位置
            double radius = 5; // 圆的半径
            using (tr)
            {
                // 创建圆形对象并添加到模型空间中
                Circle circle = new Circle(centerPoint, radius);
                btr.AppendEntity(circle);
                tr.AddNewlyCreatedDBObject(circle, true);
                ed.WriteMessage("\n圆已创建!");
            }
        }
    }
}

//感谢大家的点赞,收藏,转发,关注

相关推荐
山岚的运维笔记2 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里3 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科3 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦4 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
程序员敲代码吗5 小时前
如何通过命令行启动COMSOL的参数化、批处理和集群扫描
java·c#·bash
晚霞的不甘5 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位5 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全
海奥华25 小时前
mysql索引
数据库·mysql
2601_949593656 小时前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__6 小时前
mysql新老项目版本选择
数据库·mysql