VRChat 마이너 갤러리 저장소

제 목
일반 VRChat 유저를 위한 잡다한 Shader 강좌 <2>
글쓴이
포동포도
추천
9
댓글
1
원본 글 주소
https://gall.dcinside.com/vr/219638
  • 2019-07-13 13:53:09
 

강좌 1편

한국에서 자주 쓰는 셰이더를 소개하면서

그림자나 음영 효과를 주는 방법을 배웠다.

https://gall.dcinside.com/mgallery/board/view/?id=vr&no=218156&exception_mode=recommend&page=1


==============================


오늘 강좌는 저번 편에 소개했던대로

Standard 셰이더에 대해 배워보면서

많은 기능에 대해 배워보려고 한다.


이 기능들은 Standard뿐만 아니라

많은 셰이더들에도 포함된 기능이므로

지금 알아뒀다가 써먹도록 하자.


==============================


1. Standard 셰이더란?


저번에 설명했던 대로 PBR 셰이더라서

현실적으로 표현할 수 있는 셰이더중 하나이다.

VRChat에서는 월드, 아바타 소품 등에 자주 쓰며

금속 재질의 아바타나 물건 등에도 쓴다.


==============================


2. Rendering Mode에 대해서


저번 강좌에는 Transparent와

Opaque 두 개만 배웠는데


Opaque는 아바타 얼굴같은 불투명 물체에 쓰고

Transparent는 홍조같은

반투명 물체에 쓴다는건 기억했으면 좋겠다.



Standard에는 저쪽 빨간색으로 표시한 부분에 있다.

기본적으로는 Opaque다.


Assets의 이미지를 끌어서 Albedo 옆 네모칸에 넣거나

Albedo 옆 동그란 부분을 눌러 이미지를 검색해 넣을 수 있다.

Albedo는 Main Texture라고 생각하면 쉽다.



사용된 이미지는 아래쪽은 검은색이지만

위쪽은 흰색이 아니라 갈수록 투명해지는 그라데이션이다.


하지만 Opaque는 불투명한 물체를 표현할 수 있으므로

투명한걸 표현할 수 있는 Rendering Mode를 찾아야 한다. 









Cutout로 바꾼 모습. 

일부분의 투명한 부분이 잘려나가

감춰져있던 하늘색 타일이 드러났다.


Cutout의 역할은 텍스쳐 내에

불투명과 투명이 섞여있는 이미지의 투명한 부분을

완전히 투명처리 하여 보이지 않게 한다.


이 때, 같은 투명이라도 조금 투명한 부분과

많이 투명한 부분이 있을 텐데

이를 투명한 정도를 나타내는 알파(Alpha)값으로 수치화할 수 있다.




Alpha Cutoff을 크게 했더니 약간 투명했던 부분까지 잘려나갔다.

반대로 작게 한다면 투명한 부분이 많이 잘려나가지 않을 것이다.


뭔가 심볼이나 그룹 마크를 넣고 싶을 때 자주 쓴다.












이번에는 Fade.


Cutout는 투명한 부분이 Alpha cutoff 수치를 기준으로 잘려나갔다면

Fade는 투명한 부분의 음영이 나타나면서 Alpha가 0인 부분(완전 투명)은

완전히 보이지 않게 된다.


아바타에 신발을 신겼더니 발바닥이 신발을 뚫고 나올 때

Fade 방식을 써서 아바타 발바닥을 투명화시켜 해결하는 방법이 있다.








Fade는 Alpha cutout가 없는 대신

Albedo의 Color탭을 눌러 팔레트 아래쪽

A 오른쪽의 스펙트럼을 조절하여

Albedo 텍스쳐의 알파값(투명한 정도)을 임의대로 조절할 수 있다.


Alpha값을 255(흰색)에서 77로 낮췄더니

바닥이 더 투명해져 거의 보이지 않게 됐다.


Alpha값은 Albedo(Main Texture)의 투명도를 조절하지만

