Class.Path2D 實個體、實例,包括其 API 方法和屬性,讓您實現 2D 曲線和 2D 彎曲線,有助於路徑基礎動畫和圖形編輯器的 UI 效果。
建立 2D 道路徑
要將 Path2D 添加到屏幕或體驗中的對物件:
在 Explorer 窗口中,在可見的 Class.ScreenGui 或 Class.SurfaceGui 下插入一個 1>Class.Path2D1> 實例。
選擇新的 Path2D 以顯示視窗工具小工具。 預設值下,選擇 添加點 工具。
完成後,按下 widget 的 完成 按鈕或按下 按入 。
修改控制點
在 Path2D 階層中選擇了 Class.Path2D ,你可以修改其個別控制點以及其 tangents。
移動點
要在路徑上移動控制點,啟用 選取 工具 ( V ) 然後按一下並拖曳它到新位置。
data:image/s3,"s3://crabby-images/ae0f3/ae0f3bf293b73f4a8df4462b926f374b505f5860" alt="Select tool indicated in the 2D path editor widget."
data:image/s3,"s3://crabby-images/c5b5d/c5b5d57c26545e02eba78f980301b202522dd35e" alt="Diagram illustrating how a path control point is moved to a new position by clicking and dragging with the Select tool enabled."
對於非常具體的位置,選擇控制點,然後,在 屬性 窗口中,為點的 SelectedControlPointData 屬性設置新位置 ( UDim2 )。
data:image/s3,"s3://crabby-images/bc791/bc791f534703ff9e2bec3fbb4fab5ba32a086d03" alt="SelectedControlPointData property of a Path2D instance indicated in the Properties window."
注意點的位置不是絕對,而是相對於路徑的父容器。例如,比較控制點 30% 從左邊和 20% 從頂部為路徑內的一個路徑,而不是放置在 ScreenGui 內的相同路徑。當放置在 Class.Frame
data:image/s3,"s3://crabby-images/ca842/ca8420325e89f2508b77dbce761fd75f23db8687" alt="Diagram illustrating how the positions of path control points are relative to their parent container."
增加點數
新控制點可以在兩個現有點之間或從使用 Path2D 工具 ( P ) 的任意一端點上添加新控制點。
data:image/s3,"s3://crabby-images/249a0/249a087a295f485194a8548e0bc841446e2bfe1d" alt="Add Point tool indicated in the 2D path editor widget."
data:image/s3,"s3://crabby-images/74a55/74a55a0007c7ab3e94a399e38fecf5aaa02e1f01" alt="Diagram illustrating how a control point is added between two existing points using the Add Point tool."
data:image/s3,"s3://crabby-images/d3644/d364433bfb82b8f88d220297dcee4444feabe114" alt="Diagram illustrating how a control point is added to the end of a path using the Add Point tool."
刪除點
要刪除控制點,請將鼠標指针移動至控制點右邊,然後從上下文提示菜單中選擇 刪除點 。
data:image/s3,"s3://crabby-images/bc212/bc2126c5d034cf6a8408d7f258809bf27c278a1c" alt="Diagram illustrating how a path control point is deleted by right-clicking it and selecting Delete Point."
控制點軌道
控制點 棱角 讓您可以在路徑上創建並調整曲線。
data:image/s3,"s3://crabby-images/28f2c/28f2cdbdd94f282d3ec940caf0d4bf30fb13fcae" alt="Diagram illustrating a curved path with several tangent control points."
增加方向
要將軌道添加到任何尚未有軌道的控制點:
啟用 Add Tangent 工具在工具小工具中。
將鼠標擺置在所需控制點上,然後按一下以添加兩個 鏡像 切角 (可選) 。
調整方向角
要調整個別控制點的現有棱角:
啟用 選取工具 ( V 工具 ) 。
將鼠標揮動在控制點上,然後點擊並拖曳它到新位置。如果控制點是鏡像,則會移動雙方的控制點。
要手動設置特定 UDim2 位置以對齒輪:
啟用 選取 工具 ( V ) 並選擇控制點。在 屬性 窗口中,擴展 1> Class.Path2D.SelectedControlPointData|SelectedControlPointData1> 字段來顯示 4> Datatype.Path
設置位置為 LeftTangent 和/或 RightTangent 。注意這會導致鏡像行為的變更。
刪除接線
要從控制點移除兩個軸從,將鼠標移動至該點,然後右鍵點擊,然後從上下文菜單中選擇 清除軸 。
data:image/s3,"s3://crabby-images/1705f/1705f9be945946cdc7ca5d6c2d0a59029e23811e" alt="Diagram illustrating how both tangents of a control point are cleared by right-clicking it and selecting Clear Tangents."
要刪除只有一個角度 (左或右) ,將鼠標放在該角度的標記上,然後選擇 刪除角度 。
data:image/s3,"s3://crabby-images/11679/11679b7148aebda321da911cf1b7521bb66ea1d3" alt="Diagram illustrating how one tangent of a control point is deleted by right-clicking it and selecting Delete Tangent."
斷條和鏡像
由預設,讓齒輪鏡齒相互。當您拖曳以調整一個齒輪標記時,雙方的齒輪點將在協調中移動。
data:image/s3,"s3://crabby-images/472ac/472ac30d2da90d0064df4d6e1adc728b8121b69e" alt="Diagram illustrating how the tangents of a control point are adjusted with the Select tool enabled."
要將軸對稱分開,讓每個人都可以獨立於另一個人,將鼠標指针移動到與軸對稱的位置,然後從上下文菜單中選擇 軸對稱 。破損後,您可以移動每個軸標記,不會影響其他人。
data:image/s3,"s3://crabby-images/a7d7f/a7d7f63489d40acf0838dea060e914acd2285436" alt="Diagram illustrating how the tangents of a control point are broken by right-clicking it and selecting Break Tangents."
道路視覺特性
您可以使用以下屬性自訂 Path2D 的視覺外觀:
data:image/s3,"s3://crabby-images/42737/427372b080241f424435bb12b373be2c97ddc70b" alt="Diagram illustrating a path with Thickness of 2 and Color3 of (125, 125, 125)."
data:image/s3,"s3://crabby-images/03552/03552ec7bba1982451aa3e57e4d0b376e73d46ab" alt="Diagram illustrating a path with Thickness of 10 and Color3 of (225, 0, 50)."
data:image/s3,"s3://crabby-images/649e7/649e7d10d7692944e3a24ea52d9a5c2676b8ac7b" alt="Diagram illustrating a path layered in front of another using the ZIndex property."
路徑指令碼
腳本對於多個路徑相關工作流程有用。以下例子使用了方法 such as GetControlPoints() ,這會返回一個表 of Datatype.Path2DControlPoint|Path2D
在路徑上排列 UI 對象
local parent = script.Parent
local path = parent:FindFirstChildWhichIsA("Path2D")
local function arrangeChildren()
local segmentCount = #path:GetControlPoints()
local objectsToArrange = {}
for _, child in parent:GetChildren() do
if child:IsA("GuiObject") then
table.insert(objectsToArrange, child)
end
end
for idx, child in objectsToArrange do
local t = idx / (#objectsToArrange + 1)
child.Position = path:GetPositionOnCurveArcLength(t)
end
end
-- 初始設置子兒童 UI 對象在路徑上
arrangeChildren()
-- 聆聽孩子被添加/移除以調整配置
parent.ChildAdded:Connect(arrangeChildren)
parent.ChildRemoved:Connect(arrangeChildren)
以路徑上的動畫介面對象
local Tweenservice = game:GetService("TweenService")
local parent = script.Parent
local path = parent:FindFirstChildWhichIsA("Path2D")
local objectToAnimate = parent:FindFirstChildWhichIsA("GuiObject")
local TWEEN_DURATION = 4
local TWEEN_EASING_STYLE = Enum.EasingStyle.Cubic
local TWEEN_EASING_DIRECTION = Enum.EasingDirection.InOut
local pathSampleValue = Instance.new("NumberValue")
local tweenInfo = TweenInfo.new(TWEEN_DURATION, TWEEN_EASING_STYLE, TWEEN_EASING_DIRECTION, 0, true, 2)
local tween = Tweenservice:Create(pathSampleValue, tweenInfo, {Value = 1})
local function onSampleValueChanged()
objectToAnimate.Position = path:GetPositionOnCurveArcLength(pathSampleValue.Value)
end
pathSampleValue.Changed:Connect(onSampleValueChanged)
tween:Play()