Download

(39) Rama's Extra Blueprint Nodes for You as a Plugin, No C++ Required!

Dear Community,

MIT Software License for The Victory Plugin ~ License

I’ve decided to create my own **C++ Blueprint Function Library **of any functions that I’ve written that think you will find useful!

A Blueprint Function Library is a set of blueprint nodes that you can access from any blueprint, any time!

These are functions you can call from AnimBlueprints, Character blueprints, level blueprints, anywhere!

Because this is a plugin, you dont have to do any code compiling and can use my BP nodes in a content-only project!


**Download Links**

**4.25 ****(win32, win64, editor, dev packaged, and shipping)**
http://www.mediafire.com/file/0q10k9k3lumkbsk/VictoryPlugin26.zip/file

♥ Please note I now use the UE4 Marketplace C++ Plugin Standard when packaging Victory plugin for you ♥

1. Win64 Development
2. Win64 Shipping **<~~~~~~ NEW!**
3. Win32 Development
4. Win32 Shipping

Please see my instructions for [Packaging UE4 Plugins With Your Game](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=476476&viewfull=1#post476476).

Prior Engine Versions

**4.11: **http://www.mediafire.com/download/jp…ryPlugin11.zip

**4.12: **http://www.mediafire.com/download/g4…ryPlugin12.zip

**4.13: **https://www.mediafire.com/?7kt9fepwa1pgs0y

**4.14: ** http://www.mediafire.com/file/7915cu…ryPlugin14.zip

**4.15: ** https://www.mediafire.com/?6nne04gd74emnzu

**4.16: ** http://www.mediafire.com/file/ieovbd…ryPlugin16.zip

4.17: https://www.mediafire.com/file/ocm8o…ryPlugin17.zip

4.18: http://www.mediafire.com/file/8slx62…ryPlugin18.zip

4/19: http://www.mediafire.com/file/org12p…ryPlugin19.zip

**4.20: **http://www.mediafire.com/file/advi8v…gin20.zip/file

4.21: https://www.mediafire.com/file/ryxdp…gin21.zip/file

**4.22: **https://www.mediafire.com/file/87hgn…in422.zip/file

4.23: https://www.mediafire.com/file/2jedu…gin23.zip/file

4.24: https://www.mediafire.com/file/rqg11…ory24.zip/file

4.25: https://www.mediafire.com/file/pgrps…gin25.zip/file

4.26: http://www.mediafire.com/file/0q10k9k3lumkbsk/VictoryPlugin26.zip/file



**Donations can be sent to me via:**
http://lightningfitness.org/donate/

♥

Rama

Github Repository

If you’d like to contribute code to my Victory Plugin you can do so here!

Github Link


**Download Link**

**Epic Wiki Link**
[https://wiki.unrealengine.com/Rama%2...lugin_Download](https://wiki.unrealengine.com/Rama%27s_Vertex_Snap_Editor_Plugin#Plugin_Download)

Just get the most recent version :)

[FONT=Comic Sans MS]Entire Source Code For You!

I am including the entire source code for the plugin and the actual nodes in the download!

:heart:

Rama


**Victory BP Library Copyright Permissions**


[QUOTE=DennisSoemers;206990]
Hey Rama, a quick question. Is the code included in the download completely free to use for any and all purposes? I don't believe it contains any document that describes permissions as to what it's allowed to be used for? And yes, I realize touching the code is not strictly necessary, but in some cases I would prefer to just use the C++ code directly instead of the blueprints.
[/QUOTE]


Yes the code is free to use anywhere you want!

**I only request that you mention me in the credits for your game in the way that feels most appropriate to you, thereby honoring my contributions.**

I prefer to be mentioned as simply "Rama"

:)

Rama

Video Installation Instructions

Video Guide to Installing Victory Plugin

By Sahkan

Here’s a guide to installing my Victory Plugin, thanks for making it Sahkan!

https://youtube.com/watch?v=lr87zPbki_4


Update:

**Blueprint Nodes Now Work in Shipping Builds**

Special thanks to Lion for sending me an updated version of my plugin code that works with shipping builds!

