AnimationTrack.Looped Does Not Replicate

The AnimationTrack.Looped property does not replicate across the client/server boundary.

Changing the looped property on the server, does not replicate the property to the clients. I discovered this when trying to set the looped property on an animation track on an NPC via a server side script. Changing the property only affects the looping behavior on the server.

66 Likes

Yes, this is a known problem and we currently have a ticket tracking it. Hopefully we will get to it soon.

26 Likes

This issue is still a thing and it’s currently very frustrating to make a somewhat hacky solution. Do you guys have a possible ETA on when this issue will be resolved?

9 Likes

@UP, It’s very upsetting. Will we ever get a fix?

6 Likes

This is STILL an issue, very frustrating.
There is a workaround though, make two identical animations, one with looped property in the Editor ticked. Is there any update on this?

[CC: @CodeWriter ]

AdjustSpeed also doesn’t work :broken_heart:

5 Likes

We use AnimationController and Looped does not replicate.

function module:playAnimation(Animation,fadeTime,weight,speed,loopAnimation)
    local fadeInTime = fadeTime or self.defaultFadeInTime
    local weight = weight or self.defaultWeight
    local speed = speed or self.defaultSpeed
    local loopAnimation = loopAnimation or true
    local AnimationTrack = self.Animations[Animation] or error("playAnimation Error. Could not find 
    loaded animation: " .. Animation)
    self.Animations[Animation].Looped = true
    AnimationTrack:Play(fadeInTime,weight,speed)
    table.insert(self.activeAnimations,Animation)
end

Unfortunately it looks like this is still a problem, as the Looped does not replicate.

2 Likes

Animation.Looped still doesn’t replicate in June 2020, this bug causes a massive barrier and annoyance for developers of games with many animations (like my own) as each animation has to be uploaded 2 different times (looped + non-looped) to achieve the behavior that should be provided by the .Looped property. Be sure to let us know if you have any updates on this as it’s still ongoing and not fun to work around.

11 Likes

Another vouch for this problem. It has caused me a lot of confusion. While the animation has stopped on the server sided, the client is still running it. The file attached is the one used to create the gif.

AnimationTrackReplication.rbxl (28.2 KB)

4 Likes

I just spent two hours wondering why my NPC animations were looping but not showing up for the client. The Looped event kept firing which made the problem very confusing. Thank goodness I found this bug report. Please fix this soon; it would make animation code much more intuitive!

9 Likes

This was reported in 2 years ago? Sorry but will this be fixed in anytime soon? The animation still loops after I set it to false by script, and when I call :Stop() on a LoadAnimation after it’s first loop, it won’t stop.

1 Like

I’m at the point where I’m going to have to rethink a certain aspect of gameplay because of this issue.
I get so far as seeing the animations playing for the clients and the server but at some unspecified point in time, the animations will not be seen by the other player or the server, while the client continues to see their animation. I’ve literally battled with this for weeks now :frowning:

3 Likes

Same problem for me as well. I’m surprised this hasn’t been fixed for this long.

2 Likes

This issue is happening to my game as well. Animation is played on the server side and the play properly replicates to the clients, however when I try to stop it from the server side, it only stops on the server and it does not stop on the clients. This was acknowledged as a “known problem” with a “ticket tracking it” over 2 years ago. Where is that ticket now? What is the status on this issue?

2 Likes

This is still an issue today, two years and three months on - there is a work around where you modify it directly in the animation editor but this is a big pain for games where .Looped may be variable (change) - forcing convoluted code.

We were recently trying the fix this issue by running animations on the server instead of the client (assuming this was the issue) but even there it only works server side. Is there any ETA for this engine bug?

2 Likes

This bug still occurs in January of 2021. It’s been 2 years and it still hasn’t been fixed.

A fix I’ve found is to artificially loop the animations once you’ve detected that their duration has expired.

Hoping Roblox is actually intending to fix this issue.

4 Likes

Ridiculous, 2 years and have they’ve even mentioned this?

2 Likes

Yep-still a bug. If Roblox is going to replicate the client’s animations, then replicate everything, including the Looped setting.

1 Like

just a daily reminder that the looped property still doesnt replicate, and it needs to so i dont have to waste hours trying to figure out why the server makes it loop and not the client

2 Likes

Still an issue. Please fix this.

1 Like

The issue is still prevelant, it’s not a huge deal since you can reupload the animations but it’s still a minor inconvience that should be fixed.

Also another interesting occurance is that if you change the animation properties on the server and you tell it to stop, it doesn’t stop previously looped animations changed to non-loop animations.

Code used for the playing NPC animations:

local DanceAnimation = NPC:FindFirstChild("Humanoid"):LoadAnimation(script:FindFirstChild("DanceAnimation"..math.random(1, 5)))
DanceAnimation.Looped = false
DanceAnimation.Priority = Enum.AnimationPriority.Movement
DanceAnimation:Play(nil, nil, 1+(math.random(-1000, 1000)/7500))
local AnimationStopConnection
local function OnAnimationStop()
	AnimationStopConnection:Disconnect()
	if InitalSpawnAttackers == false and NPC:FindFirstChild("Humanoid") and NPC:FindFirstChild("Humanoid").Health > 0 then
		local CurrentPos = table.find(UsedAnimations, DanceAnimation)
		if DanceAnimation then DanceAnimation:Stop() end
		if CurrentPos then
			table.remove(UsedAnimations, CurrentPos)
		end
		DanceAnimation = NPC:FindFirstChild("Humanoid"):LoadAnimation(script:FindFirstChild("DanceAnimation"..math.random(1, 5)))
		DanceAnimation.Looped = false
		DanceAnimation.Priority = Enum.AnimationPriority.Movement
		DanceAnimation:Play(nil, nil, 1+(math.random(-1000, 1000)/7500))
		AnimationStopConnection = DanceAnimation.Stopped:Connect(OnAnimationStop)
		table.insert(UsedAnimations, #UsedAnimations+1, DanceAnimation)
	end
end
AnimationStopConnection = DanceAnimation.Stopped:Connect(OnAnimationStop)
table.insert(UsedAnimations, #UsedAnimations+1, DanceAnimation)
4 Likes