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


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


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

hatch的面积?
www.dimcax.com
hatch的面积?
这个问题,一个办法就是用vba的hatch对象的area属性了,cad
等我来改写了
这个不行的,
admin 发表于
快点改吧,我等着!
我在试那个所谓的com,没学过搞不明白,怎么才能把.net的hatch对象变成autodesk.autocad.interop.common.acadhatch呢?ctype不行,给指点一下好不?
嘿嘿,原来是这样:
imports autodesk.autocad.interop.common
imports autodesk.autocad.interop
public class study01
private db as database = hostapplicationservices.workingdatabase
private ed as editor = autodesk.autocad.applicationservices.application.documentmanager.mdiactivedocument.editor
private tm as autodesk.autocad.databaseservices.transactionmanager = db.transactionmanager
<commandmethod("test", commandflags.modal)> _
public sub test_com()
dim myt as transaction = tm.starttransaction
try
dim resent as promptentityresult = ed.getentity(vbcrlf & "选择填充")
if resent.status = promptstatus.ok then
dim ohatch as hatch = ctype(tm.getobject(resent.objectid, databaseservices.openmode.forread), hatch)
dim oacadhatch as acadhatch
oacadhatch = ctype(ohatch.acadobject, acadhatch)
ed.writemessage(oacadhatch.area.tostring)
end if
catch ex as system.exception
ed.writemessage(ex.message)
finally
myt.dispose()
end try
end sub
end class
复制代码
下面的代码证明,.net里的hatch.geometricextents得到的填充对象的外框是不正确的,它会把坐标原点放进去,而com的acadhatch.getboundingbox却不会。看来autocad的这个.net包装还很需要改进。
<commandmethod("test", commandflags.modal)> _
public sub test_hatch_extents()
dim myt as transaction = tm.starttransaction
try
dim resent as promptentityresult = ed.getentity(vbcrlf & "选择填充")
if resent.status = promptstatus.ok then
dim ohatch as hatch = ctype(tm.getobject(resent.objectid, databaseservices.openmode.forread), hatch)
dim oextents as extents3d = ohatch.geometricextents()
ed.writemessage(vbcrlf & oextents.tostring) '
dim oacadhatch as acadhatch = ctype(ohatch.acadobject, acadhatch)
dim omin as object = nothing, omax as object = nothing
oacadhatch.getboundingbox(omin, omax)
dim amin as array = ctype(omin, system.array)
ed.writemessage(vbcrlf & amin.getvalue(0).tostring & "," & amin.getvalue(1).tostring)
end if
catch ex as system.exception
ed.writemessage(ex.message)
finally
myt.dispose()
end try
end sub
复制代码
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


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

高级搜索
显示模式

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

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



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


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