if humanoid then -- Apply upward velocity to the HumanoidRootPart local rootPart = character:FindFirstChild("HumanoidRootPart") if rootPart then rootPart.Velocity = Vector3.new(rootPart.Velocity.X, upwardVelocity, rootPart.Velocity.Z) end end end
lifterPart.Touched:Connect(onTouch)
liferPart:SetNetworkOwner(nil) — but this can cause lag. Usually, velocity changes are sufficient for short lifts. -- PLACE INSIDE LIFTER PART (Server Script) local LIFTER = script.Parent local LIFT_FORCE = 60 local CHECK_INTERVAL = 0.1 FE Player Lifter Script
local function applySmoothLift(character) local rootPart = character:FindFirstChild("HumanoidRootPart") if not rootPart then return end local bodyVel = Instance.new("BodyVelocity") bodyVel.Velocity = Vector3.new(0, 50, 0) bodyVel.MaxForce = Vector3.new(0, math.huge, 0) bodyVel.Parent = rootPart
local function onTouch(otherPart) local character = otherPart.Parent local humanoid = character:FindFirstChild("Humanoid") if humanoid and not activeCharacters[character] then activeCharacters[character] = true liftCharacter(character) end end if humanoid then -- Apply upward velocity to
LIFTER.Touched:Connect(function(hit) local char = hit.Parent if isCharacterValid(char) and not active[char] then active[char] = true lift(char) end end)
local active = {}
-- Apply velocity repeatedly while character remains on lifter while activeCharacters[character] do rootPart.Velocity = Vector3.new(rootPart.Velocity.X, upwardVelocity, rootPart.Velocity.Z) task.wait(0.1) -- Adjust for smoothness end end