找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 3703|回复: 8

[原创] 练习 Lisp定义选择集包围盒

[复制链接]

已领礼包: 859个

财富等级: 财运亨通

发表于 2014-4-26 11:12:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
[ 本帖最后由 csharp 于 2014-4-26 14:22 编辑 ]\n\n
  1.         [LispFunction("ssbox")]
  2.         public static ResultBuffer SelectionBox(ResultBuffer rb)
  3.         {
  4.             Document document = Application.DocumentManager.MdiActiveDocument;
  5.             Transaction transaction = document.TransactionManager.StartTransaction();
  6.             if (rb == null) return null;
  7.             TypedValue[] tvValues = rb.AsArray();
  8.             using (transaction)
  9.             {
  10.                 try
  11.                 {
  12.                     ResultBuffer result = new ResultBuffer();
  13.                     if (tvValues.Length == 1 && tvValues[0].TypeCode == (int)LispDataType.SelectionSet)
  14.                     {
  15.                         SelectionSet ssSet = tvValues[0].Value  as SelectionSet;
  16.                         var ids = ssSet.GetObjectIds();
  17.                         Entity ent = (Entity)transaction .GetObject( ids [0],OpenMode.ForRead ) ;
  18.                         Extents3d tmpExtents3D = ent.GeometricExtents;
  19.                         for (int i = 1; i < ids.Length ; i++)
  20.                         {
  21.                             Entity entity = (Entity) transaction.GetObject(ids[i], OpenMode.ForRead);
  22.                             Extents3d tmp = entity.GeometricExtents;
  23.                             tmpExtents3D.AddExtents(tmp);
  24.                         }
  25.                         Point3d maxpt = tmpExtents3D.MaxPoint;
  26.                         Point3d minpt = tmpExtents3D.MinPoint;
  27.                         
  28.                         result.Add(new TypedValue((int) LispDataType.Point3d, minpt));
  29.                         result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
  30.                     }
  31.                     transaction.Commit();
  32.                     return result ;
  33.                 }
  34.                 catch (Exception)
  35.                 {
  36.                     
  37.                     throw;
  38.                 }
  39.             }
  40.             
  41.         }

没有进行坐标转换

因为这个返回值仅有两个点, 效率比 vla-getboundingbox 要高非常之多!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 859个

财富等级: 财运亨通

 楼主| 发表于 2014-4-26 15:06:30 | 显示全部楼层
再加几句支持实体或者选择集
  1.         [LispFunction("ssbox")]
  2.         public static ResultBuffer SelectionBox(ResultBuffer rb)
  3.         {
  4.             Document document = Application.DocumentManager.MdiActiveDocument;
  5.             Editor editor = document.Editor;
  6.             Transaction transaction = document.TransactionManager.StartTransaction();
  7.             if (rb == null) return null;
  8.             TypedValue[] tvValues = rb.AsArray();
  9.             using (transaction)
  10.             {
  11.                 try
  12.                 {
  13.                     ResultBuffer result = new ResultBuffer();
  14.                     if (tvValues.Length == 1 && tvValues[0].TypeCode == (int)LispDataType.SelectionSet | tvValues [0].TypeCode == (int)LispDataType .ObjectId )
  15.                     {
  16.                         switch (tvValues[0].TypeCode)
  17.                         {
  18.                             case 5006:
  19.                             {
  20.                                 Entity entity =
  21.                                     (Entity) transaction.GetObject((ObjectId) tvValues[0].Value, OpenMode.ForRead);
  22.                                 Extents3d tmpExtents3D = entity.GeometricExtents;
  23.                                 Point3d maxpt = tmpExtents3D.MaxPoint;
  24.                                 Point3d minpt = tmpExtents3D.MinPoint;
  25.                                 result.Add(new TypedValue((int)LispDataType.Point3d, minpt));
  26.                                 result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
  27.                                 break;
  28.                             }
  29.                             case 5007:
  30.                             {
  31.                                 SelectionSet ssSet = tvValues[0].Value as SelectionSet;
  32.                                 var ids = ssSet.GetObjectIds();
  33.                                 Entity ent = (Entity)transaction.GetObject(ids[0], OpenMode.ForRead);
  34.                                 Extents3d tmpExtents3D = ent.GeometricExtents;
  35.                                 for (int i = 1; i < ids.Length; i++)
  36.                                 {
  37.                                     Entity entity = (Entity)transaction.GetObject(ids[i], OpenMode.ForRead);
  38.                                     Extents3d tmp = entity.GeometricExtents;
  39.                                     tmpExtents3D.AddExtents(tmp);
  40.                                 }
  41.                                 Point3d maxpt = tmpExtents3D.MaxPoint;
  42.                                 Point3d minpt = tmpExtents3D.MinPoint;
  43.                                 result.Add(new TypedValue((int)LispDataType.Point3d, minpt));
  44.                                 result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
  45.                                 break;
  46.                             }
  47.                         }
  48.                     }
  49.                     transaction.Commit();
  50.                     return result ;
  51.                 }
  52.                 catch (Autodesk .AutoCAD .Runtime .Exception ex)
  53.                 {
  54.                     return null;
  55.                 }
  56.             }
  57.         }
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1632个

