EndTangent 属性 (ActiveX)
将样条曲线的端切指定为方向向量。 支持的平台:仅限 Windows 属性值只读:不 类型:变体(双打的三元素阵列) 表示样条曲线的端切的定向向量。 言论当样条曲线被抬高时,该样条曲线将从插值(拟合)样条转换为控制点样条曲线。这意味着在高程之后,样条不再具有拟合切线,并且样条的 和 属性不再可用。编辑控制点样条曲线的唯一方法是通过属性或 or 方法。StartTangentEndTangentControlPointsSetControlPointGetControlPoint 例子VBA: Sub Example_EndTangent()
' This example creates a spline. It then queries the current setting for
' the EndTangent, and then changes the EndTangent to a new value.
' Create the spline
Dim splineObj As AcadSpline
Dim startTan(0 To 2) As Double
Dim endTan(0 To 2) As Double
Dim fitPoints(0 To 8) As Double
Dim msg As String
startTan(0) = 0.5: startTan(1) = 0.5: startTan(2) = 0
endTan(0) = 0.5: endTan(1) = 0.5: endTan(2) = 0
fitPoints(0) = 1: fitPoints(1) = 1: fitPoints(2) = 0
fitPoints(3) = 5: fitPoints(4) = 5: fitPoints(5) = 0
fitPoints(6) = 10: fitPoints(7) = 0: fitPoints(8) = 0
Set splineObj = ThisDrawing.ModelSpace.AddSpline(fitPoints, startTan, endTan)
ZoomAll
GoSub GETPOINTS
MsgBox "The EndTangent for the spline is " & msg, vbInformation, "EndTangent Example"
' Change the end tangent of Spline to (1.5,0.707,2)
Dim newTan(0 To 2) As Double
newTan(0) = 1.5: newTan(1) = 0.707: newTan(2) = 2
splineObj.EndTangent = newTan
ThisDrawing.Regen True
GoSub GETPOINTS
MsgBox "The EndTangent has been changed to " & msg, vbInformation, "EndTangent Example"
Exit Sub
GETPOINTS:
msg = ""
' Get the coordinates from the end tangent
Dim count As Integer
For count = 0 To 2
msg = msg & Format(splineObj.EndTangent(count), "0.###") & ", "
Next
msg = VBA.Left(msg, Len(msg) - 2)
Return
End Sub
可视化 LISP: (vl-load-com)
(defun c:Example_EndTangent()
;; This example creates a spline. It then queries the current setting for
;; the EndTangent, and then changes the EndTangent to a new value.
(setq acadObj (vlax-get-acad-object))
(setq doc (vla-get-ActiveDocument acadObj))
;; Create the spline
(setq startTan (vlax-3d-point 0.5 0.5 0)
endTan (vlax-3d-point 0.5 0.5 0)
fitPoints (vlax-make-safearray vlax-vbDouble '(0 . 8)))
(vlax-safearray-fill fitPoints '(1 1 0
5 5 0
10 0 0
)
)
;; Create the spline
(setq modelSpace (vla-get-ModelSpace doc))
(setq splineObj (vla-AddSpline modelSpace fitPoints startTan endTan))
(vla-ZoomAll acadObj)
(setq msg "")
;; Get the coordinates from the end tangent
(setq endTangent (vlax-safearray->list (vlax-variant-value (vla-get-EndTangent splineObj))))
(setq msg (strcat msg (rtos (nth 0 endTangent) 2 3) ","
(rtos (nth 1 endTangent) 2 3) ","
(rtos (nth 2 endTangent) 2 3)))
(alert (strcat "The EndTangent for the spline is " msg))
;; Change the end tangent of Spline to (1.5,0.707,2)
(setq newTan (vlax-3d-point 1.5 0.707 2))
(vla-put-EndTangent splineObj newTan)
(vla-Regen doc :vlax-true)
(setq msg "")
(setq endTangent (vlax-safearray->list (vlax-variant-value (vla-get-EndTangent splineObj))))
(setq msg (strcat msg (rtos (nth 0 endTangent) 2 3) ","
(rtos (nth 1 endTangent) 2 3) ","
(rtos (nth 2 endTangent) 2 3)))
(alert (strcat "The EndTangent has been changed to " msg))
)
|
|Archiver|CAD开发者社区
( 苏ICP备2022047690号-1 苏公网安备32011402011833)
GMT+8, 2025-11-1 10:06
Powered by Discuz! X3.4
Copyright © 2001-2021, Tencent Cloud.