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
번호 분류 제목 글쓴이 날짜 추천
401010 일반 지금일어남 2 반다이몰 2020-04-22 0
401009 일반 h방가쟈 5 다히냥 2020-04-22 0
401008 일반 미취학아동 마이너 갤러리입니다. 4 ㅇㅇ 125.129 2020-04-22 1
401007 일반 아바타 3.0은 또 뭐임 4 ㅇㅇ 175.203 2020-04-22 1
401006 일반 오늘의 움짤 1 세이렊 2020-04-22 0
401005 일반 퍼블릭 야본역에서 야스뜨노..JPG 4 のむくん 2020-04-22 0
401004 일반 라이젠 1600 970 램16이다 ㅁㄹㄴㅌㅁㅈ 2020-04-22 0
401003 질문 이거 아바타 3인칭되는데 왜이럼? 9 ㅇㅇ 121.139 2020-04-22 0
401002 일반 븡모닝 12 노라 2020-04-22 1
401001 일반 좋은 아침~ 연병장이야 ㅎ 13 ㅇㅇ 175.203 2020-04-22 4
401000 일반 야 체조하자며; 8 ㅇㅇ 182.221 2020-04-22 0
400999 일반 아니 왜 970무시해 20 ㅁㄹㄴㅌㅁㅈ 2020-04-22 0
400998 일반 흑백맵 돌아다니는 재미가 있네 3 세할디아 2020-04-22 0
400997 일반 이번년도안에 2세대mr 나오겠지? 7 ㅇㅇ 112.145 2020-04-21 0
400996 일반 컴퓨터까지 바꿔야하면 예산 오버네.. 13 헬시오네 2020-04-21 0
400995 일반 곤약넘좋음 5 ㅇㅇ 59.31 2020-04-21 0
400994 일반 지금일어남 3 컵밥 2020-04-21 0
400993 일반 쓉 풀트랭 할려면 컴도 좋아야해?? 10 헬시오네 2020-04-21 0
400992 일반 풀트묵언친구 잇엇는데 2 운이 2020-04-21 0
400991 일반 안뇽 조은 아침 10 SeoYi 2020-04-21 0
400990 일반 브갤 최고 퍼지 3 빅몬 2020-04-21 0
400989 일반 풀 트래킹 VR 하나 장만 하고 싶은데 10 헬시오네 2020-04-21 0
400988 일반 건망증이너무심해요 5 ㅇㅇ 223.33 2020-04-21 0
400987 일반 ㄹㅇ시골같은데서 살고싶다 9 블프 2020-04-21 0
400986 일반 세젤퍼 3 빅몬 2020-04-21 0
400985 일반 vrc속보! 모션 인식지연 픽스됨 3 세이렊 2020-04-21 0
400984 일반 vr챗에 생겼으면 하는 버그 4 ㅇㅇ 112.145 2020-04-21 0
400983 일반 갤글에 이거 설명된것도있음? 3 SEGAMI 2020-04-21 0
400982 일반 메리노 작가 트윗 구글번역에 브이켓 맞춰서 낸다고 나왔던데 1 ㅇㅇ 221.145 2020-04-21 0
400981 일반 브모닝 5 아르♡페 106.101 2020-04-21 0
400980 일반 오늘 하루는 영어를 할 줄 아는 게 화가 난다 9 epimehyun 2020-04-21 1
400979 일반 어떤사람은 픽스드조인트같은거 막 존나어려운거처럼 말하더만 4 SEGAMI 2020-04-21 0
400978 일반 VRChat 속보! 2 ㅇㅇ 175.203 2020-04-21 28
400977 일반 우효갤 보플 개웃기네 ㅋㅋㅋㅋ 2 Artpe 2020-04-21 0
400976 일반 오늘 브알도 재미있었서 10 ㅇㅇ 125.176 2020-04-21 0
400975 일반 과몰입 하지마라 1 ㅇㅇ 211.54 2020-04-21 0
400974 일반 내가 브붕이들을 VRC에서 본적이 있을까요? 2 xKiD 2020-04-21 0
400973 일반 위이이잉 1 반다이몰 2020-04-21 0
400972 일반 9시 체조할사람 모여랑 2 반다이몰 2020-04-21 0
400971 일반 브붕이 오랜만에 혼자 체조 했다 10 으ㅡ음 2020-04-21 0
념글 삭제글 갤러리 랭킹