财富等级: 堆金积玉

发表于 2014-5-4 22:39:57 | 显示全部楼层
建议写一下增加坐标转换的{:soso_e140:}
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 9个

财富等级: 恭喜发财

发表于 2019-4-19 12:49:37 | 显示全部楼层
C# Lispfunction 继续学习
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 96个

财富等级: 招财进宝

发表于 2019-8-27 20:25:25 | 显示全部楼层
样条包围盒不行
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2019-8-27 22:02:12 | 显示全部楼层
这个感觉就比lisp难多了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2019-9-1 00:17:09 来自手机 | 显示全部楼层
什么叫包围盒啊
来自: 微社区
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 58个

财富等级: 招财进宝

发表于 2019-10-5 20:10:51 | 显示全部楼层
本帖最后由 brainstorm 于 2019-10-5 21:43 编辑

学着改写一下,支持用户坐标系,功能与xdrx_entity_box相同,但是在没有安装天正机器上天正对象报错,而xdrx_entity_box没问题。速度比xdrx_entity_box要快一些
命令: TT1(ssbox)
选择对象: 指定对角点: 找到 40086 个
选择对象:
"2.141"
命令:
命令: TT2(xdrx_entity_box)
选择对象: 指定对角点: 找到 40086 个
选择对象:
"6.39"

public static Matrix3d GetUcsMatrix(Database db)
        {
            Point3d origin;
            Vector3d xAxis, yAxis, zAxis;
            if (IsPaperSpace(db))
            {
                origin = db.Pucsorg;
                xAxis = db.Pucsxdir;
                yAxis = db.Pucsydir;
            }
            else
            {
                origin = db.Ucsorg;
                xAxis = db.Ucsxdir;
                yAxis = db.Ucsydir;
            }
            zAxis = xAxis.CrossProduct(yAxis);
            return Matrix3d.AlignCoordinateSystem(kOrigin, kXAxis, kYAxis, kZAxis, origin, xAxis, yAxis, zAxis);
        }
        public static Database GetCurDwg()
        {
            Database db = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Database;
            return db;
        }

