几何尺寸与公差论坛------致力于产品几何量公差标准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:12 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】oddbspatialfilterboundary

oddbspatialfilter::boundary
oddbspatialfilter::boundary
i tried to read spatial filters from a dwg file.
(i use dd 1.13.02.)
here a drawing with two xclip blocks.
it copied and was made two.
oddbspatialfilterptr pfilt = oddbindexfiltermanager::getfilter( pblk, oddbspatialfilter::desc(), oddb::kforread );
odgepoint2darray points;
pfilt->boundary( points );
it becomes the value with two same.
points = (55, 55), (145,145)
the value of the 2nd block is different.
please teach me how to calculate.
attached files
hi,
here is how to calculate boundary in wcs:
oddbspatialfilterptr pfilt = oddbindexfiltermanager::getfilter( pblk, oddbspatialfilter::desc(), oddb::kforread );
odgiclipboundary def;
pfilt->getdefinition(def);
oduint32 i;
odgematrix3d toworld = pblk->blocktransform() * def.m_xinverseblockrefxform * def.m_xtoclipspace.inverse();
odgepoint3darray boundary;
if(def.m_points.size() > 2)
{
// polygonal border
boundary.resize(def.m_points.size()+1);
for(i = 0; i < def.m_points.size(); i ++)
{
boundary[i].x = def.m_points[i].x;
boundary[i].y = def.m_points[i].y;
boundary[i].z = 0.0;
boundary[i].transformby(toworld);
}
boundary[i].x = def.m_points[0].x;
boundary[i].y = def.m_points[0].y;
boundary[i].z = 0.0;
boundary[i].transformby(toworld);
}
else
{
// rectangular border
boundary.resize(5);
boundary[0].x = def.m_points[0].x;
boundary[0].y = def.m_points[0].y;
boundary[1].x = def.m_points[0].x;
boundary[1].y = def.m_points[1].y;
boundary[2].x = def.m_points[1].x;
boundary[2].y = def.m_points[1].y;
boundary[3].x = def.m_points[1].x;
boundary[3].y = def.m_points[0].y;
boundary[4].x = def.m_points[0].x;
boundary[4].y = def.m_points[0].y;
for(i = 0; i < 5; i ++)
{
boundary[i].z = 0.0;
boundary[i].transformby(toworld);
}
}
last edited by dmitry a. novikov; 16th september 2005 at 05:54 amfff">.
thank you for reply.
simple dwg(base.dwg) is ok.
but it shifts, when this drawing(026.dwg).
in for example, the case of the 1st point
before transform : 12710.29, -33954.25
after transform : 1673419.98, 474983.33
both have shifted.
please teach me how to calculate.
attached files (85.3 kb, 8 views)

hi,
i forgot to take block record's origin into account.
oddbspatialfilterptr pfilt = oddbindexfiltermanager::getfilter( pblk, oddbspatialfilter::desc(), oddb::kforread );
odgiclipboundary def;
pfilt->getdefinition(def);
oduint32 i;
oddbblocktablerecordptr pblockrecord = pblk->blocktablerecord().safeopenobject();
odgematrix3d toworld = pblk->blocktransform() *
odgematrix3d::translation(odgepoint3d::korigin - pblockrecord->origin()) *
def.m_xinverseblockrefxform * def.m_xtoclipspace.inverse();
...
great!
calculably.
it succeeded in the clipping of the block.
thank you very much.
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



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


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