Skip to content

aivenhoe/KlakSpout

 
 

Repository files navigation

KlakSpout

gif screenshot

KlakSpout is a Unity plugin that allows sharing video frames with other applications using the Spout system.

Spout is a video sharing system for Windows that allows applications to share frames in real time without incurring significant performance overhead. It's supported by several applications (MadMapper, Resolume, etc.) and frameworks (Processing, openFrameworks, etc.). It works in a similar way to Syphon for Mac, and it's similarly useful for projection mapping and VJing.

System requirements

  • Unity 2017.4 or later.
  • KlakSpout only supports Direct3D 11 (DX11) graphics API mode. Other APIs (DX9, DX12, OpenGL, etc.) are not supported at the moment.

Installation

Download and import one of the unitypackage files from the Releases page.

Spout Sender component

The Spout Sender component (SpoutSender) is used to send frames to other Spout compatible applications.

There are two modes in Spout Sender:

Camera capture mode

inspector

The Spout Sender component runs in the camera capture mode when attached to a camera object. It automatically captures frames rendered by the camera and publish them via Spout. The dimensions of the frames are dependent on the screen/game view size.

Note that the camera capture mode is not compatible with scriptable render pipelines; The render texture mode should be applied in case of using SRP.

Render texture mode

inspector

The Spout Sender component runs in the render texture mode when it's independent from any camera. In this mode, the sender publishes content of a render texture that is specified in the Source Texture property. This render texture should be updated in some way -- by attaching to a camera as a target texture, by custom render texture, etc.

Alpha channel support

This controls if the sender includes alpha channel to published frames. In most use-cases of Unity, alpha channel in rendered frames is not in use; it only contains garbage data. It's generally recommended to turn off the Alpha Channel Support option to prevent causing wrong effects on a receiver side.

Spout Receiver component

inspector

The Spout Receiver component (SpoutReceiver) is used to receive frames published by other Spout compatible applications.

Source Name property

The Spout Receiver tries to connect to a sender which has a name specified in the Source Name property. Note that the search is done with exact match (case-sensitive). It can be manually edited with the text field, or selected from the drop-down labelled "Select" that shows currently available Spout senders.

Target Texture property

The Spout Receiver updates a render texture specified in the Target Texture property every frame. Note that the Spout Receiver doesn't care about aspect ratio; The dimensions of the render texture should be manually adjusted to avoid stretching.

Target Renderer property

When a renderer component (in most cases it may be a mesh renderer component) is specified in the Target Renderer property, the Spout Receiver sets the received frames to one of the texture properties of the material used in the renderer. This is a convenient way to display received frames when they're only used in a single instance of renderer.

Script interface

The received frames are also accessible via the receivedTexture property of the SpoutReceiver class. Note that the receivedTexture object is destroyed/recreated when the settings (e.g. screen size) are changed. It's recommended updating the reference every frame.

Spout Manager class

The Spout Manager class (SpoutManager) only provides a single functionality: Get a list of sender names that are currently available in the system (GetSourceNames). This is useful to implement a sender selection UI for run time use.

gif

Please check the Source Selector example for detailed use of this function.

Frequently Asked Questions

Can't send/receive more than 10 sources

See issue #33 in the Spout SDK. You can download the SpoutSettings app from the thread that allows changing the maximum number of Spout senders.

Spout vs NDI: Which one is better?

The answer is simple: If you're going to use a single computer, use Spout. If you need connecting multiple computers, use NDI.

Spout is a superior solution for local interoperation. It's faster, low latency, more memory efficient and better quality. It's recommended using Spout unless multiple computers are involved.

License

MIT

About

Spout plugin for Unity

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 85.4%
  • C 7.0%
  • C# 6.1%
  • ShaderLab 1.5%