[LispFunction("ssbox")]
        public static ResultBuffer SelectionBox(ResultBuffer rb)
        {
            Document document = Application.DocumentManager.MdiActiveDocument;
            Editor editor = document.Editor;
            Transaction transaction = document.TransactionManager.StartTransaction();
            Matrix3d m1 = GetUcsMatrix(GetCurDwg());
            m1 = m1.Inverse();
            object obj = Application.GetSystemVariable("worlducs");
            if (rb == null) return null;
            TypedValue[] tvValues = rb.AsArray();
            using (transaction)
            {
                try
                {
                    ResultBuffer result = new ResultBuffer();
                    if (tvValues.Length == 1 && tvValues[0].TypeCode == (int)LispDataType.SelectionSet | tvValues[0].TypeCode == (int)LispDataType.ObjectId)
                    {
                        if (System.Convert.ToInt16(obj) != 0)
                        {
                            switch (tvValues[0].TypeCode)
                            {
                                case 5006:
                                    {
                                        Entity entity = (Entity)transaction.GetObject((ObjectId)tvValues[0].Value, OpenMode.ForRead);
                                        Extents3d tmpExtents3D = entity.GeometricExtents;
                                        Point3d maxpt = tmpExtents3D.MaxPoint;
                                        Point3d minpt = tmpExtents3D.MinPoint;
                                        result.Add(new TypedValue((int)LispDataType.Point3d, minpt));
                                        result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
                                        break;
                                    }
                                case 5007:
                                    {
                                        SelectionSet ssSet = tvValues[0].Value as SelectionSet;
                                        var ids = ssSet.GetObjectIds();
                                        Entity ent = (Entity)transaction.GetObject(ids[0], OpenMode.ForRead);
                                        Extents3d tmpExtents3D = ent.GeometricExtents;
                                        for (int i = 1; i < ids.Length; i++)
                                        {
                                            Entity entity = (Entity)transaction.GetObject(ids, OpenMode.ForRead);
                                            Extents3d tmp = entity.GeometricExtents;
                                            tmpExtents3D.AddExtents(tmp);
                                        }
                                        Point3d maxpt = tmpExtents3D.MaxPoint;
                                        Point3d minpt = tmpExtents3D.MinPoint;
                                        result.Add(new TypedValue((int)LispDataType.Point3d, minpt));
                                        result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
                                        break;
                                    }
                            }
                        }
                        else
                        {
                            switch (tvValues[0].TypeCode)
                            {
                                case 5006:
                                    {
                                        Entity entity = (Entity)transaction.GetObject((ObjectId)tvValues[0].Value, OpenMode.ForWrite);
                                        entity.TransformBy(m1);
                                        Extents3d tmpExtents3D = entity.GeometricExtents;
                                        Point3d maxpt = tmpExtents3D.MaxPoint;
                                        Point3d minpt = tmpExtents3D.MinPoint;
                                        result.Add(new TypedValue((int)LispDataType.Point3d, minpt));
                                        result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
                                        break;
                                    }
                                case 5007:
                                    {
                                        SelectionSet ssSet = tvValues[0].Value as SelectionSet;
                                        var ids = ssSet.GetObjectIds();
                                        Entity ent = (Entity)transaction.GetObject(ids[0], OpenMode.ForWrite);
                                        ent.TransformBy(m1);
                                        Extents3d tmpExtents3D = ent.GeometricExtents;
                                        for (int i = 1; i < ids.Length; i++)
                                        {
                                            Entity entity = (Entity)transaction.GetObject(ids, OpenMode.ForWrite);
                                            entity.TransformBy(m1);
                                            Extents3d tmp = entity.GeometricExtents;
                                            tmpExtents3D.AddExtents(tmp);
                                        }
                                        Point3d maxpt = tmpExtents3D.MaxPoint;
                                        Point3d minpt = tmpExtents3D.MinPoint;
                                        result.Add(new TypedValue((int)LispDataType.Point3d, minpt));
                                        result.Add(new TypedValue((int)LispDataType.Point3d, maxpt));
                                        break;
                                    }
                            }
                        }
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 58个

财富等级: 招财进宝

发表于 2019-10-5 21:58:40 | 显示全部楼层
这个文件无法取得包围盒,不知道什么原因

Drawing2.rar

18.89 KB, 下载次数: 2, 下载积分: D豆 -1 , 活跃度 1

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-6-26 23:11 , Processed in 0.396852 second(s), 47 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表