Rendering Mode가 Opaque라면 투명도를 조절할 수 없다.













이건 Transparent로 바꾼 결과.

Fade와는 다르게 약간 유리같이 되어있다.


Transparent는 투명한 부분 중에서도

약간 반투명한게 있을 때 사용한다.

홍조 마테리얼에 쓰는 이유도

홍조 가운데는 투명도가 0으로 불투명하지만

끄트머리로 갈 수록 투명도가 255로 점점 투명해지기 때문이다.


사진이 잘 안보이므로 가까이에서 확인해보자.










주변의 빛을 반사하는 모습이다. 따라서 아크릴 판처럼 보인다.

Fade의 완전 투명을 표현하기보다는

유리창이나 물 등을 표현하는데 쓴다.













왼쪽이 Fade다. 갈수록 아예 보이지 않게 되는 모습이다.

Fade는 빛의 반사가 없는 물체를 그릴 때 쓴다.










==============================


3. 금속 재질 표현하기



Albedo에 텍스쳐 하나만 입힌 모습이다.


금속처럼 보이기엔 여전히 무리가 있어보인다.








Metallic을 살짝 올려줬더니 빛의 반사가 일어나면서

금속 재질이라는 느낌이 훨씬 들기 시작한다.


아래쪽 특히 가장 밝은 부분은 하이라이트(Highlight)라고 생각하면 좋다.

이 반사는 일반적인 빛 뿐만 아니라 Skybox의 빛도 포함하는데

수치가 커질수록 Skybox의 빛을 더 반사하며

그만큼 Albedo의 색을 감소시킨다.


따라서 Metallic은 수치가 커질 수록 금속이기보다는

거울의 느낌에 가깝다고 볼 수 있는 것이다.



Metallic에 쓸 이미지에 적색은 Metallic 값을 결정하고

투명한 정도의 알파값은 smoothness를 결정한다.

하지만 VRChat에서 이를 위해 이미지를 직접 수정하면서

만들기란 여간 귀찮은게 아니다. 이건 생략해도 좋다.











Smoothness는 대상의 표면적인 부드러움을 결정하는데 

Smoothness가 커질수록 하이라이트가 커진다.


Smoothness 아래쪽의 Source는 Smoothness의 값을

어떤 텍스쳐의 Alpha에서 가져올 지 설정하는데

보통 Metallic Alpha를 사용하기도 하고

VRChat에선 그닥 사용하지 않는 옵션이다.









셰이더를 바꿔서

Standard (Specular Setup)을 썼더니 Metallic가 사라지고

Specular가 생겼다.


옆의 팔레트에서 V값을 조절하여 반사의 강도를 조절하는데

작을수록(검은색) 반사가 희미해지고 클수록(흰색) 반사가 강해진다.


Specular에 들어가는 이미지는 흑백 이미지를 써야 하며

이 또한 검은색 흰색에 따라 반사의 강도가 조절된다.






Metallic와 Specular(Roughness로 표현되기도 한다)를 적절히 조절하면

금속 재질을 충분히 표현할 수 있을 것이다.





==============================


4. 평평한 물체 표면에 높낮이가 있어보이는 효과 주기




Normal에 Albedo에 썼던 같은 이미지를 넣었더니

뭔가 수정해야한다면서 Fix Now를 누르라고 한다.


유혹에 넘어가 그냥 누르지 말고 Albedo에 썼던 이미지를 복사한 다음

Normal Map에 넣어야한다. Fix Now를 누르면

Normal Map 이미지를 만드는 과정이 진행되면서 이미지의 색이 바뀌기 때문이다.


이미지는 RGB보다는 흑백 이미지로 해야 Normal Map를 만들 때 효과가 좋다.


Normal Map를 넣었더니 평평했던 이미지에 높낮이가 추가되면서

빛의 정반사와 난반사가 일어나 표면이 입체적으로 보이게 된다.


이 효과는 낮은 품질의 텍스쳐를 더 좋아보이게 만들거나

