Music Band
This effect allows creators to tap the various band members on the screen to create music, like an MIDI controller. This tutorial will show you how to import your own assets and attach them to the correct objects in the Music Band Template.
data:image/s3,"s3://crabby-images/a2417/a2417c076b26ed1f868bac3c65f54b11311e4a68" alt="music band demo"
Prepare
Before we get started, prepare a set of PNGs for a texture sequence. They should all share the same aspect ratio and resolution for best results. There are two states that a band member can be in, so you’ll want a texture sequence for “Dance” and one for “Tap”. We’ve provided some additional music band texture sequences here:
↓ music_band_characters_additional_sequence.zip
You’ll also want to prepare some audio files. These must be .mp3 files that don’t contain copyrighted material or you’ll receive an error while uploading. Here is an example of an audio file.
Open the Template
Start by opening Effect House, logging in with the account you want to use to publish your effect. Go to Templates and select Music Band.
data:image/s3,"s3://crabby-images/ca913/ca91341a91e4f2309cc2459c3e08592b6659cf90" alt="open the music band template tutorial in effect house"
Let the template load and then save your project to a folder of your choice to save your progress.
Import Assets
Import a new “Dance” texture sequence asset by clicking the Add button [+] > Import > Texture Sequence in the Assets panel.
data:image/s3,"s3://crabby-images/49fbc/49fbc2ce3d3be3f568bc31daa1e6f77573a2b45b" alt="import dance texture sequence asset in the assets panel"
Select all “Dance” images and click Open.
data:image/s3,"s3://crabby-images/630bb/630bba7099e5dcd8e215b9edb189201f7e3066d8" alt="select and open dance images"
You’ll see a new texture sequence appear in the Assets window.
data:image/s3,"s3://crabby-images/8fde7/8fde7529257b145503c0dd58760fda584ddc7bbf" alt="mushroom texture in the assets panel"
It’s recommend to rename and categorize your assets so you can find them easily. This is especially important when there are a lot of assets. To rename it, right-click > Rename and type the new name. Then click and drag it to the folder with the rest of the textures. You can delete the empty Textures folder.
data:image/s3,"s3://crabby-images/0cf49/0cf494f2017c1fe714ee9b38525026c37fe151ba" alt="rename the_ texture folder"
Repeat these steps for the “Tap” version of your texture sequence as well.
Let’s import an audio file by clicking the Add button [+] > Import > From Computer in the Assets panel.
data:image/s3,"s3://crabby-images/a353e/a353e444a279e370ec7f69d4943d2afb34d9a62f" alt="import from computer in the assets panel"
Select your audio file and click Open.
data:image/s3,"s3://crabby-images/e765d/e765da29d200f3bf81d848bad4eb618071a08fe8" alt="open audio file"
Wait for the audio file asset to import. Remember, if this file contains copyrighted material, it will fail to import.
Replace Assets
Let’s take a look at the Hierarchy panel to see how this project is setup.
data:image/s3,"s3://crabby-images/d07a7/d07a787c89868990739a86f6a076569bb5b2a734" alt="replace assets in the hierarchy panel"
Each band member contains three objects: one audio object, one idle dance state object, and one tap state object.
Let’s replace the Crow Beat object with the new assets we just imported. Expand the Crow Beat by clicking the arrow next to the object, then clicking CrowDanceState.
data:image/s3,"s3://crabby-images/b907b/b907b2c2dee4fa8583f44b1d74a2a1b3d992955e" alt="replace crow beat in the hierarchy panel"
Navigate to the Animation Sequence component in the Inspector panel of the object and click Texture Sequence, then select the Dance sequence from the pop-up Assets window.
data:image/s3,"s3://crabby-images/5e4a3/5e4a32a2183b422ad0b721d13bbf659863aef0d4" alt="select dance sequence from assets window"
When replacing the Texture Sequence for Tap State, remember to check the frame number and update it in the corresponding subgraph.
If the frame number of your Tap State sequence is 4, find the CrowTapEventController and change the number from 3 to 4 of the TapStateSeq_FrameNum property.
data:image/s3,"s3://crabby-images/12edd/12edd1c963f85c0f77d94a061cc66b913d7fb4e0" alt="change the frame number of the tap state"
You can find the number of frames in the Duration field by clicking the Texture Sequence in the Hierarchy panel.
data:image/s3,"s3://crabby-images/e7398/e739809579e2b682413962ee69959a06e2d4a87a" alt="frame number in duration"
Now, you will replace the audio that is played when the character is tapped.
Click CrowAudio in the Hierarchy panel.
data:image/s3,"s3://crabby-images/6a977/6a97732394ea0f4fb2d1564f4b4ff6cf5c74c068" alt="replace the audio that is played"
data:image/s3,"s3://crabby-images/207f0/207f0a76d689a5f5d53bbcdb76f75ea904ec4ed9" alt="replace the audio that is played"
Navigate to the Audio Player component in the Inspector panel of the object and click Audio File, then select the audio file from the pop-up Assets window. There are some additional settings here, such as Play Mode and Volume.
data:image/s3,"s3://crabby-images/6ff7c/6ff7ca63bf94d30a044b575533aff4f236433377" alt="audio player component in inspector panel"
Congratulations! Now you’ve customized the Music Band template and made it your own! If you have any questions, please feel free to reach out for help on our Discord.
Visual Scripting and Subgraph Deep Dive
Each of the following purple comment boxes is responsible for the behavior of a band member. Let’s take a closer look at the Crow Beat Control comment box.
data:image/s3,"s3://crabby-images/e2c1d/e2c1d8d0b707eca619c0a5e70534d64974e031e7" alt="control beat control subgraph"
Here you can see all the references being passed into the subgraph. The first reference is the Image component of Dance State. The second is the Scene object of Dance State and the third is the Animation Sequence of Tap State. The fourth is the Scene object of Tap State and the last is the Audio Player from the crow’s Audio component.
To get a new reference, click the the Add button [+] next to a component’s details and select Get.
data:image/s3,"s3://crabby-images/93cdd/93cdd683ce0108bfa1cfc65c395c8a5888a65a5d" alt="references passed to the subgraph"
To inspect inside the subgraph, double-click it.
data:image/s3,"s3://crabby-images/10b81/10b812ea1d59bab63a413e73a5985d0eb44d6dcd" alt="references passed to the subgraph"
The node setup is relatively straightforward. Use the Image Tap node to Play the desired animation sequence via the Animation Sequence Controller. From there, you can simply toggle the visibility of the animation sequence to hide the one that is not currently playing. For example, when you tap the crow, it should show the “Tap” state animation sequence and hide the “Dance” state animation sequence.
data:image/s3,"s3://crabby-images/220a3/220a31b339211ef82144e4dea682ff9ebc256049" alt="nodes setup"
The Audio Player Controller plays the audio file connected to the Audio Player.
data:image/s3,"s3://crabby-images/b46ba/b46bab16f0a0e3ebe2299651727c1b050d6eae9d" alt="audio player controller"