In this article, I am going to introduce how to create a three-dimensional sound waveform from a sound waveform video, without using scripts. We will use 3 softwares, but it’s not so difficult so I hope you find this article helpful!
Overall flow
Create a sound waveform video → Create a Cube in Blender and divide the polygons → Create a shader → Implement in Unity
Note 1: I used AviUtl for editing videos in this tutorial
Note 2: I used the Japanese version of Blender in this tutorial
data:image/s3,"s3://crabby-images/2c32c/2c32c859c7ca703d23c67079bf8b6f806f7f8a82" alt="立体音声波形 - STYLY 立体音声波形"
three-dimensional sound waveforms
Sample
The Unity project that I introduce in this article can be downloaded from here.
The “rittaionseihaikei” folder in “STYLY_Examples” is the one we are going to use.
STYLY_Unity_Examples
Create a sound waveform video with AviUtl
( You can use any video edit software if you can create a sound waveform video) Please confirm that X264 is installed here.
Insert the audio file and the sound waveform
Create a project, select the resolution size ( I used 240×240 so that the file size remains small ). Then, drag and drop the audio file into the scene. Next, right click in the Adv.Edit window and insert the sound waveform from insert media object.
data:image/s3,"s3://crabby-images/dc568/dc5684e4e49e07fe7168f71dcb0fbd1a4408fab9" alt="aviutl onseihakei - STYLY aviutlでの音声波形作成動画1"
Creating a sound waveform video in AviUtl
Edit the expansion rate and wavelength height so that the soundwave fits the screen size.
data:image/s3,"s3://crabby-images/75c26/75c26e191c36f66a4cfae4c9a6041393f64232d9" alt="aviutl onseihakeui - STYLY 音声波形のサイズ調整"
Adjusting the sound waveform size
Export the video
Export the video using x.264.
Creating a object to use for the three-dimensional soundform with Blender
In order to express the soundform in 3D, we need to divide the Cube’s polygons
First, press Shift + A, select Mesh, and create a Cube.
data:image/s3,"s3://crabby-images/824fe/824fe7a5bc28b906b54c2db22c31d2146ce445a7" alt="blender キューブ作成 - STYLY blender キューブ作成"
Creating a Cube in Blender
UV deployment
Change to Edit mode from Object mode, press A to select all, and press Ctrl + E to mark seam.
data:image/s3,"s3://crabby-images/d3a4d/d3a4dfa650ba0d11390965a48c22fad7296b77d7" alt="シーム付け - STYLY シーム付け"
Mark seam
Open the UV Editing window, press u to UV edit.
Then, press I to select a face, select tool→UV tool→pack island and spread the face.
data:image/s3,"s3://crabby-images/e370b/e370bb6d8843b48eb23de2dd16f3c33f83d4308f" alt="UV展開と島の梱包 - STYLY UV展開と島の梱包"
UV editing and packing island
Subdivision surface modifier
Return to the default screen, select the subdivision surface modifier in modifiers. Apply simple, pull up the view to 6, apply the modifier and divide the polygon. ( In order to see the waveform shape, I divided over 20000 cuts )
data:image/s3,"s3://crabby-images/2a56e/2a56e0e980f010a2ab6372556b2a0d725e3c0001" alt="細分割曲面でポリゴンを割る - STYLY 細分割曲面でポリゴンを割る"
Divide polygons using the subdivision surface modifier
Once you confirmed that the polygons are subdivided, export the object as a FBX format.
Create a shader in Unity
Import shader forge ( Which you can download from here → https://github.com/FreyaHolmer/ShaderForge ), and create a shader that changes the vertex position according to the texture color, as in the image below.
data:image/s3,"s3://crabby-images/e5194/e51947caff7f9f4da7f25fe1d7af9b3e26e87dc2" alt="立体音声波形用のシェーダー - STYLY 立体音声波形用のシェーダー"
Shader for 3D soundform
It is included in the sample project, so you can just download it from there.
Create a 3D Sound waveform
Now, we are going to create a three-dimensional sound waveform in the Unity scene.
Preparation
Import the soundwave video and the Cube object from previous steps, and create a material with a Unlit/Texture shader applied.
Next, insert a Quad into the scene to use to display the audio soundwave.
data:image/s3,"s3://crabby-images/6cdfa/6cdfaaa14d6e6a8777d04c21de17bfa3036078e3" alt="QuadにVideo playerを追加 - STYLY QuadにVideo playerを追加"
Attach a Video player to the Quad
Create a GameObject, click Add component and select Audio Source. Set the GameObject as a child of the Quad, and add a GameObject to the Quad’s Video Player Audio Source. ( So the sound from the video can be heard )
data:image/s3,"s3://crabby-images/adb5e/adb5e175dde32cd334eb30a8e410fe978186725f" alt="audio sorceの追加 - STYLY audio sorceの追加"
Make the sound of the video hearable
Apply a material with Unlit/Texture applied to the Quad, so that the soundform video will not be affected by lighting.
data:image/s3,"s3://crabby-images/03924/0392413dc5a371ee101e4ae11c0c41f13b798efd" alt="unlitシェーダーを適用 - STYLY unlitシェーダーを適用"
Apply the Unlit shader
Add a camera, and move it so that the Quad is shown on it. Then, change Clear Flags to Solid color, and change the Background color to black. ( This is so that it will not be affected by the sky box colors )
data:image/s3,"s3://crabby-images/2fabc/2fabc0b4fc7c7411837a0380b4277183b78d793e" alt="cameraの設定 - STYLY cameraの設定"
camera settings
Create a Render Texture for the 3D sound waveform
Create a Render Texture within the project, and attach it to the Camera’s Target Texture. Set the Render Texture size as 720×720 ( Any size is ok if it is not too small ).
data:image/s3,"s3://crabby-images/34eba/34eba095fa18631ccae92c27f06cd6f29fc3857c" alt="Render Textureをカメラに適用 - STYLY Render Textureをカメラに適用"
Applying the Render Texture to the Camera
Creating a 3D sound wavefrom
Create a material for 3D sound waveform, and apply the shader you created using shader forge to it.
Then, add the Render Texture to the Material inspector.
data:image/s3,"s3://crabby-images/55dee/55dee6ee21e602b9e8409d4ba8f49257eba9b27d" alt="マテリアルにRender Textureの適用 - STYLY マテリアルにRender Textureの適用"
Applying Render Texutre to the material
The 3D sound waveform is complete! Good job!
It might have been difficult a bit, but by understanding the process, you can utilize your knowledge and create any form of 3D sound waveforms!