낮은 폴리곤의 금속 물건을 울퉁불퉁하게 만들어

조금 더 고퀄리티의 고폴리곤 물건처럼 보이게 할 수 있는 것이다.












Height Map는 높이가 있는 것 처럼 표현하는 방식이 아니라

실제 높이를 설정하여 그에 따라 그림자가 생겨 명암을 주는 방법인데


Height Map에는 흑백 텍스쳐가 들어가며

흰색일수록 높이가 커지고 검은색이면 높아지지 않는다고 생각하면 된다.


높낮이 차이가 적은 철판보다는

돌 담벼락을 표현하는 데 효과적이다.










Occlusion은 표면의 돌출을 빛으로 나타내게 해주는데

역시 흑백 이미지를 사용하며 흑색일수록 어두워진다.


빛을 받기 어려운 부분이 있는 물체를 표현하는 데 쓴다.





==============================


5. 어두운 곳에서도 밝게 하기



이건 Standard 말고도 다른 셰이더에서도 쓸 수 있다.

Emission의 색을 지정해주면 지정한 색대로 밝게 빛난다.

다만 색만 지정했으므로 아바타 전체가 붉게 되어버렸으니

Emission Map를 만들어 빛나게 할 부분과

그렇지 않은 부분을 만들어줘야 한다.







빛나게 하지 않을 부분을 검은색으로 칠하고

빛나게 할 부분을 남겨뒀더니 부분적으로 빨간색 빛이 칠해졌다.


Global illumiation을 Realtime으로 설정하면

emission으로 방출되는 빛이 실시간으로 적용되어

근처 오브젝트를 밝게 만들지만

Baked로 설정하면 Static이라는 거의 움직임이 없는

오브젝트에만 영향을 주게 된다.


최적화를 위해선 Baked로 해두는게 좋을 것 같다.


==============================


6. 패턴 만들기 



Tiling X에 5, Y에 5를 입력했더니

X축 5개의 텍스쳐, Y축에 5개의 텍스쳐가 더 생겨

타일 패턴을 만들었다.


쓰는 이유는 오브젝트의 Scale이 클 때. 크기가 커질 수록

텍스쳐도 같이 늘어나기 때문에 이를 이용하는 것이다.


사용된 텍스쳐가 가장자리가 서로 이어지는 타일 텍스쳐가 아니라서

이상한 부분이 조금 있지만 Tiling 전용 텍스쳐를 쓴다면

어색한 부분이 없을 것이다.




==============================


Secondary Maps와 Detail Mask는 물체를 근접하여 봤을 때

정교한 표현을 위해 쓰는 것으로 기존 텍스쳐에 중복 적용되는 텍스쳐다.


하지만 VRChat에서 잘 쓰는 편도 아니고 마테리얼이 무거워진다.


==============================






이번 강좌의 핵심은 Rendering Mode와 금속 재질의 표현, Emission이므로

Standard 셰이더 말고도 다른 셰이더에서도 찾아볼 수 있으며

VRChat에서 자주 쓰는 기능이기도 하다.


궁금한거나 원하는 내용이 있으면 덧글로 신청했으면 좋겠고

지금까지의 과정은 생각보다 어려운건 아니니 잘 이용해주길 바란다.



