明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1815|回复: 2

[基础] 实体的镜像

[复制链接]
发表于 2010-12-30 18:52:29 | 显示全部楼层 |阅读模式
本帖最后由 cdinten 于 2010-12-30 19:01 编辑

貌似AutoCAD2006中实体没有Mirror方法,这让人很纠结,写了个程序演示实体的镜像,代码如下:

  1. [CommandMethod("MP")]//Mirror Entity
  2. public void MirrorEntity()
  3. {
  4. Database db = Application.DocumentManager.MdiActiveDocument.Database;
  5. Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
  6. //对称平面
  7. Plane mp = new Plane(new Point3d(1, 0, 0), new Point3d(0, 1, 0), new Point3d(0, 0, 1));
  8. double x = mp.Normal.X;
  9. double y = mp.Normal.Y;
  10. double z = mp.Normal.Z;
  11. double[] dm = new double[16];
  12. dm[0] = 1 - 2 * x * x;
  13. dm[5] = 1 - 2 * y * y;
  14. dm[10] = 1 - 2 * z * z;
  15. dm[15]=1;
  16. dm[1] = dm[4] = -2*x * y;
  17. dm[2] = dm[8] = -2*x * z;
  18. dm[6] = dm[9] = -2*y * z;
  19. Matrix3d Tm = new Matrix3d(dm);
  20. using (Transaction trans = db.TransactionManager.StartTransaction())
  21. {
  22. BlockTable bt = (BlockTable)trans.GetObject(db.BlockTableId, OpenMode.ForRead);
  23. BlockTableRecord btr = (BlockTableRecord)trans.GetObject(db.CurrentSpaceId, OpenMode.ForWrite);
  24. Solid3d sld = new Solid3d();
  25. sld.SetDatabaseDefaults();
  26. sld.CreateBox(100, 150, 200);
  27. sld.ColorIndex = 1;//red
  28. btr.AppendEntity(sld);
  29. trans.AddNewlyCreatedDBObject(sld, true);
  30. Solid3d sldClone = sld.Clone() as Solid3d;
  31. sldClone.ColorIndex = 3;//green
  32. sldClone.TransformBy(Tm);
  33. btr.AppendEntity(sldClone);
  34. trans.AddNewlyCreatedDBObject(sldClone, true);
  35. trans.Commit();
  36. }
  37. }

希望对大家能有所帮助。
详细的原理讲解可以看我的博客,链接为:http://379910987.blog.163.com/blog/static/33523797201011306586296/

评分

参与人数 1明经币 +1 金钱 +6 收起 理由
雪山飞狐_lzh + 1 + 6 原创内容

查看全部评分

发表于 2010-12-30 20:35:00 | 显示全部楼层
还有简单的方法,:)
Matrix3d mat = Matrix3d.Mirroring(plane);
发表于 2011-1-1 15:01:18 | 显示全部楼层
谢谢分享,学习了,
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 22:34 , Processed in 0.168520 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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