找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2242|回复: 2

[分享] 对任意平面的镜像

[复制链接]

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-12-21 16:43:36 | 显示全部楼层 |阅读模式

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

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

×
http://379910987.blog.163.com/blog/static/33523797201011306586296/?suggestedreading&wumii
对任意平面的镜像  


数学基础
如果向量n为平面P的单位法向量,即有:
0.jpg
1.jpg
则实体关于该平面的变换矩阵为:
2.jpg

AutoCAD环境下的实现
下面是测试代码,我们用三个点构建一个平面,平面的Normal返回一个Vector3d对象,该对象是该平面的单位法向量。
using System;
using Autodesk.AutoCAD.Runtime;
using Autodesk.AutoCAD.Geometry;
using Autodesk.AutoCAD.ApplicationServices;
using Autodesk.AutoCAD.DatabaseServices;
using Autodesk.AutoCAD.EditorInput;
namespace CADTest
{
    public class Class1
    {
        #region实体镜像
        [CommandMethod("MP")]//Mirror Entity
        public void MirrorEntity()
        {
Database db = Application.DocumentManager.MdiActiveDocument.Database;
Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
            //对称平面
Plane mp = new Plane(new Point3d(1, 0, 0), new Point3d(0, 1, 0), new Point3d(0, 0, 1));
            double x = mp.Normal.X;
            double y = mp.Normal.Y;
double z = mp.Normal.Z;
double[] dm = new double[16];
            dm[0] = 1 - 2 * x * x;
dm[5] = 1 - 2 * y * y;
            dm[10] = 1 - 2 * z * z;
            dm[15]=1;
            dm[1] = dm[4] = -2*x * y;
            dm[2] = dm[8] = -2*x * z;
            dm[6] = dm[9] = -2*y * z;
Matrix3d Tm = new Matrix3d(dm);
using (Transaction trans = db.TransactionManager.StartTransaction())
            {
BlockTable bt = (BlockTable)trans.GetObject(db.BlockTableId, OpenMode.ForRead);
BlockTableRecord btr = (BlockTableRecord)trans.GetObject(db.CurrentSpaceId, OpenMode.ForWrite);
Solid3d sld = new Solid3d();
                sld.SetDatabaseDefaults();
                sld.CreateBox(100, 150, 200);
                sld.ColorIndex = 1;//red
                btr.AppendEntity(sld);
                trans.AddNewlyCreatedDBObject(sld, true);
Solid3d sldClone = sld.Clone() as Solid3d;
                sldClone.ColorIndex = 3;//green
                sldClone.TransformBy(Tm);
                btr.AppendEntity(sldClone);
                trans.AddNewlyCreatedDBObject(sldClone, true);
                trans.Commit();
            }
        }
        #endregion
    }
}

评分

参与人数 1D豆 +3 收起 理由
ScmTools + 3 出题引导交流奖!

查看全部评分

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

已领礼包: 1632个

财富等级: 堆金积玉

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

使用道具 举报

已领礼包: 859个

财富等级: 财运亨通

发表于 2014-5-5 21:15:20 来自手机 | 显示全部楼层
Mark
1 new plan (p1,p2,p3)
2 new Matrix3d (new Double[16])
3 clone transformby
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-28 00:48 , Processed in 0.294459 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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