Archive 19/01/2023.

Execute code over time? Camera shake example

burt

I’m trying to apply an effect on my camera over time. In Unity, coroutines are often used for this. How would one do this in Urho?

Sinoid

@Urho3D @weitjong can we get a sticky for script requests and github-gists for pot-shots like this?


@burt you can do this with a script attached to the node you want to manipulate. They get a FixedUpdate call and you can interpolate during that.

Do you need an example? In Lua or Angelscript?

weitjong

I believe any of the moderators in the forum have the privilege to do that. We have more moderators than admins. However, we have reached the quota and cannot include more. Let’s see how this thread goes first before making it sticky.

Modanung

What I’d do is subclass LogicComponent to create a custom camera component with support for shaking. The shaking itself could be handled during the Update of this component or as a ValueAnimation that the component adds to some offset child node.

Sinoid

Here’s an angelscript gist of the basic behviour:

I don’t really think that’s good enough to use out of the box. Requires some tuning and it’s really way too smooth - part of that is due to how I did the blending over time.

For serious use I’d fix the blending and enforce a minimum distance between the random shake vectors (I’d just dot-prod them and add a threshold variable).

Edit: I deliberately called this Shake and not CameraShake because with a couple of tweaks it should be able to take care of your recoil post as well.

Sinoid

@weitjong I agree after the fact, I’ll toss of up a ScriptLibrary repo with a dump of misc helper scripts.

burt

Thanks a lot for such a detailed and thoughtful response! :star_struck:

Is the interval based on the amount of internal engine “ticks”? Is it framerate independent?

Sinoid

The smoothing is framerate dependent, otherwise it’s all tied to time-deltas, so engine-ticks don’t really effect much.

The interval is a time-window, it’s basically the time between shakes. So a bunch of intervals means a lot of shakes, where as just a few intervals means very few.

For the duration of the interval the camera will interpolate towards the shake the target direction. A lot of control could be had on using some basic easing functions on the weight variable, such as a bounce-out easing to make it oscillate towards the end of each shake.

That’d be as easy as weight = MyEasingFunction(weight);

When the interval ends, if it’s not the end of the shake the next interval’s shake target direction will be determined. If the returnToRef switch is enabled then once out of intervals the camera will return to its original (parent relative) orientation. The parent-relative bit is important, as otherwise you’d have issues like a head/gun-holding-wrist pointing in bizarre locations if the whole orientation of the object changed.

Note: I fixed a null access in there (when removing self), the gist is updated for that.