几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量  


返回   几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 » 仿射空间:CAX软件开发(三)二次开发与程序设计 » CAD二次开发 » AutoCAD二次开发 » DirectDWG
用户名
密码
注册 帮助 会员 日历 银行 搜索 今日新帖 标记论坛为已读


回复
 
主题工具 搜索本主题 显示模式
旧 2009-05-06, 08:36 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】odgematrix3d internals

odgematrix3d internals
odgematrix3d internals
hi everyone,
i have a very simple question, i have a drawing that when using the matrix i derive from opendwg and use the odgematrix3d to transform the points manually, all works great, however i actually need to perform the calculation outside of the odgematrx3d. now the problem is i use the same values from your matrix in my own matrix and the paper space projections are sometimes incorrect ( usually it is in the case of a very perspective projection). could someone be kind enough to tell me what matrix calcs i must perform to get the same result. basically my matrix calc is a very simple matrix and operates as follows :
real newx = m_xyz[x] * mtrx(0,0) + m_xyz[y] * mtrx(1,0) + m_xyz[z] * mtrx(2,0) + mtrx(3,0);
real newy = m_xyz[x] * mtrx(0,1) + m_xyz[y] * mtrx(1,1) + m_xyz[z] * mtrx(2,1) + mtrx(3,1);
real newz = m_xyz[x] * mtrx(0,2) + m_xyz[y] * mtrx(1,2) + m_xyz[z] * mtrx(2,2) + mtrx(3,2);
real neww = m_xyz[x] * mtrx(0,3) + m_xyz[y] * mtrx(1,3) + m_xyz[z] * mtrx(2,3) + mtrx(3,3);
but i am guessing that you do something extra, as the results in these particular cases is very close, just not close enough?
thanx to whoever helps in advance
jason

code:
ge_toolkit_export odgepoint3d operator*(const odgematrix3d& mat, const odgepoint3d& pt)
{
double diver = mat[3][0] * pt.x + mat[3][1] * pt.y + mat[3][2] * pt.z + mat[3][3];
odgepoint3d res(
(mat[0][0] * pt.x + mat[0][1] * pt.y + mat[0][2] * pt.z + mat[0][3])/diver,
(mat[1][0] * pt.x + mat[1][1] * pt.y + mat[1][2] * pt.z + mat[1][3])/diver,
(mat[2][0] * pt.x + mat[2][1] * pt.y + mat[2][2] * pt.z + mat[2][3])/diver
);
return res;
}
sincerely yours,
george udov
thank you very much, just need to apply the division
cheers
jason
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


主题工具 搜索本主题
搜索本主题:

高级搜索
显示模式

发帖规则
不可以发表新主题
不可以回复主题
不可以上传附件
不可以编辑您的帖子

vB 代码开启
[IMG]代码开启
HTML代码关闭



所有的时间均为北京时间。 现在的时间是 07:25 AM.


于2004年创办,几何尺寸与公差论坛"致力于产品几何量公差标准GD&T | GPS研究/CAD设计/CAM加工/CMM测量"。免责声明:论坛严禁发布色情反动言论及有关违反国家法律法规内容!情节严重者提供其IP,并配合相关部门进行严厉查处,若內容有涉及侵权,请立即联系我们QQ:44671734。注:此论坛须管理员验证方可发帖。
沪ICP备06057009号-2
更多