Dear Community,
Newest Awesome
(In Complimentary (no cost) Victory Plugin!)
Now You Can Get the Text Output (STDOUT or STDERR) from any .exe program, straight into Unreal Engine!
is the output of a video compression commandline tool (Handbrake), launched by your UE game & delivered straight into the Unreal Engine Viewport!
Using only 3 Blueprints nodes!
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!
These are functions you can call from AnimBlueprints, Character blueprints, level blueprints, anywhere!
Because 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.27 For OS
4.27 (win32, win64 only)
**4.26 **(win32, win64, editor, dev packaged, and shipping)
Please note I now use the UE4 Marketplace C++ Plugin Standard when packaging Victory plugin for you
- Win64 Development
- Win64 Shipping <~~~~~~ NEW!
- Win32 Development
- Win32 Shipping
Please see my instructions for Packaging UE4 Plugins With Your Game.
~
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: **VictoryPlugin13
**4.14: ** http://www.mediafire.com/file/7915cu…ryPlugin14.zip
**4.15: ** VictoryPlugin15
**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: VictoryPlugin26
4.27 VictoryPlugin27
~
Donations can be sent to me via:
~
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/%2…lugin_Download
Just get the most recent version
~
Entire Source Code For You!
I am including the entire source code for the plugin and the actual nodes in the download!
~
Victory BP Library Copyright Permissions
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 “”
~
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!
~
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]((39) 's Extra Blueprint Nodes for You as a Plugin, No C++ Required! - Blueprint - Epic Developer Community Forums) ~ Retrieve your local current, milliseconds, seconds, minutes, hours, day, month, year!
Get Since Previous Recorded]((39) 's Extra Blueprint Nodes for You as a Plugin, No C++ Required! - Blueprint - Epic Developer Community Forums) ~ Retrieve the difference in since your chosen previous! You can record down to the sub-millisecond level, and up to hours!
Get Difference Between Any Two Times ~ With node you can compare any two times that you’ve recorded using my node above!
You can store as many moments in as you want using my above node, the 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 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./e-3irWhYzMU
~
Pictures
Here are some pics of a few of the nodes I am giving you below!
Get Recently Rendered / Not Rendered Actors
Get Character Bone Current Locations
Trace for Closest Socket
Victory Ragdoll System, Including Follow Camera
Trace Data With Skeletal Mesh
5 More Pictures, Enjoy!
https://forums.unrealengine.com/show…ll=1#post26153
~
Installation
-
put the .zip contents in a folder in your main directory where your .uproject is, called “Plugins” (name most be precise)
-
open editor and go to window->plugins
-
make sure my Victory Plugin is checked off as being active
-
restart editor
-
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
- If you want to use the vertex snapping as well, please see installation instructions here:
https://wiki.unrealengine.com/%2…n#Installation
**Current List of Functions (48 Nodes Total)**
**~~~ Recently Added ~~~**
**~~~ Frame Rate / Graphics Options ~~~**
**Set Frame Rate
Set Frame Rate To Be Unbound!**
**4 New Nodes**
** of Float Array
of Int Array
Min of Float Array
Min of Int Array**
[https://forums.unrealengine.com/show...ll=1#post77775](https://forums.unrealengine.com/showthread.php?3851-(39)--s-Extra-Blueprint-Nodes-for-You-as-a-Plugin-No-C-Required!&p=77775&viewfull=1#post77775)
Get Current Operating System
https://forums.unrealengine.com/show…ll=1#post65910
Get Since Previous Record Timed
https://forums.unrealengine.com/show…ll=1#post65910
Get Difference Between Any Two Recorded OS Times
https://forums.unrealengine.com/show…ll=1#post65920
**Get Supported Screen Resolutions for End User’s Current Display Adapter **
https://forums.unrealengine.com/show…ll=1#post26535
Combine Strings ~ Combine two strings with optional separator and labels
https://forums.unrealengine.com/show…ll=1#post26535
**Clone Static Mesh Actor (during game) **
https://forums.unrealengine.com/show…ll=1#post26262
Teleport Actor to Actor
https://forums.unrealengine.com/show…ll=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 :)
~ **Get Bone Locations ** Returns an array of the bone locations on the Character. The Character's Mesh component must be valid for 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 currently rendered actors. You can choose what 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 currently NOT rendered actors. You can choose what 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 BP Library, is a Blueprint version of the same core c++ code as Shootergame uses. With 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 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 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 /Actor Name As String ** - Get the name of any actor, component, or anything at , 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 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 node. Note that you only call node ONCE. If you call while character is in ragdoll it will not work correctly :) So I call 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 :)
~ **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. 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 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.