딜런 2019.07.13 13:53:21
번호 분류 제목 글쓴이 날짜 추천
219805 일반 무슨짓을해도 그림자가 안사라지네여 3 구케 2019-07-13 0
219804 일반 오 뭐야 이제 댓글 코드 없어졌네?? 1 ㅇㅇ 175.114 2019-07-13 0
219803 일반 스타킹에 고양이 그려놨당 2 verdani 2019-07-13 0
219802 일반 얼리버드 취침인 거시다! 1 양산형이세계물 2019-07-13 0
219801 일반 휴대폰에 우유 부워버림 ; 8 카디아. 2019-07-13 0
219800 일반 새로운 아바타용 바디 중간단계 7 쿰척쿰척 2019-07-13 0
219799 강좌/정보 미세팁) 포이요미 쉐이더 그림자없애기 4 가상여행 2019-07-13 1
219798 일반 칭구하자 1 sing)Hana 2019-07-13 0
219797 일반 그림자 텍스쳐빼도 그림자생겨요.. 2 구케 2019-07-13 0
219796 일반 파딱이 주딱차단할수있잖아 ㅇㅇ 39.7 2019-07-13 0
219795 일반 이게임이 cpu를 잘갈구는 게임이었나 2 cold 59.22 2019-07-13 0
219794 일반 무슨일이 있었던 거야? 6 みなみ 2019-07-13 0
219793 질문 대기모션 필요한데.. 제작가능하거나 배포해주는곳 있나요? 3 _YUJIN_ 2019-07-13 0
219792 일반 검은연 하야 ㅇㅇ 175.223 2019-07-13 0
219791 일반 이 아바타 이름좀... ㅂㅂ 115.86 2019-07-13 0
219790 일반 ?-? 자다가 왔는데 봉하마을에서 정모함? 1 커피존맛탱 2019-07-13 0
219789 일반 포이요미 그림자 질문 7 구케 2019-07-13 0
219788 일반 트래커 7개다는 상상 해봣는데 카디아. 2019-07-13 0
219787 일반 트래커 7개 지원되면 조켔따 일레임 2019-07-13 0
219786 일반 나도 바쁘고 피곤해서 브얄챗 안하게되고 팔까했는데 1 혀뇽 2019-07-13 0
219785 일반 야식타임 2 V 2019-07-13 0
219784 일반 닉네임 바꾸면 세탁 씹가능??? ㅇㅇ 223.38 2019-07-13 0
219783 일반 갤 하는 꼬라지가 웃대 보는거같누 ㅇㅇ 110.70 2019-07-13 0
219782 일반 일요일 출근하는 라무네.. 6 혀뇽 2019-07-13 0
219781 일반 이거 ㅅㅋㅋ 누가 저격햇을때인데 ㅇㅇ 117.111 2019-07-13 0
219780 일반 브이알챗은 브이알 쎋스를 하기 위한 게임 1 ㅇㅇ 218.147 2019-07-13 0
219779 일반 브얄 걍 팔아버릴까 18 (윤이) 2019-07-13 0
219778 일반 훼리아 제작자한테 메세지가 왔어 3 ㅇㅇ 182.226 2019-07-13 0
219777 일반 자동으로 눈깜박이는거 어떻게함? 1 ㅇㅁ 119.195 2019-07-13 0
219776 일반 여기 디씨 공식 ㅈ목방임? ㅂㅂ 115.86 2019-07-13 0
219775 일반 좆목이 여기하고 디코만 있던게 아니네 3 ㅇㅇ 125.180 2019-07-13 0
219774 일반 오늘자 '그 그룹'정모 모집내용 이었던것 2 ㅇㅇ 182.231 2019-07-13 1
219773 일반 새로운 모델 머리조형 2 쿰척쿰척 2019-07-13 0
219772 일반 나 잘건데 가슴만지는 꿈 꿀거임 2 딜런 2019-07-13 0
219771 일반 브알챗하면서 이거 나만이럼? 4 발도참 2019-07-13 0
219770 일반 그 그룹 정모 갔다가 ㅈ같아서 짤뿌린다 3 티나은챙 2019-07-13 4
219769 일반 코드모야 1 ㅇㅇ 39.122 2019-07-13 0
219768 일반 저댄 열심히 했더니 배가아파 2 혀뇽 2019-07-13 1
219767 일반 현실 친구들 있는데 계속 인터넷 친구랑만 만나는건 뭐임;; 2 ㅇㅇ 223.38 2019-07-13 0
219766 일반 부랄챗 트래커 몇개부터 지원해? 2 ㅂㅂ 115.86 2019-07-13 0
념글 삭제글 갤러리 랭킹