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圆已创建!");
            }
        }
    }
}

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

相关推荐
字节跳动数据平台11 小时前
火山引擎多模态数据湖:基于 Daft 与 Lance,构筑 AI 时代数据湖新范式
数据结构·数据库·数据挖掘
妙妙屋(zy)12 小时前
简单来讲讲C#中的锁
c#·.net
倔强的石头_14 小时前
零门槛体验国产数据库硬核实力 —— 金仓 KingbaseES 在线体验平台全解析
数据库
唐青枫21 小时前
对象映射从未如此简单!C#.NET AutoMapper 超详细教程
c#·.net
AAA修煤气灶刘哥1 天前
数据库优化自救指南:从SQL祖传代码到分库分表的骚操作
数据库·后端·mysql
yghr3a2 天前
[项目开发经验分享]基于强类型事件的类型参数传递问题 —— 在 .NET Winform项目中如何设计泛型事件总线以实现UI与核心层的解耦
c#·.net framework
老纪的技术唠嗑局2 天前
经验分享 —— 在 Ubuntu 虚拟机中部署 OceanBase 数据库
数据库·ubuntu
咖啡Beans2 天前
MySQL中使用@符号定义用户变量
数据库·mysql
GreatSQL2 天前
MySQL迁移至GreatSQL后,timestamp字段插入报错解析
数据库
expect7g2 天前
COW、MOR、MOW
大数据·数据库·后端