The vertex editor mode is still there, but the BP Nodes portion is a separate module now and will compile when my nodes are included in a packaged game.

thanks Lion!

[FONT=Comic Sans MS]Newest Nodes!

Get Controller ID ~ takes in player controller and gives the ULocalPlayer’s ControllerID

Get Player State PlayerID ~ returns the replicated unique PlayerID for the supplied Player Controller!

Get Current Operating System Time](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=65910&viewfull=1#post65910) ~ Retrieve your local current time, milliseconds, seconds, minutes, hours, day, month, year!

Get Time Since Previous Recorded Time](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=65910&viewfull=1#post65910) ~ Retrieve the difference in time since your chosen previous time! You can record down to the sub-millisecond level, and up to hours!

Get Difference Between Any Two Times ~ With this node you can compare any two times that you’ve recorded using my node above!

You can store as many moments in time as you want using my above node, the time is recorded as string that I can parse back into actual DateTime struct data!

**Get Supported Screen Resolutions for End User’s Current Display Adapter **
https://forums.unrealengine.com/show…ll=1#post26535

Get Current OS Platform (Win,Mac,Linux,PS4,XboxOne,Android,iOs,HTML5, etc)
https://forums.unrealengine.com/show…ll=1#post59742


**Video of my BP Rag Doll System With Follow Camera**

Included in these BP nodes is a set of nodes to enable you to activate/deactivate ragdoll any time you want, WITH a built-in follow camera during ragdoll!

**Here is a video of exactly what I am providing in these nodes, I used these nodes to make the video.**


https://www.youtube.com/watch?v=e-3irWhYzMU


Pictures

Here are some pics of a few of the nodes I am giving you below!

Get Recently Rendered / Not Rendered Actors
renderedactorshappy.jpg](filedata/fetch?id=1134322&d=1504063719)

Get Character Bone Current Locations
characterbonelocations.jpg](filedata/fetch?id=1134318&d=1504063727)

Trace for Closest Socket
picofclosestsocket.jpg](filedata/fetch?id=1134319&d=1504063724)

Victory Ragdoll System, Including Follow Camera
ragdollgraph.jpg](filedata/fetch?id=1134320&d=1504063713)

Trace Data With Skeletal Mesh
tracedata_from_mesh_and_getskelmesh.jpg](filedata/fetch?id=1134321&d=1504063721)

5 More Pictures, Enjoy!
https://forums.unrealengine.com/show…ll=1#post26153


**Installation**

1. put the .zip contents in a folder in your main directory where your .uproject is, called "Plugins" (name most be precise)

2. open editor and go to window->plugins

3. make sure my Victory Plugin is checked off as being active

4. restart editor

5. go to a blueprint, turn off context sensitive, look up "Victory" and you should see a lot of new blueprint nodes / functions!


https:\/\/d3ar1piqh1oeli.cloudfront.net\/0\/0b\/Victorybpplugin.jpg\/800px-Victorybpplugin.jpg


6. If you want to use the vertex snapping feature as well, please see installation instructions here:

