找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1210|回复: 1

[原创] 练习 Lisp定义SetMark及GetSS

[复制链接]

已领礼包: 859个

财富等级: 财运亨通

发表于 2014-5-13 08:48:25 | 显示全部楼层 |阅读模式

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

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

×
新建一个类用来记录 Entlast,最大记录5个 Entlast
  1.     public class MySSet
  2.     {
  3.         private static ObjectId []  myLastEnt = new ObjectId[5];

  4.         //构造函数
  5.         public static ObjectId[] MyLastEnt(int i ,ObjectId id)
  6.         {
  7.             myLastEnt[i] = id;
  8.             return myLastEnt;
  9.         }

  10.         public static void  Put(int i, ObjectId id)
  11.         {
  12.             myLastEnt[i] = id;
  13.         }

  14.         public static ObjectId  MyGetLastId(int i)
  15.         {
  16.             return myLastEnt[i];
  17.         }
  18.     }

定义一个 Lisp 函数标记 Entlast
  1.         [LispFunction("SetMark")]
  2.         public static Object  SetMark(ResultBuffer rb)
  3.         {
  4.             if (rb != null)
  5.             {
  6.                 TypedValue[] values = rb.AsArray();
  7.                 Boolean ret = true;
  8.                 if (values.Count() == 1 && values[0].TypeCode == (int) LispDataType.Int16)
  9.                 {
  10.                     int i = Convert.ToInt16(values[0].Value);
  11.                     if (i < 0 | i > 4)
  12.                     {
  13.                         i = 0;
  14.                     }
  15.                     ObjectId id = Utils.EntLast();
  16.                     if (id == ObjectId.Null)
  17.                     {
  18.                         id =  Utils.EntFirst();
  19.                     }
  20.                     MySSet.Put(i, id);
  21.                     return ret;
  22.                 }
  23.                 else
  24.                 {
  25.                     return null;
  26.                 }
  27.                
  28.             }
  29.             else
  30.             {
  31.                 int i = 0;
  32.                 Boolean ret = true;
  33.                 MySSet.Put(i, Utils.EntLast());
  34.                 return ret;
  35.             }
  36.         }

再定义一个获取对应选择集的函数
  1.         [LispFunction("getss")]
  2.         public static Object MyGetSS(ResultBuffer rb)
  3.         {
  4.             int j;
  5.             if (rb == null)
  6.             {
  7.                 j = 0;
  8.             }
  9.             else
  10.             {
  11.                 TypedValue[] values = rb.AsArray();
  12.                 if (values.Count() == 1 && values[0].TypeCode == (int) LispDataType.Int16)
  13.                 {
  14.                     int i = Convert.ToInt16(values[0].Value);
  15.                     if (i < 0 | i > 4)
  16.                     {
  17.                         j = 0;
  18.                     }
  19.                     else
  20.                     {
  21.                         j = i;
  22.                     }
  23.                 }
  24.                 else
  25.                 {
  26.                     return null;
  27.                 }
  28.             }
  29.             ObjectId lastEnt = MySSet.MyGetLastId(j);
  30.             ObjectId[] ids = GetNextentIds(lastEnt);
  31.             if (ids.Count() > 0)
  32.             {
  33.                 SelectionSet ss = SelectionSet.FromObjectIds(ids);
  34.                 return ss;
  35.             }
  36.             else
  37.             {
  38.                 return null;
  39.             }
  40.         }

下面是一个获取函数
  1.         public static ObjectId[] GetNextentIds(ObjectId id)
  2.         {
  3.             ObjectIdCollection idColl = new ObjectIdCollection();
  4.             if (id != ObjectId.Null)
  5.             {
  6.                 ObjectId nextent = Utils.EntNext(id);
  7.                 idColl.Add(nextent);
  8.                 while (nextent != ObjectId.Null)
  9.                 {
  10.                     idColl.Add(nextent);
  11.                     nextent = Utils.EntNext(nextent);
  12.                 }
  13.             }
  14.             if (idColl.Count > 0)
  15.             {
  16.                 ObjectId[] ids = new ObjectId[idColl.Count];
  17.                 for (int i = 0; i < idColl.Count; i++)
  18.                 {
  19.                     ids[i] = idColl[i];
  20.                 }
  21.                 return ids;
  22.             }
  23.             else
  24.             {
  25.                 return null;
  26.             }
  27.         }


使用方法

(setmark) (getss) 默认保存到 0 标记

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

已领礼包: 859个

财富等级: 财运亨通

 楼主| 发表于 2014-5-13 08:51:43 | 显示全部楼层
本帖最后由 csharp 于 2014-5-13 10:53 编辑

.Net 中的Utils.Entnext 不加参数是忽略子实体(如块内)

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-6 01:32 , Processed in 0.378757 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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