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

odgenurbcurve3d::evalpoint for closed spline
odgenurbcurve3d::evalpoint for closed spline
hi,
i am using odgenurbcurve3d to get splinefitted and curvefitted points.. for a 2dpolyline.. i am creating odgenurbcurve3d by knots and control points..
code:
odgepoint3darray cntrlpoints;
oddbobjectiteratorptr pvertiter = ppoly->vertexiterator();
for (; !pvertiter->done(); pvertiter->step())
{
oddb2dvertexptr pvertex = pvertiter->entity( oddb::kforwrite);
cntrlpoints.push_back( pvertex->position());
}
odgedoublearray knots, weights;
if( bisclosed)//for closed 2dpolyline
{
knots.resize( nvertex);
for( int i = 0; i < nvertex; i++)
knots[i] = i;
}
else
{
knots.resize( nvertex + ndegree + 1);
for( int i = 0; i <= ndegree; i++)
knots[i] = 0;
for( i = ndegree+1; i <= nvertex; i++)
knots[i] = i - ndegree;
for( i = nvertex+1; i < nvertex + ndegree + 1; i++)
knots[i] = nvertex - ndegree;
nstartknotindex = ndegree;
}
odgeknotvector knotvector( knots);
weights.resize( nvertex, 1.0);
//now creating nurbcurve ......
odgenurbcurve3d gespline( ndegree, knotvector, cntrlpoints, weights, bisclosed);
// after spline is created... evalpoint() is called at some for tha parameters.....
odgepoint3d point = gespline.evalpoint( paramt);
......
...
now evalpoint() funtion is working fine for open gespline but when i am called it when bisclosed is true..(for closed polyline..) then it is throwing error as "not applicable
please help me... how do i get the correct spline fitted vertices for closed one... thank you alot.........
.................................................. .........................


please note these two facts:
1) the number of knots, control points and degree of nurbs curve must be under the following formula:
number of knots = number of control points + degree + 1;
2) the start parameter for nurbs curve is knots[degree]. the end parameter is knots[number of knots - degree - 1]. attempting to call evalpoint() with argument out of these bounds will cause enotapplicable exception.
hope this helps.
sincerely yours,
george udov
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
 


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

高级搜索
显示模式

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

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

相似的主题
主题 主题发起者 论坛 回复 最后发表
【转帖】a problem about spline yang686526 DirectDWG 0 2009-05-04 03:11 PM
【转帖】求助如何将pline变成spline yang686526 数据库ObjectDBX 0 2009-04-28 03:03 PM
【转帖】export xy coordinates from points in between spline points yang686526 SolidWorks二次开发 0 2009-04-13 10:48 AM


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


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