[https://wiki.unrealengine.com/Rama%2...n#Installation](https://wiki.unrealengine.com/Rama%27s_Vertex_Snap_Editor_Plugin#Installation)

Current List of Functions (48 Nodes Total)

~~~ Recently Added ~~~

~~~ Frame Rate / Graphics Options ~~~

**Set Max Frame Rate

Set Frame Rate To Be Unbound!**

4 New Nodes

**Max of Float Array

Max of Int Array

Min of Float Array

Min of Int Array**

https://forums.unrealengine.com/show…ll=1#post77775


**Get Current Operating System Time**
[https://forums.unrealengine.com/show...ll=1#post65910](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=65910&viewfull=1#post65910)

**Get Time Since Previous Record Timed**
[https://forums.unrealengine.com/show...ll=1#post65910](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=65910&viewfull=1#post65910)

**Get Difference Between Any Two Recorded OS Times**
[https://forums.unrealengine.com/show...ll=1#post65920](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=65920&viewfull=1#post65920)


**Get Supported Screen Resolutions for End User's Current Display Adapter **
[https://forums.unrealengine.com/show...ll=1#post26535](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=26535&viewfull=1#post26535)

**Combine Strings ~ Combine two strings with optional separator and labels**
[https://forums.unrealengine.com/show...ll=1#post26535](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=26535&viewfull=1#post26535)

**Clone Static Mesh Actor (during game time) **
[https://forums.unrealengine.com/show...ll=1#post26262](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=26262&viewfull=1#post26262)

**Teleport Actor to Actor**
[https://forums.unrealengine.com/show...ll=1#post25769](https://forums.unrealengine.com/showthread.php?3851-(39)-Rama-s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=25769&viewfull=1#post25769)


**~~~ File IO ~~~**

~ **SaveStringTextToFile - Save human-readable text to a file of your choosing.**



**~~~ ViewPort & Mouse Cursor ~~~**

The Set/Get Mouse Position nodes work directly with the player's viewport, and do not require access to the HUD canvas.

**~ Set Mouse Position** - SET the mouse position to any values of your choosing!
**~ Get Mouse Position** - Get the current mouse position, will be consistent with results of SET Mouse Position

**~ Get Center Of Viewport** - Obtain the coordinates of the center of the viewport! Works in PIE as well as standalone game instances

~~~ Traces ~~~

TraceData - Calculates the Start and End for a new Trace for use with any trace node of your choosing!

**~ TraceData Get Trace Data From Character Socket ** - You pick the rotation, and only need to supply the actor (really a character, but casted internally for your convenience), and a socket name, and a trace length. Optionally you can draw the trace data as a thick 3D line so you can visualize what the actual trace will do

~ TraceData Get TraceData From Skeletal Mesh Socket - You pick the rotation, and only need to supply the Skeletal Mesh Component, a socket name, and a trace length. Optionally you can draw the trace data as a thick 3D line so you can visualize what the actual trace will do

~ **Trace For Character Mesh, Closest Bone ** Pass in just 3 simple variables, Trace Start, Trace End, and the Trace Owner. Get Back: Hit Location, Hit Normal, Name of Closest Bone to the impact, the location of that Bone, and the Actor/Character that was hit.

~ Trace For Character Mesh, Closest Socket: Pass in just 3 simple variables, Trace Start, Trace End, and the Trace Owner. Get Back: Hit Location, Hit Normal, Name of Closest Socket to the impact, the location of that Socket, and the Actor/Character that was hit.

~ **Get Character’s Mesh Component ** Retrieve the Mesh component of a character, IsValid let’s you know whether the return value is valid or not, so do a branch to check :slight_smile:

~ **Get Bone Locations ** Returns an array of all the bone locations on the Character. The Character’s Mesh component must be valid for this to work. Returns false if the operation could not occur.

~~~ Closest Point to Source Point Calculation ~~~

~ Closest Point to Source Point : Takes in an array of points and finds which one was closest to the source point. Returns: what the minimum distance was, as well as the vector that was closest to Source.

~~~ Rendering ~~~

~ Freeze Game Render

~ UnFreeze Game Render

**~ Game Window is the Foreground window in the OS: - works in PIE and Standalone game instances

You can combine the above to freeze the game render whenever the game window is not the foreground in the OS !

**~ Get Array of Currently Rendered Actors ** - Retrieve array for use with foreach loop, iterating over all currently rendered actors. You can choose what time interval is recent enough, I default to 0.01 seconds.

**~ Get Array of Currently NOT Rendered Actors Detailed Info and Pics) - Retrieve array for use with foreach loop, iterating over all currently NOT rendered actors. You can choose what time interval is recent enough, I default to 0.01 seconds.

~~~ Aim Offsets ~~~

~ Aim Offsets, For Use With Blend Spaces in probable range of -90,90 to 90,90

~ GetAimOffsets - Original Inspiration for this BP Library, This is a Blueprint version of the same core c++ code as Shootergame uses. With this function you can create a blendspace using 9 animations for the nine directions to create an equivalent of the UE3 Aim Node. You plug the results of this function straight into your Aim Blendspace. See Shootergame example for exact details.

~ GetAimOffsetsFromRotation - Instead of assuming you want to get the character’s aim based on the controller, you can use this version to supply the rotation in world space that you want the character to aim to.

~~~ 3D Drawing ~~~

~ Drawing 3D Lines of Chosen Thickness

~ Thick3DLineBetweenActors - Draw a 3D line of your chosen thickness and duration between two Actors! You can use the BP color pick to pick line color!

~ Thick3DLineFromCharacterSocket - Draw a 3D line of your chosen thickness and duration from a specified Character Mesh Socket to your chosen destination. You can use the BP color pick to pick line color!

~ Thick3DLineFromSocket - Same as above, but you can use any mesh of your choosing.

~~~ Misc ~~

**~ Get Object/Actor Name As String ** - Get the name of any actor, component, or anything at all, as a String.

Identify whether game logic is running in Editor,PIE,or Game World!

**~ Set Scene Component Mobility

Convenience
~ GetControllerRotation - Get the Character’s controller’s rotation, fast way to get PlayerController or AIController rotation!

Conversions

~ RotatorToVector
~ VectorToRotator

~~~ Misc 2: Colors and Math ~~~

~ **Change Hue **

~ **Change Saturation **

~ Get Float As String With Precision - Get a float as a string with your chosen precision, the re-precisioned float is rounded appropriately. Enjoy!

~ GetSocketLocalTransform - Accessor to this c++ function for your convenience, enjoy

~~~ My Fully Toggle-able Ragdoll Physics System ~~~

Below is the entire graph using my nodes to toggle ragdoll physics mode with the press of a button, while also causing the camera to stay up to date with the position of the ragdoll as it flies around!

See video above!

~ Initialize Victory Rag Doll - you need to have two variables in your blueprint to store the output of this node. Note that you only call this node ONCE. If you call while character is in ragdoll it will not work correctly :slight_smile: So I call this at game start with EventReceiveBeginPlay. The output is in relative Character space, not world space so once it is obtained once it is always correct.

~ Is In Rag Doll - Very useful for creating a Rag doll toggle system :slight_smile:

~ Enter Rag Doll - The supplied actor is converted to a Character for your convenience, returns false if operation could not occur. Checks whether the character has a physics asset for you.

~ Leave Rag Doll - Here is where you use the output from Initialize Victory Rag Doll to restore the character to proper orientation. This part took me a while to figure out!

~ Update Character Camera - My gift to you, causes the camera to stay up to date with the ragdoll as it moves around, but does so SMOOTHLY. Took me a while to get this just right. You can adjust the interpolation speed / how fast the camera keeps up with the ragdoll. The offset determines how high above the ragdoll the camera tries to stay.

2 Likes

Wow good work! I didnt even know we could provide a Blueprint library. Where/How did you find out about this?

Nick Whiting told me about it back in the Beta!

It’s super useful and let’s you share nodes with others, or have a set of global BP nodes for use in your own project!


**Wiki tutorial on Blueprint Node Library**

https://wiki.unrealengine.com/Blueprint_Function_Library,_Create_Your_Own_to_Share_With_Others

:)

Rama

Thanks Rama!

Always enjoy your many community contributions

Hee hee!

:slight_smile:

Rama

Awesome! Looking forward to more!

Can this help me with making some kind of blending between ragdoll and some animations? Like you can see on this video here( Watch after 0:30) :

https://youtube.com/watch?v=zVWZbxGFGiA

Hee hee!

Um, it looks the same as my video, as far as I can tell.

From animation state the character is blending into ragdoll, but never blending out, only restarting.

So that would mean the answer is “Yes!”

Great to hear from you Alex3D!

Rama

Well, I guess you didn’t spot the diferences. rsss On that video, the guy made when the character goes into ragdoll, it is a mix between ragdoll and animation. And this make it more realistic. Your video shows blending from animation into Ragdoll. But ragdoll alone is not that natural. So, if we could mix 50 % ragdoll with 50% animation, that would be better.
Take another look at the video. The guy shows Blending from animation to just radgoll, then he shows blending from animation to a mix of 50 % ragdoll with 50% animation.

Glad to be here. :slight_smile:

ooooh I see now, I did not get that far in the video!

Yea that’s neat!

I will have to look into doing partial ragdoll more at some pt in future :slight_smile:

Rama

Hello Rama,
So I am no coder…but I am learning Blueprint and wanted to ask you … do I need C++ in order to create a mix or blend between a Ragdoll/Animation setup or can it be done solely in Blueprint?

Good to see your plugins back Rama! :slight_smile: Are you going to recompile and reupload them for every new engine version in the future?
Thanks again for sharing!

Thanks a lot for sharing this Rama, this is very generous and awesome.

I’m glad Alex3D brought up Ragdoll Blending or whatever you want to call it(Procedural Animation?). That’s a feature I’ve wanted since I saw some old video of Motionbuilder(Overgrowth is pretty cool too) doing it that added all kinds of subtle natural bounce to animations and proper foot placement much like IK does. If you decide to implement it, I’d request the ability to control the blend amount per bone. Lots of possibilities.

This is so cool! Thanks so much for supporting the UE4 community!

If we’re ever in the same city I’d love to buy you lunch!

Please feel free to private message me with your contact details.

Thanks Rama, nice set of functions. I am also working on a function library, but it isn’t as complete as yours, my functions are more basic.

Oh so nice of you! I’m finding amazing how close the Epic team is getting to us, small developers. Even more amazing is to see Mark Rein and Tim around here, answering forum topics of little mortals like us :cool:

This is what really has me excited for UE4 are the function libraries (via plugins especially). I could see these type of things doing well in the marketplace. I’ll need to start designing more of my functions like this, very modular, and beneficial for all.

Thanks rama

Yup I will be keeping the Victory Blueprint Library updated, though remember I am including the entire source code, so anyone can rebuild my plugin if they feel I am not fast enough :slight_smile:

Great to hear from you Jacky!


Ragdoll + Animation Blend

Wow lot of interest in this! I will check it out.

For those who want to poke about, check out **primitivecomponent.h**, there are these functions:



```

/**
	 *	'Wake' physics simulation for a single body.
	 *	@param	BoneName	If a SkeletalMeshComponent, name of body to wake. 'None' indicates root body.
	 */
	UFUNCTION(BlueprintCallable, Category="Physics")
	void WakeRigidBody(FName BoneName = NAME_None);

```





```

	/** 
	 *	Force a single body back to sleep. 
	 *	@param	BoneName	If a SkeletalMeshComponent, name of body to put to sleep. 'None' indicates root body.
	 */
	UFUNCTION(BlueprintCallable, Category="Physics")
	void PutRigidBodyToSleep(FName BoneName = NAME_None);

```





```

/**
	 *	Force all bodies in this component to sleep.
	 */
	virtual void PutAllRigidBodiesToSleep();

```


	


```

	/**
	 *	Returns if a single body is currently awake and simulating.
	 *	@param	BoneName	If a SkeletalMeshComponent, name of body to return wakeful state from. 'None' indicates root body.
	 */
	bool RigidBodyIsAwake(FName BoneName = NAME_None);

```


	


```

	/**
	 *	Returns if any body in this component is currently awake and simulating.
	 */
	virtual bool IsAnyRigidBodyAwake();

```

Great to hear from you Mark Rein!

I did PM you :slight_smile:

Thank you for your life’s work / UE4!

UE4 is so much fun!

Rama

Hey Rama,

Thanks for so many great contributions so far!

I’ve tried to adapt your BP Ragdoll functions for use on character death, but the location/rotation are tripping me up - instead of respawning at a spawn point, the character is brought to the location of their ragdoll/death. Any ideas on how to circumvent that?

I am making a node for this, in a general purpose way.

For those wanting to do this immediately on their own:


If you have a reference to the player start you want to use, you can

1. end ragdoll
2. set actor location to the location of the player start
3. set actor rotation to the rotation of the player start

I could design a node to do this, but you'd still have to Get the Location and Rotation of the player start, so its really not that much of a shortcut :)

:)

Rama

PS: click on the playerstart in the world, then open the graph and you can add reference