Summary
I explain how to render a masked rotating image.
data:image/s3,"s3://crabby-images/bed2b/bed2b256375f71d5b44aa13681d205318ae962eb" alt="1_overview - STYLY 回転する画像にマスクをかける表現"
Masked rotating image
Samples
The sample project – GitHub
The sample project – STYLY GALLERY
Masked rotating image
Rotate a texture
Firstly, create a rotating image as shown below.
data:image/s3,"s3://crabby-images/acf51/acf51a2c7a6d8c0b76cbe15cdf244a031257a6e9" alt="1 - STYLY 画像を回転させる"
Rotate an image
Mask a texture
The ‘Mask’ effect is to show the part of the texture where the mask image is white, while it hides where the mask image is black.
data:image/s3,"s3://crabby-images/0f769/0f7698eccbebd8a7d3d608abd8743d29894a030a" alt="img_5bfd529c84a31 - STYLY 回転マスク 概要"
Schematic chart – Masked rotating texture
The result – A masked rotating image
It gives the result shown below.
data:image/s3,"s3://crabby-images/cad52/cad52bb7c34cb9621d50025143a1755b25f25628" alt="2 - STYLY 回転テクスチャにマスクをかけた結果"
The rotating texture with ‘Mask’ applied.
You can make various expressions by replacing the texture.
data:image/s3,"s3://crabby-images/7ce94/7ce943fbba8c9acee6e795420a047269bdf73782" alt="sample - STYLY テクスチャの他の組み合わせ"
Various combinations of textures
I picked up those textures from the sample project in GitHub.
Create a masked rotating image
Let’s create a masked rotating image with Unity.
Textures used
The following two textures are used in this tutorial. Download them and add them to the project file.
data:image/s3,"s3://crabby-images/9ef7a/9ef7ad2ea060649aff3ef8385ec4a436150534b7" alt="intensive_line - STYLY ベーステクスチャ"
ベーステクスチャ
data:image/s3,"s3://crabby-images/ac553/ac553ef2581c0805e45179a3027210f479bdd05b" alt="マスク用テクスチャ rect.png - STYLY マスク用テクスチャ"
マスク用テクスチャ
Create a board
Crate a board by selecting ‘Create > 3D Object > Plane’ in the Hierarchy window.
data:image/s3,"s3://crabby-images/8b841/8b841e8bb8fd4dcc956baf79dd07b47df841c664" alt="img_5bfd54e11b12a - STYLY Planeオブジェクトの作成"
Create a Plane object.
data:image/s3,"s3://crabby-images/51a45/51a45c8ebe524130232b9e315b94bf39cd648b42" alt="img_5bfdc80a69419 - STYLY 作成したPlaneオブジェクト"
The Plane object created
Create a Shader
To mask the texture, we use a shader available in Unity. Click the Create button on the project tab and select ‘Shader/Unlit Shader’ to create a shader file.
data:image/s3,"s3://crabby-images/3c38d/3c38d2698f214b297f7ec574c60f4bd0d0c1978d" alt="img_5bfd56c076c4e - STYLY シェーダーファイルの作成"
Create a shader file
data:image/s3,"s3://crabby-images/e6d9d/e6d9d9e153dd5cf1d98e838f052f102194dcd803" alt="img_5bfdbcc0bd9da - STYLY 作成したシェーダーファイル"
The shader file created
Open the shader file created and paste the code shown below and save the file.
Shader "STYLY/Examples/RotationMask" { Properties{ _Color("Color", Color) = (1,1,1,1) _OverTex("Base Texture (RGB)", 2D) = "white" {} _MaskTex("Mask Texture (RGB)", 2D) = "white" {} _RotationSpeed("Rotation Speed", Float) = 1.0 } SubShader{ Tags { "RenderType" = "Opaque" } LOD 200 CGPROGRAM #pragma surface surf Standard fullforwardshadows #pragma target 3.0 sampler2D _MaskTex; sampler2D _OverTex; struct Input { float2 uv_MaskTex; float2 uv_OverTex; }; float _RotationSpeed; fixed4 _Color; #define ANGLE (_Time.z * _RotationSpeed) void surf(Input IN, inout SurfaceOutputStandard o) { fixed4 mask = tex2D(_MaskTex, IN.uv_MaskTex); clip(mask.r - 0.5); // do not draw if mask.r is less than 0.5 fixed2 center = fixed2(0.5, 0.5); float2x2 rotate = float2x2(cos(ANGLE), -sin(ANGLE), sin(ANGLE), cos(ANGLE)); fixed2 uv_OverTex = mul(rotate, IN.uv_OverTex - center) + center; fixed4 over = tex2D(_OverTex, uv_OverTex); fixed4 c = mask * over * _Color; o.Emission = c.rgb; } ENDCG } FallBack "Diffuse" }
Create a material
Right-click the shader and select ‘Create/Material’ to create a material.
data:image/s3,"s3://crabby-images/f9cc7/f9cc7117404ea6afa3964020b114ae1d2e36cdb4" alt="img_5bfdbd8a05b2c - STYLY マテリアルの作成"
Create a material
data:image/s3,"s3://crabby-images/500b2/500b26e1736c9003423cd84118941079d01e29ee" alt="img_5bfdbe42c2b79 - STYLY 作成したマテリアル"
The material created
Assign textures to the material
Assign the base texture and the mask texture to the material created. Select the material created earlier.
data:image/s3,"s3://crabby-images/3f80e/3f80e47b5ff3f9fb9b04b73400ea4a4e8b6f44a1" alt="img_5bfdbf3171bf6 - STYLY マテリアルをクリック"
Click on the material.
To prevent the Inspector from changing when selecting another asset, lock it by clicking the key icon in the top-right corner.
data:image/s3,"s3://crabby-images/96695/96695978e965d0b7a00f5db6df7df01e254f66c1" alt="img_5bfdc25bb6a41 - STYLY 鍵アイコンをクリックしてロック状態にする"
Lock by clicking the key icon.
data:image/s3,"s3://crabby-images/66a4c/66a4c1267874e347bcc0ea08f2db3733fc2db893" alt="img_5bfdc2a6e1b8b - STYLY Inspectorタブのロックがかかった状態"
The state with the Inspector tab locked
Drag the textures onto the Inspector to assign them to the material.
data:image/s3,"s3://crabby-images/9184e/9184e7c32e31435d51ca9e00ca839f9e95cfac1a" alt="img_5bfdc08ff3eaa - STYLY テクスチャのマテリアルへの登録"
Assign the textures to the material.
That’s all for the setting of the material.
data:image/s3,"s3://crabby-images/926a7/926a7f1eb9d621e120e7b0ecc69d08f550951156" alt="img_5bfdc98e456f8 - STYLY テクスチャ登録後のマテリアル"
The material with the textures assigned
Assign the material to the Plane object
Drag the material into the board created earlier (the Plane object) to assign.
data:image/s3,"s3://crabby-images/ce444/ce4448b71a0d5159be6de1f895f5c2252add73e2" alt="img_5bfdc8d21c2b1 - STYLY Planeオブジェクトへのマテリアル登録"
Assign the material to the Plane object.
Completion
It completes the masked rotating image.
data:image/s3,"s3://crabby-images/17b30/17b3078bfd44a727fb3adf968200802f605dfa45" alt="result - STYLY マテリアルの適用結果"
The appearance after applying the material.
Edit the rotating mask
Change the colour
Let’s change the colour of the rotating mask. Select the colour of the material to change the colour.
data:image/s3,"s3://crabby-images/7a224/7a2245f0727f2e9ba07f8839f05a963379aa4ddd" alt="img_5bfdca849f4f3 - STYLY 色のクリック"
Click the colour box.
Set it to yellow as shown below.
data:image/s3,"s3://crabby-images/e3c5f/e3c5fab52056794e86e64f7e154caa1502895837" alt="img_5bfdcad215a5c - STYLY 黄色を設定"
Set the colour to yellow.
The whole board has been coloured in yellow.
data:image/s3,"s3://crabby-images/2462b/2462b888a2a07623c90f2c727e58a41658e1ad6d" alt="img_5bfdcb9e765b1 - STYLY 色の変更結果"
The result – the colour has been changed.
Upload it from Unity to STYLY
Please read the article below to learn how to upload the object created in Unity to STYLY. https://styly.cc/ja/manual/unity-asset-uploader/