- 1 Introduction
- 2 Play sound with Timeline
- 3 Create Shader
- 4 Change Shader with Timeline
- 4.1 Assign Cube to Timeline
- 4.2
- 4.3 Add a clip to Timeline
- 4.4 Convert into ‘Clip Track’
- 4.5 Duplicate Clip Track
- 4.6 Rename the Clip
- 4.7 Make Keyframe white
- 4.8 Synchronize the White track with sound
- 4.9 Disable ‘Snap’
- 4.10 Adjust the White track to the timing when the sound starts
- 4.11 Convert Animation clip into Asset
- 4.12 Troubleshooting: The Name field of AnimationClip doesn’t show up
- 4.13 Place AnimationClip in Timeline
- 4.14 Copy the length of other animation track
- 5 How to upload the asset from Unity to STYLY (For Scenes)
- 6 How to upload the asset from Unity to STYLY (For Prefab)
- 7 The setting for the sound to upload it to STYLY
Introduction
Example
A representation of a noise-style shader synchronized with noise-style music is shown below.
Sample
Github Sample Project
https://github.com/styly-dev/STYLY-Unity-Examples/tree/master/Assets/STYLY_Examples/NoiseMusicSync_Sample
Play sound with Timeline
Here I explain how to create a Timeline and play sound.
Create Timeline
Firstly, create a Timeline. Right-click on the Project window and select ‘Create > Timeline’.
data:image/s3,"s3://crabby-images/2955e/2955eb997c6c693e8290b7f855f0eb350c7977cc" alt="0_create_timeline - STYLY Timelineの作成"
Create Timeline
data:image/s3,"s3://crabby-images/8bc0e/8bc0e47f21ccded8b32614ec91c39ffd0e7b4fc4" alt="img_5c6f368b488e2 - STYLY 作成されるTimelineアセット"
The Timeline asset created
Convert Timeline asset into an object
Next, convert the Timeline asset into an object. Drag the Timeline asset created earlier into the Hierarchy window.
data:image/s3,"s3://crabby-images/7def3/7def33d1d48a117ccf2cb17fd94ffdb5198b5b60" alt="1_drag_and_drop_timeline - STYLY TimelineアセットをHierarchyへD&D"
Drag the Timeline asset into the Hierarchy window
It creates a GameObject with PlayableDirector. You need PlayableDirector to enable Timeline.
data:image/s3,"s3://crabby-images/383f5/383f582266ea21f31511cf52c933ea1d2befae20" alt="img_5c6f3858834cf - STYLY 作成されたPlayableDirectory付きのGameObject"
The created GameObject with PlayableDirectory
Double-click the Timeline asset to open the Timeline window.
data:image/s3,"s3://crabby-images/49bc4/49bc4578fb411c32542bdf05612644ec31d61860" alt="img_5c6f399c4a21f - STYLY Timelineアセットをダブルクリック"
Double-click the Timeline asset
In the Timeline window, you can edit and play the Timeline. You basically work on this window when editing the Timeline.
data:image/s3,"s3://crabby-images/52348/52348c2b11c05bffeb3c74975adc8deb59aebadf" alt="img_5c6f39d0e228f - STYLY Timelineウィンドウ"
Timeline window
Play sound
In this time, I use the sound that plays the sine wave at regular intervals.
You can download the sample sound (Link). Firstly, drag the sound data (AudioClip) into the Timeline.
It creates ‘AudioTrack’ and assigns ‘AudioClip’ to the Timeline.
data:image/s3,"s3://crabby-images/d4aa1/d4aa16b5e751b57dcb7762903dccfe2c82078b4b" alt="img_5c6f3cb101a6e - STYLY AudioClipがTimelineに登録される"
AudioClip is assigned to Timeline
Drag the ‘sin_C5’ clip so that its left end is at 0.
data:image/s3,"s3://crabby-images/3807f/3807fb4dcab2322ab6cdde7e833ed806d92873bd" alt="img_5c6f3d4b78550 - STYLY Clipの開始位置を0に合わせる"
Adjust the starting point of the Audio Clip to 0
In this state, you can play the sound by pressing the Play button in Unity.
Lock Timeline
To avoid unselecting the Timeline when selecting other objects, lock the Timeline by clicking the ‘Padlock’ icon in the top-right corner of the window.
data:image/s3,"s3://crabby-images/dd605/dd60542cd68fad1198377e4d5d5a5a9e6e7d0f8d" alt="img_5c71f7df48353 - STYLY Timelineをロック"
Lock Timeline
Create Shader
Next, create a shader that is controlled by the Timeline. Right-click the Project window to open the context menu and select ‘Create > Shader > Unlit Shader’ to create a shader.
data:image/s3,"s3://crabby-images/fe67c/fe67c15737713446e9823a5c1aff1defb84c0559" alt="1_create_timeline - STYLY シェーダー作成"
Create Shader
Name it ‘SimpleColor’.
data:image/s3,"s3://crabby-images/d0bfb/d0bfbf804634eaef3c83ad40337f0f890c5732ba" alt="img_5c6f334be7f92 - STYLY SimpleColor.shader"
SimpleColor.shader
Edit the shader as shown below.
Shader "Unlit/SimpleColor" { Properties { _MainTex("Texture", 2D) = "white" {} _Color("Color", Color) = (0, 0, 0, 1) // color } SubShader { Tags { "RenderType" = "Opaque" } LOD 100 Pass { CGPROGRAM #pragma vertex vert #pragma fragment frag // make fog work #pragma multi_compile_fog #include "UnityCG.cginc" struct appdata { float4 vertex : POSITION; float2 uv : TEXCOORD0; }; struct v2f { float2 uv : TEXCOORD0; UNITY_FOG_COORDS(1) float4 vertex : SV_POSITION; }; sampler2D _MainTex; float4 _MainTex_ST; float4 _Color; // color v2f vert(appdata v) { v2f o; o.vertex = UnityObjectToClipPos(v.vertex); o.uv = TRANSFORM_TEX(v.uv, _MainTex); UNITY_TRANSFER_FOG(o,o.vertex); return o; } fixed4 frag(v2f i) : SV_Target { return tex2D(_MainTex, i.uv) * _Color; } ENDCG } } }
Create Material
Create a material from the above SimpleColor.
data:image/s3,"s3://crabby-images/28282/2828254c198d761d466f7ea9f84bb1fd40838f81" alt="img_5c71f49817471 - STYLY マテリアルの作成"
Create Material
data:image/s3,"s3://crabby-images/7a9bf/7a9bfb980bf81101ed4100d2bd4b4874fafd4f7b" alt="img_5c71f3ff19204 - STYLY 作成されたマテリアル"
The created material
Create a Cube
Press the Create button in the Hierarchy window and select ‘3D Object > Cube’ to create a Cube.
data:image/s3,"s3://crabby-images/e4e9a/e4e9a69c24575ddbfb9a92c212789d3837d48c5f" alt="img_5c71f55ad70a9 - STYLY Cubeを作成"
Create a Cube
Attach Material to Cube
Attach the material to the Cube by dragging the material into it.
data:image/s3,"s3://crabby-images/488b0/488b048b9a2dff26d9cda825088da3ff0c7049d3" alt="img_5c71f657e27f2 - STYLY Cubeにマテリアルを登録"
Attach the material to the Cube
When attaching the material, the Cube turns black.
data:image/s3,"s3://crabby-images/8822b/8822b8155f9fbf253eb8fdd0f9a2689d6bcc7bfd" alt="img_5c71f6d702e18 - STYLY マテリアルの登録結果"
The result – The material has been attached
Change Shader with Timeline
Assign Cube to Timeline
Drag the Cube into the Timeline to assign the Cube to the Timeline.
data:image/s3,"s3://crabby-images/db694/db69426e884238a4f8b0c7652370a02831efc4ce" alt="img_5c71f9fbb9981 - STYLY CubeをTimelineへドラッグ&ドロップ"
Drag Cube into Timeline
It brings up the menu. Select ‘Animation Track’.
data:image/s3,"s3://crabby-images/67e97/67e97f4c25060d10ba83d9efda5caed71c15064a" alt="img_5c71fa8ba95a8 - STYLY Animation Track を選択"
Select ‘Animation Track’
It creates the AnimationTrack for the Cube object in the Timeline.
data:image/s3,"s3://crabby-images/9d7ea/9d7ea599e9902b8471fc69ae69e93f548a6ab0f3" alt="img_5c7244b11fcf3 - STYLY 作成されたAnimationTrack"
The created AnimationTrack
That’s all you need to assign the Cube object to the Timeline. Next, we are going to edit this ‘AnimationTrack’. Set the position of the ‘Seek Bar'(=the Playhead) to 0.
data:image/s3,"s3://crabby-images/166a3/166a35d1db7606c8e6b181693f8b41bba170d7c8" alt="img_5c724b335504d - STYLY シークバーを0の位置に合わせる"
Set the position of the ‘Seek Bar’ to 0.
Alternatively, you can set the ‘Seek Bar’ position to zero by pressing the ‘<<‘ button on the Timeline.
data:image/s3,"s3://crabby-images/5c19b/5c19bd794d96efd4d808d4674a73159c67107780" alt="img_5c77e28aa569b - STYLY シークバー位置を0に合わせる"
The button to set the Playhead position to zero
Add a clip to Timeline
Set Timeline to the ‘Recording’ mode
Click the red button in the upper left corner of the Timeline window to set the Timeline to the Recording mode.
data:image/s3,"s3://crabby-images/9f8f5/9f8f57c70de45b5839a80c7bb7c45bf2cb4054e3" alt="img_5c7245cc589b0 - STYLY Recording開始"
Start Recording
Then, the AnimationTrack turns red, which means it became the Recording mode and it’s editable now.
data:image/s3,"s3://crabby-images/03a84/03a8413e10aa163f40650123434177be881c5f35" alt="img_5c724613bde41 - STYLY Recording状態のTimeline"
The Timeline in the ‘Recording’ mode
Add a ‘Black’ keyframe
Next, select the Cube.
data:image/s3,"s3://crabby-images/25027/250275b6e2647aae0d34f6fc415c2a87ce274ae8" alt="img_5c72468f41c6b - STYLY Cubeをクリック選択"
Click the Cube to select
Right-click ‘Color’ in the Material field of the Inspector window.
data:image/s3,"s3://crabby-images/41283/41283a43b32ee8e26b17687811c0602816a920bf" alt="img_5c724a5e1207a - STYLY InspetorのColorの部分を右クリック"
Right-click ‘Color’ in the Inspector window
It brings up the menu. Select ‘Add Key’.
data:image/s3,"s3://crabby-images/96ace/96ace0cff7d554625db16bd60e12809ae90cd77a" alt="img_5c724a16742f4 - STYLY Add Keyを選択"
Select ‘Add Key’
It added the current Color information to the Timeline as a keyframe.
data:image/s3,"s3://crabby-images/47578/47578ffbe258e677cd07321f30b555c666099a29" alt="img_5c72486b6f883 - STYLY Timelineのシークバーの位置にキーフレームが追加される"
A keyframe is added at the position of the Timeline ‘Seek Bar’.
In this time, the ‘Black’ keyframe, ‘Color = (0, 0, 0, 1)’, has been added to the Timeline.
Convert into ‘Clip Track’
We added a keyframe just now. Then, let’s convert it into ‘Clip Track’ to make it easy to handle.
data:image/s3,"s3://crabby-images/2b8aa/2b8aa1bb8c0c93fe87884ad729912379da57cff6" alt="img_5c724f74c47fe - STYLY 右クリック"
Right-click the Animation Track
In the displayed menu, select ‘Convert to Clip Track’.
data:image/s3,"s3://crabby-images/12791/12791ac92b29babb277f04d4d78fc8e9945e1e0a" alt="img_5c724ff661c2d - STYLY ClipTrackへ変換"
Convert into ‘ClipTrack’
It changes the keyframe into ‘Clip Track’.
data:image/s3,"s3://crabby-images/ac115/ac1150621fb6f340664cd0e11688d7f8e47b1675" alt="img_5c725057855d8 - STYLY 作成されたClip Track"
The created Clip Track
Double-click the Clip Track to open the Animation window and the Clip Track. This time, The ‘Color=(0, 0, 0, 1)’ keyframe is placed at 0:00.
Duplicate Clip Track
Right-click the Clip Track and select ‘Duplicate’ from the menu displayed.
data:image/s3,"s3://crabby-images/194fc/194fcf980709a74785b5b010e78be2db06ff82bb" alt="img_5c725201dc7d4 - STYLY ClipTrackを複製"
Duplicate ClipTrack
data:image/s3,"s3://crabby-images/f205e/f205e2119621eaefdd4ccf3eb9ae1672f582305d" alt="img_5c72526cc1a94 - STYLY 複製されたClipTrack"
The duplicated ClipTrack
Rename the Clip
The name of the clip is not so descriptive at the moment, so we rename it. Firstly, click the first Recorded clip.
data:image/s3,"s3://crabby-images/6a684/6a6849f4e33bebf0229ba37d38dfd301545e67e3" alt="img_5c77e3883091c - STYLY 1番目のRecordedクリップをクリック選択"
Click the first Recorded clip
Enter ‘Black’ in the Name field (It’s been set to ‘Recorded’ by default) at the top of the Inspector window.
data:image/s3,"s3://crabby-images/588d9/588d9d37c6ddc836a8dfd90adc66d5546074b2c6" alt="img_5c77e41be7bdd - STYLY Recordedの部分をBlackに変更"
Change ‘Recorded’ into ‘Black’
Once you renamed, the text on the clip turns into ‘Black’.
data:image/s3,"s3://crabby-images/950b8/950b880f5087e1d2b394e2376664bfb9bbe25c6e" alt="img_5c77e49ba73e4 - STYLY クリップのテキストがBlackに変化している"
The text on the clip turned into ‘Black’
Similarly, rename the second clip ‘White’.
data:image/s3,"s3://crabby-images/d3ff0/d3ff0243bab784ee3fc8dbf341364cca7d750a66" alt="img_5c72541cb4d14 - STYLY リネームした結果"
Result – the clips have been renamed
Make Keyframe white
Double-click the White clip to open.
data:image/s3,"s3://crabby-images/b3cab/b3cab25e6274b340026a084483734b85b0cec5ff" alt="img_5c7255003478c - STYLY Whiteクリップをダブルクリックして開く"
Double-click the White clip to open
Set the keyframe shown in the window to ‘Color = (1, 1, 1, 1)’.
data:image/s3,"s3://crabby-images/4319c/4319cdc7c2fa5aea2996bf11a85a342ddd2800bd" alt="img_5c72549a7842e - STYLY キーフレームをColor = (1, 1, 1, 1)にする"
Set the keyframe to ‘Color = (1, 1, 1, 1)’
If you play the Timeline in this state, the cube turns white ‘Color = (1,1,1,1)’ when the White track starts.
data:image/s3,"s3://crabby-images/16e89/16e89f46a84affa54053e7b4241bb2908393c8eb" alt="10_preview_timeline - STYLY Whiteトラックが開始するタイミングでCubeが白くなる"
Cube turns white when the White track starts
Now the colour of the Cube changes but it’s not synchronized with the timing of the playing sound.
Synchronize the White track with sound
We synchronize the sound and the colour change by synchronizing the waveform and the White track. Since the waveform is displayed too small to adjust, scale it up by using the mouse wheel.
data:image/s3,"s3://crabby-images/71625/716258122d40a2d5691b68087edce89456d44568" alt="img_5c77e6e3c8461 - STYLY マウスホイールを回転させてウィンドウを拡大する"
Use the mouse wheel to scale it up
Scale it up so that you can see the waveform.
data:image/s3,"s3://crabby-images/8f660/8f6605c19f5f679a5969985476ec8e2afb968a06" alt="img_5c77e770ab8ae - STYLY 波形が見えるレベルまで拡大"
Scale it up until you can see the waveform
Next, we adjust the White clip to the timing when the sound starts, which is indicated by the red frame below.
Because ‘Snap to Frame’ is enabled by default, the track moves using frames when matching the track to the sound.
data:image/s3,"s3://crabby-images/79a4c/79a4c2f5813f968a8ad72090e983301d54b07d85" alt="11_move_track - STYLY トラックを動かそうとすると目盛りの位置に移動してしまう"
When moving the track, the track is snapped to a frame.
You need to turn off ‘Snap to Frame’ to solve it.
Disable ‘Snap’
Click the Cog icon in the top right corner of the window.
data:image/s3,"s3://crabby-images/7a570/7a570f8cc4111ca5680958112f7e8e964c38eb86" alt="img_5c724d011d49a - STYLY 歯車アイコンをクリック"
Click the Cog icon
You can find ‘Snap to Frame’ in the menu displayed, so uncheck it.
data:image/s3,"s3://crabby-images/657c2/657c2ed87936f492b995c56aafa6e969bea5e97a" alt="img_5c724dd13b771 - STYLY Snap to Frameのチェックを外す"
Uncheck ‘Snap to Frame’
You can move the track to anywhere as you disabled ‘Snap to Frame’.
data:image/s3,"s3://crabby-images/d8991/d89913789a541473e8c25165451cefbf1781c5c8" alt="12_move_track - STYLY スナップOFFで移動させた場合"
Move the track with ‘Snap to Frame’ disabled
Adjust the White track to the timing when the sound starts
As shown below, place the White track so that it’s synchronized with the sound.
In this state, when playing back the scene, the cube turns white as the sound starts.
Anyway, let’s save the scene here. You can save the scene by selecting ‘File > Save Scene’ from the menu in the top left corner of the window.
data:image/s3,"s3://crabby-images/e0a05/e0a053c995deaece24531d56d72cfba35c1002c0" alt="img_5c77e88345894 - STYLY シーンの保存"
Save the scene
Convert Animation clip into Asset
If you converted the clip created in the Timeline into an asset, it would be more convenient as it could be shared for other use.
Name Asset
Firstly, select the Black clip and enter ‘SetBlack’ for ‘Animation Clip Name’ in the Inspector. Similarly, select the White clip and enter ‘SetWhite’ for ‘Animation Clip Name’ in the Inspector.
data:image/s3,"s3://crabby-images/41219/4121998151a46f7d2091cc09353faa9fdb2fae98" alt="img_5c725c884e7e8 - STYLY BlackクリップのAnimationNameにSetBlackと入力"
Enter ‘SetBlack’ in the ‘Animation Clip Name’ field
In this state, ‘AnimationClip’ is created in the Timeline asset by saving the scene.
data:image/s3,"s3://crabby-images/6d75a/6d75a7ac46e925c6e70be170f3431e0e4ee6a44b" alt="img_5c725d0d7164f - STYLY Timelineの中にAnimationClipが出現"
‘AnimationClip’ appeared in the Timeline
Troubleshooting: The Name field of AnimationClip doesn’t show up
If you didn’t save the scene, the Name field of AnimationClip wouldn’t appear.
data:image/s3,"s3://crabby-images/d6f87/d6f876d7a206b5d8c9fa6146a1e75bb5ea2e2c09" alt="img_5c77e9c3eb463 - STYLY シーンを保存していない場合、Animationクリップ名入力欄が表示されない"
The Name field of AnimationClip wouldn’t appear if you didn’t save the scene.
You need to save the scene to solve it.
data:image/s3,"s3://crabby-images/e0a05/e0a053c995deaece24531d56d72cfba35c1002c0" alt="img_5c77e88345894 - STYLY シーンの保存"
Save the scene
Convert AnimationClip to Asset
Select and duplicate the AnimationClip in the Timeline to take it out from the Timeline and convert it into an asset.
data:image/s3,"s3://crabby-images/399d5/399d59eb68290c984f9aa6ad488f92daeebe036c" alt="img_5c725e72affbe - STYLY AnimationClipを複製"
Duplicate AnimationClip
Then, the SetBlack animation is converted into an asset and the ‘SetBlack.anim’ file is created.
data:image/s3,"s3://crabby-images/c7fc1/c7fc13174e3653ad112ce220481c551934d578cc" alt="img_5c725f1e703be - STYLY アセット化されたAnimationClip"
The AnimationClip converted into an asset
You also create ‘SetWhite.anim’ in the same way.
Place AnimationClip in Timeline
Drag the created SetWhite.anim and SetBlack.anim into the Timeline.
data:image/s3,"s3://crabby-images/d2a20/d2a20f81885b9414861874db095c9ddaa7e864b7" alt="img_5c7261bf87904 - STYLY SetBlack.animをTimelineへ登録"
Assign ‘SetBlack.anim’ to ‘Timeline’
It creates the clip in the Timeline, but it looks too short.
data:image/s3,"s3://crabby-images/64c21/64c21c8f39cc068477daabf40e2015b933e8202a" alt="img_5c7262217d780 - STYLY Timeline上に作成されたSetBlackクリップ"
The SetBlack clip created in the Timeline
Copy the length of other animation track
As the length of the Black track seems to be relevant, I want to adjust the SetBlack tract to the same length. Firstly, select the Black clip and copy the ‘Duration’ value in the Inspector.
data:image/s3,"s3://crabby-images/dc3a2/dc3a2b4dc61ed9c58a795b6a76f23cf0961287df" alt="img_5c7263dd04965 - STYLY Durationの数値をコピー"
Copy the ‘Duration’ value
Select the SetBlack clip and paste it into the ‘Duration’ field.
data:image/s3,"s3://crabby-images/e0670/e06708767cc9c7863c3634004f1163f6de18dced" alt="img_5c72646097bc2 - STYLY Durationの数値ペースト"
Paste the value into ‘Duration’
Now the length of the SetBlack clip is the same as the Black clip.
data:image/s3,"s3://crabby-images/10d93/10d9335e3e7321b30a05b9a47768ea69528cf55a" alt="img_5c7264ac6fc37 - STYLY Durationペースト後のSetBlackクリップ"
How the SetBlack clip looks after copying the Duration value
Similarly, place SetBlack clips and SetWhite clips alternately with no gaps.
data:image/s3,"s3://crabby-images/e6c6f/e6c6f2438136623f65af3d46c31794c080f8fefb" alt="img_5c7265cdeecd7 - STYLY 交互に配置したSetBlackとSetWhite"
SetBlack and SetWhite placed alternately
In this state, when playing back the scene, the colour turns white and black alternately, synchronizing with the sound.
That’s all you need to synchronize the shader with the sound.
How to upload the asset from Unity to STYLY (For Scenes)
By uploading the Scene with the Timeline object placed, you can upload the Timeline to STYLY. Please refer to the URL below to learn more about how to upload an asset.
How to upload the asset from Unity to STYLY (For Prefab)
If you want to upload the Timeline object as a Prefab, you need to put what the Timeline object refers to, into the Prefab. The Timeline object refers to the Cube this time, so put the Cube into the Timeline object.
data:image/s3,"s3://crabby-images/ca858/ca858d03ac612eaa03694432f7d2cfcb588f215d" alt="img_5c77f014187b8 - STYLY Timelineオブジェクトの中にCubeを入れる"
Put the Cube into the Timeline object
Please refer to the URL below to learn more about how to upload an asset.
The setting for the sound to upload it to STYLY
If you uploaded a large sound data to STYLY, the changes of the shader and the sound would sometimes get out of sync because of the latency when playing back the sound. You can solve this latency by using the setting shown below; Use the ‘.wav‘ sound file; Check ‘Load in background‘ (i.e. load the sound with the other thread); Set ‘Compression Format‘ to PCM.