cad.net 块裁剪边界反向修剪

本文介绍了如何在AutoCAD中使用.NET API查询XCLIP边界是否反转。在Acad2015及以上版本,可以使用SpatialFilter.Inverted函数,而在低版本则需要自定义实现。注意,示例代码未包含撤销和刷新操作,这部分需要读者自行完成。
摘要由CSDN通过智能技术生成

 

Querying for XCLIP information inside AutoCAD using .NET  这里下面观众讨论了

How do I determine if an x-clip boundary is inverted?

看起来Autodesk忘记了通过API公开此设置,或将其包含在DXF输出中.
也许您可以通过调用 SpatialFilter.ClipVolumeIntersectsExtents() 来确定它,它的内容完全在边界之内.
该设置通过 DwgOutFields() 提交给DWG文件管理器,因此,如果所有其他操作均失败,则可以编写一个自定义AcDbDwgFiler来捕获该设置。 

 

首先说明一下,根据以上的帖子,我们会得到一个消息是,桌子并没有封装好cad的块裁剪边界翻转部分.

然后我翻了翻api,在Acad2015版本上面是已经加了一个 SpatialFilter.Inverted 这个函数.

而我们低版本需要的就是重写出一个 Inverted ..

最后要进行刷新.

这样就完成了.

 

 

但是要注意下面的函数,它们只是个例子,没有提供撤销回滚的时候要刷新的操作...这个部分大家自己自行制作.

命令主函数部分:

    public static partial class Command_jjMoveBlockCropBoundary
    {
        //选择图块,进行反向裁剪  
        [CommandMethod("test", CommandFlags.Modal | CommandFlags.UsePickSet | CommandFlags.Redraw | CommandFlags.Session)]
        public static void test()
        {
            Database db = HostApplicationServices.WorkingDatabase;//当前的数据库
            Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
            var peo = new PromptEntityOptions(Environment.NewLine + "点选图块:")
            {
                AllowObjectOnLockedLayer = false,
                AllowNone = false
            };
            var gt = ed.GetEntity(peo);
            if (gt.Status != PromptStatus.OK)
            {
                return;
            }
            using (Application.DocumentManager.MdiActiveDocument.LockDocument())//锁文档  用CommandFlags.Session就要锁,否则eLockViolation
            {
                using (Transaction tr = db.TransactionManager.StartTransaction())
                {
                    var ent = tr.GetObject(gt.ObjectId, OpenMode.ForRead);
                    if (ent is BlockReference acBlkRef)
                    {
                        SpatialFilter blockBoundaryInfo = BlockBoundaryInfo(acBlkRef, tr);//块裁剪边界信息   
                        if (blockBoundaryInfo != null)
                        {
                            //直接设置为反向
                            blockBoundaryInfo.UpgradeOpen();
#if false //这个在2015以上版本有,但是下面的操作是通用的
                            blockBoundaryInfo.Inverted = !blockBoundaryInfo.Inverted;
#endif
                            var fa = blockBoundaryInfo.Inverted(out XmDwgFiler xmDwgFiler);
                            blockBoundaryInfo.SetInverted(xmDwgFiler);

                            blockBoundaryInfo.DowngradeOpen();
 
                            acBlkRef.UpgradeOpen();
                            acBlkRef.RecordGraphicsModified(true);//记录图元已修改,这个之前要ent.UpgradeOpen()
                            acBlkRef.DowngradeOpen();
                        }
                    }
                    tr.Commit();
                }
            }
        }
View Code

 

判断和设置部分.

        /// <summary>
        /// 边界是否为反向裁剪
        /// </summary>
        /// <param name="spatialFilter">裁剪信息</param>
        /// <returns></returns>
        public static bool Inverted(this SpatialFilter spatialFilter, out XmDwgFiler xmDwgFiler)
        {
            xmDwgFiler = new XmDwgFiler();
            spatialFilter.DwgOut(xmDwgFiler);
            var f = xmDwgFiler.UInt16List[1];
            if (f != 1)
            {
                return false;
            }
            else
            {
                return true;
            }
        }

        /// <summary>
        /// 设定反向裁剪
        /// </summary>
        /// <param name="spatialFilter">裁剪数据</param>
        /// <param name="xmDwgFiler">原始数据</param> 
        /// <returns></returns>
        public static void SetInverted(this SpatialFilter spatialFilter, XmDwgFiler xmDwgFiler)
        {
            if (xmDwgFiler.UInt16List[1] == 1)
            {
                xmDwgFiler.UInt16List[1] = 0;
            }
            else
            {
                xmDwgFiler.UInt16List[1] = 1;
            }
            spatialFilter.DwgIn(xmDwgFiler);
        }

 

 

继承DwgFiler的类,超长的部分...

    public class XmDwgFiler : DwgFiler
    {
        public FilerType m_FilerType;
        public ErrorStatus m_FilerStatus;

        public
#if AC2008
        int
#else
        long
#endif
        m_Position;

        //
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现这个功能,你可以按照以下步骤进行操作: 1. 在 ASP.NET MVC 中添加一个上传图片的控件。 2. 在控制器中编写上传图片的代码,将图片保存在服务器的指定文件夹中。 3. 使用 Image 类库对上传的图片进行裁剪操作。 4. 将裁剪后的图片再次保存在服务器的指定文件夹中。 5. 使用 HtmlHelper 中的 Image 方法在 View 中显示裁剪后的图片。 以下是一些示例代码,用于实现图片上传和裁剪的功能: 上传图片的控件: ``` @using (Html.BeginForm("Upload", "Home", FormMethod.Post, new { enctype = "multipart/form-data" })) { <input type="file" name="file" /> <input type="submit" value="Upload" /> } ``` 控制器中的上传图片代码: ``` [HttpPost] public ActionResult Upload(HttpPostedFileBase file) { if (file != null && file.ContentLength > 0) { var fileName = Path.GetFileName(file.FileName); var path = Path.Combine(Server.MapPath("~/Images"), fileName); file.SaveAs(path); } return RedirectToAction("Index"); } ``` 使用 Image 类库对图片进行裁剪: ``` public static void CropImage(string imagePath, int x, int y, int width, int height) { using (var image = Image.FromFile(imagePath)) { using (var croppedImage = new Bitmap(width, height)) { using (var graphics = Graphics.FromImage(croppedImage)) { graphics.DrawImage(image, new Rectangle(0, 0, width, height), x, y, width, height, GraphicsUnit.Pixel); } croppedImage.Save(imagePath); // 保存裁剪后的图片 } } } ``` 在 View 中显示裁剪后的图片: ``` @{ var imagePath = Url.Content("~/Images/myImage.jpg"); } <img src="@imagePath" alt="My Image" /> ``` 请注意,以上代码仅供参考,实际实现中可能需要根据具体需求进行修改。同时,为了保证安全性,需要对上传的图片进行一定的校验和过滤,以防止恶意攻击和非法操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值