EdgeUse 和 Edge的Evaluator 区别

我的同事Adam最近写了篇关于EdgeUse 和 Edge的Evaluator 的区别。EdgeUse 和 Edge是初学Inventor  Brep容易混淆和迷惑的知识。我认为Adam的这篇文章有一定帮助。特翻译如下。原文地址:

http://adndevblog.typepad.com/manufacturing/2013/03/evaluator-of-edgeuse-vs-edge.html

EdgeUse 提供了基于边Edge所在面Face上下文的信息。所以其Evaluator是Curve2dEvaluator ,返回的是基于面Face的信息,即返回的坐标信息是在面的参数空间内Face (u, v).  如果需要在模型空间上下文的坐标信息,则需要用FaceEvaluator 把u,v转换成模型坐标(x, y, z) 。

Edge是基于模型空间,其Evaluator 也是Curve2dEvaluator,但返回的是模型空间坐标。 

下图是个图例说明。实际中,可能0点的u,v不在面或边的起点。你需要用相应的方法先获取最小和最大值做判断。 

EdgeUse

以下代码演示了EdgeUse的Evaluator的 坐标,面Face的 u,v坐标,以及模型空间坐标。先选取一个面,执行代码:

Sub PlaceParametricPoints()
    Dim oDoc As PartDocument
    Set oDoc = ThisApplication.ActiveDocument

    Dim oFace As Face
    Set oFace = oDoc.SelectSet(1)
    
    Dim oCompDef As PartComponentDefinition
    Set oCompDef = oDoc.ComponentDefinition
    
    Dim oWPs As WorkPoints
    Set oWPs = oCompDef.WorkPoints
    
    Dim oEdgeLoop As EdgeLoop
    For Each oEdgeLoop In oFace.EdgeLoops
        Dim oEdgeUse As EdgeUse
        For Each oEdgeUse In oEdgeLoop.EdgeUses
            Dim oEval As Curve2dEvaluator
            Set oEval = oEdgeUse.Evaluator
            
            ' 获取曲线参数范围 
            Dim oMinU As Double
            Dim oMaxU As Double
            Call oEval.GetParamExtents(oMinU, oMaxU)
            
            ' 获取面上参数化点
            Dim oParams(1) As Double
            Dim oFaceUV() As Double
            oParams(0) = oMinU
            oParams(1) = oMaxU
            Call oEval.GetPointAtParam(oParams, oFaceUV)
            
            ' 计算出对应模型空间点 
            Dim oModel() As Double
            Call oFace.Evaluator.GetPointAtParam(oFaceUV, oModel)
            
            Dim oTG As TransientGeometry
            Set oTG = ThisApplication.TransientGeometry
            
           ‘利用模型空间点增加一个工作点
            Call oWPs.AddFixed(oTG.CreatePoint( _
                oModel(0), oModel(1), oModel(2)))
            
            Debug.Print _
                "> Min Point >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>" + vbCrLf + _
                " Edge  u = " + str(oMinU) + vbCrLf + _
                " Face  u = " + str(oFaceUV(0)) + _
                ", v = " + str(oFaceUV(1)) + vbCrLf + _
                " Model x = " + str(oModel(0)) + _
                ", y = " + str(oModel(1)) + _
                ", z = " + str(oModel(2)) + vbCrLf + _
                "> Max Point >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>" + vbCrLf + _
                " Edge  u  = " + str(oMaxU) + vbCrLf + _
                " Face  u  = " + str(oFaceUV(2)) + _
                ", v = " + str(oFaceUV(3)) + vbCrLf + _
                " Model x = " + str(oModel(3)) + _
                ", y = " + str(oModel(4)) + _
                ", z = " + str(oModel(5))
        Next
    Next
End Sub



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值