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

solid hatch tesselation generated 1 million triangles
solid hatch tesselation generated 1 million triangles
i got a strange problem: a small dwg generated over a million triangles during rendering. reason: there was a hatches with solid fill that had a high res curve outline. this hatch was tesselated into a million very narrow triangles.
the one parameter i found that could influence this was the kodgimaxdevforcurve in the myview::deviation call. for this particular drawing the odgsbasevectorizeview::deviation() will return "2.5e-005". this was definitively not appropriate for this drawing. setting it to 1.0 yielded acceptable resolution and number of triangles.
how is default for deviation kodgimaxdevforcurve calulated?
lets say i know the minimum length "l" of any curve segment in wcs. and i am rendering *model_space. what would be the formula for calculating an appropriate myview::deviation for kodgimaxdevforcurve?
-rune jorgensen
hi,
deviation is maximum distance between segment (l) inscribed into curve and appropriate chord.
could you elaborate a bit? from the manual:
"with respect to the current active viewport"
i am rendering *model_space and the model "viewport" is active, not any layouts. the projection is a standard "top" projection. the view center according to autocad is [14950.9 -11929.2] and width/height [129493.0 81547.7].
what formula do the toolkit odgsbasevectorizeview::deviation() apply that makes it end up with a kodgimaxdevforcurve of "2.5e-005" in this situation? what logic is used to determine a reasonable deviation?
-rune jorgensen

code:
double odgsbasevectorizeview::calcdeviation(const odgideviationtype , const odgepoint3d& pt) const
{
...
odgepoint2d pixelsperunit;
getnumpixelsinunitsquare(pt, pixelsperunit);
pixelsperunit.x = fabs(pixelsperunit.x);
pixelsperunit.y = fabs(pixelsperunit.y);
double deviation = (0.5 / odmax(pixelsperunit.x, pixelsperunit.y));
...
}
in other words it's half of pixel in world units.
pixel resolution is set by odgsdevice:nsize().

there we go! thats what i was looking for.
thanks!
-rune jorgensen
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
 


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

高级搜索
显示模式

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

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

相似的主题
主题 主题发起者 论坛 回复 最后发表
【转帖】one color gradient hatch yang686526 DirectDWG 0 2009-05-06 09:22 PM
【转帖】hatching entities yang686526 DirectDWG 0 2009-05-05 12:01 PM
【转帖】hatch problem yang686526 DirectDWG 0 2009-05-05 11:56 AM
【转帖】color problem with hatch while vectorization yang686526 DirectDWG 0 2009-05-04 05:55 PM
【转帖】a hatch problem yang686526 DirectDWG 0 2009-05-04 03:07 PM


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


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