Fabric is a powerful Unity-based audio middleware solution extending the features available and providing custom user interfaces.
Heavy can generate Fabric specific DSP plugins for a variety of use cases, including sound generators, effects units and continuous or one-shot style sounds.
-
Create a new Unity project, or start with an existing one.
-
Install Fabric either by dragging the package into the project. Or through the Unity menu:
Assets > Import Package > Custom Package > select Fabric .unitypackage
-
Again install this package into the Unity project.
Don't want to manually organise patches and plugin scripts and binaries in your projects? The Fabric Heavy Uploader
is made for you!
Once installed the uploader window can be accessed through the menu:
Window > Fabric > Integrations > Heavy Uploader
If the Menu item is greyed out then make sure to select the Fabric Manager object in your scene heirarchy first.
Interface Features:
Auto Upload
: when enabled the uploader watches for changes in the patch and automatically sends then to the heavy server.Token
: allows the uploader to correctly authenticate with your account.About
: shows the Fabric Heavy Uploader version.Enzien Audio
: a link to the heavy site.Build
: choose which platform plugin to downloadUpload
: Uploads the current patch and downloads the selected 'Build' option....
: Context menu showing two options:Clean Patch
: removes all downloaded plugin binaries for the selected patch.Delete Patch
: removes all assets related to the patch including the patch file itself.
In order to authenticate with heavy a user token will need to be generated and stored in the Fabric Heavy Uploader.
See the Token documentation for information on managing your tokens.
Copy your generated user token to the Token
field of the Fabric Heavy Uploader interface.
- Note: Currently it is neccessary to first create a new patch on the heavy site.
Then in your Assets folder create a directory that contains the new patch. The name of the folder will be the name that the Fabric Heavy Uploader will reference when uploading to the heavy server. Make sure it is the same as the one pre-created on the site.
The minimum requirement is to have a patch named _main.pd
, this will be used as the top-level reference. Other patch abstractions and files can also be included in this directory.
See the image below as an example:
After following the previous steps, in the Fabric Heavy Uploader window select the appropriate Build
option to generate and click Upload
.
The plugin assets will be automatically managed.
For a quick Fabric setup follow these instructions:
- Create and a new Fabric Manager (
Menu > Fabric > FabricManager
)- Select the Manager in the object heirarchy.
- Add an Event to the Fabric Manager's Event Manager, for example 'Test'.
- Add a DSP plugin
(Menu > Fabric > Components > Heavy > {patch})
- Select the newly added DSP plugin object.
- Add a Listener (
Add Component > Fabric > Events > Listener
). - Set the Listener's Event Name to 'Test'.
- Add a Listener (
- Create a separate empty gameobject in the top-level scene hierarchy.
- Select the new gameobject.
- Add a Trigger (
Add Component > Fabric > Events > Trigger
). - Set the Trigger's Event Name to 'Test'.
- Press play in Unity.
The type of plugin that heavy generates is dynamically determined depending on the I/O channel configuration.
A patch that doesn't contain an [adc~]
will result in a Generator
unit being created (i.e. a simple sinewave or synth). This only outputs audio an audio signal.
If an [adc~]
object exists in the patch the generated plugin with be an Effect
unit, for processing input audio sources (i.e. a filter, compressor, distortion fx).
- Note: make sure that the corresponding AudioSource component's AudioClip property is set to Null.
The Fabric target supports both input and output parameters which can be used to either control the patch from Fabric, or to control Fabric from the patch.
Input parameters will display a slider control and can also be automated or script within Fabric.
Output parameters will display a popup menu next their respective name that enables bindings to existing Global Parameters defined in Fabric. Use these to create an audio-driven system.
Typically in sample-based approaches, sounds can be categorised roughly as either being a one-shot or a continuous loop. This playback behaviour can be similarly recreated with heavy.
By default, once a plugin is triggered to start via a Fabric Event it will continue with an infinite duration until given a Stop command.
However, the patch itself can instruct Fabric to stop itself from playing and remove it from the playback pool.
First make sure that within the Fabric Manager object, the AudioSource Pool's Size
property is set to a non-zero number.
Then at any point you can send a bang
message to a [send finished @hv_event]
object in the patch, which will then instruct Fabric to stop playback.
The example patch below will play a sinewave sound for 2 seconds before ending:
Each platform has its own way of compiling the plugins.
An Xcode project exists in the unity/xcode
directory and the plugin may be built manually. It can also be compiled directly from the commandline.
$ cd unity/xcode
$ xcodebuild -project Hv_heavy_Fabric.xcodeproj -arch x86_64 -alltargets
The results are placed in unity/build/macos/x86_64/Release
.
$ cd unity/linux
$ make -j
The results are placed in unity/build/linux/x86_64/release
.
A Visual Studio 2015 project exists in the unity/vs2015
directory and the plugin may be built manually. It can also be compiled directly from the commandline.
$ cd unity/vs2015
$ "C:/Program Files (x86)/MSBuild/14.0/Bin/MSBuild.exe" /property:Configuration=Release /property:Platform=x64 /t:Rebuild Hv_heavy_Fabric.sln /m
The results are placed in unity/build/win/x64/Release
.
Plugins for x86 may also be built by specifying /property:Platform=x86
.
$ cd unity/android
$ ndk-build APP_ABI=armeabi-v7a -j
The results are placed in unity/build/android/libs/armeabi-v7a
.