VRChat 마이너 갤러리 저장소

제 목
강좌/정보 VRChat 유저를 위한 잡다한 Shader 강좌 <1>
글쓴이
포동포도
추천
14
댓글
6
원본 글 주소
https://gall.dcinside.com/vr/218156
  • 2019-07-10 22:45:30
 


원래 셰이더 강좌 순서대로라면

셰이더를 하나씩 소개하면서 그에 따른 기능을 소개하는거였겠지만


오늘 유동이 분탕친것도 있고 내가 요즘 낮시간엔 바빠져서 시간관계상

VRChat에서 자주 쓰는 셰이더를 소개하기도 하고

대략적으로 (수치를 임의적으로 수정하지 않은)특징과

어떤 환경과 소품, 아바타에 써야하는지 등에 소개하고자 함.


이 강좌는 시리즈물로써 일주일마다 1~2회씩,

3~10개 정도의 단원으로 내용을 분류하여 올릴거임.


처음에는 기본적이거나 자주 겪는 실수 등을 쓸거고

점점 어려운 내용이나 화제가 되는 셰이더 등에 대해 쓸 계획.


물론 쓸데없는 잡다한 정보도 많이 쓸거다.



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


1. VRChat에서 자주 쓰는 Shader의 구분



일단 크게 3가지로 셰이더를 구분했고 용도도 구분할 수 있다.

초록색 글씨, 노란 글씨, 회색 글씨로 구분했는데


초록색 글씨는 PBR 셰이더거나 그에 가까운 것으로

물리 기반 셰이더라고 보면 된다.


물체의 현실적인 빛반사와 그림자가 특징으로

사진에서 볼 수 있듯이 그림자의 음영이 현실적이다.

햇빛으로 인해 그림자가 지고

바닥 부분은 땅에서 반사 된 빛으로 인해 살짝 밝게 되는 모습.


용도로써는 현실적인 느낌과 금속재질의 표현 등이 대표적으로

아바타보다는 월드나 아바타에 넣는 소품류에 이용된다.





노란 글씨는 툰(Toon) 셰이더로 NPR 셰이더에 속한다.

뚜렷하고 단조로운..단계적인 그라데이션 음영으로

2D 느낌도 나고 3D 느낌도 나는 표현이 많다.

거의 아바타에 쓰는데 월드 테마에 따라선 월드에다가도 넣는다.





회색 글씨는 조금 특수한 경우로

unlit 셰이더는 빛의 영향을 받지 않는다.

불투명 물체를 표현할 땐 Unlit/Transparent를 사용하면 되는데

월드의 UI, 아바타, 아바타의 이펙트 등에 고루 이용된다.


다만 밝은 월드에 가면 아바타가 잘 안보이거나

다른 사람들이 봤을 때 눈이 아플 정도로

빛나는 경우가 있어 주의해야한다.





이용한 셰이더는 이렇다.

Standard

Unlit/Texture

UnityChanToonShader/Toon_DoubleShadeWithFeather (2.0.7 버전)

Poiyomi/Master/Opaque

arktoon/Opaque

Reflex Shader 2/Reflex Shader 2





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


2. Transparent와 Opaque


초보자라면 무조건 겪었을 위 사진은

Transparent와 Opaque의 존재를 몰라 겪는 일이다.






짤 하나로 요약된다. 불투명한건 opaque shader,

투명한건 transparent shader로 처리한다.


투명한건 alpha(알파)값이 있다고들 한다.

alpha가 클수록, 보통 255에 가까울수록 불투명하고

0에 가까울수록 투명해지는거다.


투명한 물체는 mmd아바타의 홍조가 대표적이다.


셰이더에 따라

셰이더를 선택하는 탭에서

위 두가지 셰이더 중 하나를 선택해 적용하든지


셰이더 인스펙터 내에서 Rendering Mode 탭에서 설정해

적용하는 경우(Standard Shader)가 있다.


대부분은 셰이더를 선택할 때 Opaque와 Transparent중 하나를 선택해 적용하는 방법이다.



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









3. UnityChanToonShader가 이상해요


메인 텍스쳐 하나만 집어넣고 비교한 사진.


근데 UnityChanToonShader(이하 UTS)가 이상하다.




이럴 땐 사진에 보이는 1st ShadeMap에 텍스쳐를 넣어주면 된다.

2st ShadeMap에는 굳이 텍스쳐를 넣을 필요는 없고 색깔만 조절해주면 된다.









이제 UTS도 정상적으로 보이기 시작한다.








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






4. PBR, NPR, Unlit 셰이더 비교


로봇은 뭔가 차이점이 별로 안보여서 아바타를 바꿨고

큰 세가지 그룹을 한 줄로 나열했다.


PBR인 Standard는 점토같이 생겼는데

세이프티로 shader를 껐을 때

많은 아바타들은 저렇게 보이게 된다.


NPR에 속하는 Toon 셰이더인 UTS는 제법 볼만하다.


UNLIT는 빛의 영향을 받지 않아 항상 밝다.




사용된 모델은 https://einzzwei.booth.pm/items/954617

매시와 바디가 분리되어 있고 .FBX파일만 있다. 뚜따재료 비추천











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





5. Toon 셰이더의 꽃, 음영과 그림자


위 사진은 셰이더의 음영이나 그림자 설정의 잘못된 예시로

생각보다 많은 초보자가 이 문제에 대해 해결 방법을 몰라

Unlit shader를 쓰거나 아예 그림자를 없애는 경우가 있다.


하지만 아바타에 있어서 그림자와 음영을 부여하면

자연스럽고 조금이나마 생동감 있는 모습을 연출할 수 있다.








소개했던 같은 Toon 셰이더끼리 모아봤다.

Reflex Shader 2, Arktoon과 Poiyomi는 그림자로 인해 어색한 반면

UTS는 자연스러워 보기 좋은 모습.








먼저

Reflex Shader 2/Reflex Shader 2에서는 



이 부분을 건드리면 되는데

Reflex Shader 2는 빛을 받는 방향부터 순서대로

Diffuse 텍스쳐, Shadow 1, Shadow 2를 나타낸다.

쉽게 말하자면 그림자 1은 흰색, 그림자 2는 검은색일때

빛이 왼쪽에 있으면 아바타 텍스쳐>흰색>검은색 순서로 칠해진다는거다.

이것만 알면 그나마 쉽게 위 수치를 조절할 수 있다.


다만 이건 아직 제작자의 답변도 없고 설명서도 없으므로

일일이 설명하기엔 한계가 있는 것 같다.


Shadow 1또는 2 Contrast: 해당 Shadow의 강도


Shadow Contrast Toggle:

Shadow 1 Contrast과 Shadow 2 Contrast의 수치 바꿔치기,


Shadow Color: 그림자 색


Shadow Color Darken: 그림자를 흑백으로 할건지


Shadow 1또는 2 Place: 해당 그림자의 위치를 조절한다.


Shadow Mask: 그림자가 해당 텍스쳐의

검은색 부분에 생기지 않도록 제외시킨다.

아바타에 사용된 바디 텍스쳐를 통해 만들어야 하는

귀찮음과 수고로움이 있다.


사실 그림자가 예쁘게 만들어지는 것 같진 않아보인다면

간단하게 Shadow Toggle을 체크해제 하면 된다.

그럼 그림자가 사라진다. 이럴바엔 차라리 Unlit 쓴다.






왼쪽 아바타가 오른쪽 인스펙터에 나타난 대로 조절한 모습

오른쪽 아바타는 Reflex Shader 2를 그냥 적용만 시킨 모습이다.


음영을 조절함으로써 2D임에도 불구하고

입체적인 느낌을 잘 나타낸 예이다. 특히 슴1가.

사실 이 아바타 텍스쳐가 워낙 입체적이라 좋긴 하네.













Arktoon/opaque에서는Shadow탭의


Border: 그림자 두께


Strength & Mask: 그림자 강도와 흑백의 아바타 바디 텍스쳐를 넣어

그림자가 생기는 부분과 그렇지 않은 부분을 정한다.


Blur& & Mask: 그림자의 흐림 강도와 아바타 바디 텍스쳐를 넣어

그림자가 번지는 부분과 그렇지 않은 부분을 정한다.


Arktoon은 색깔을 지정하지 못한다는 점에서

그림자/음영 면에서는 아쉬운 것 같다.














UTS는 빛을 받는 방향부터 순서대로

Base Color, 1st Shade Color, 2nd Shade Color를 나타낸다.


UnityChanToonShader/Toon_DoubleShadeWithFeather에서는

대부분 [Basic Lookdevs: shading Step and Feather Settings]탭에서


BaseColor Step: Base Color와 Shade Color사이의 경계를 설정한다.


Base/Shade Feather: 기본 색상과 음영 색상 사이의 경계를 부드럽게 한다.


ShadeColor Step: 1st Shade Color와 2nd Shade Color의 경계를 설정한다.

2nd Shade Color를 사용하지 않으면 0으로 설정한다.


1st / 2nd_Shades Feather: 1st와 2nd사이 음영의 경계를 부드럽게 한다.



왼쪽이 음영만 잡은 모습이라면

오른쪽은 음영과 RimLight, Matcap, Outline 등을 추가한 모습.

이게 UTS2의 장점인데 이건 후에 있을 강좌때 설명하기로 하자.











Poiyomi/Master/Opaque

FakeLightning 탭에서 주로 이뤄진다.


lightning lamp: 음영을 입힐 텍스쳐를 넣는다.


Ramp Strength: 경사면의 강도. 자주 쓰진 않는다


Shadow Strength: 그림자 강도

Light Direction: 빛이 비치는 위치를 조절한다.


사실 poiyomi는 기본적으로 그림자 음영이 예쁘진 않다.

Shadow Strength를 0으로 하는걸 추천한다.












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


사진은 PBR 셰이더를 쓴 월드와 아바타의 모습이다.

잘만 이용하면 현실감 있는 연출을 할 수 있으나

그런 연출을 하려면 특정 월드에 가야할 필요가 있다.

Standard 셰이더는 다음 시간에 자세히 다루기로 하자.

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



딜런 2019.07.10 22:46:11
tntnt 개추 - dc App 2019.07.10 23:17:07
(≧◡≦) 2019.07.10 23:19:46
V 2019.07.10 23:30:14
ㅇㅇ 와 진짜 내가 어떻게 해야하나 고민했던 부분의 글이 딱 올라오네 개추 먹어라 진짜 감사 211.59 2019.07.10 23:34:46
ㅇㅇ 가슴골 엉덩이골표현에 유용할거같네ㄱㅅ 193.23 2019.07.10 23:36:46
번호 분류 제목 글쓴이 날짜 추천
218767 일반 해외배송 이거 이미 비행기 탓다는거야? 2 2019-07-12 0
218766 일반 지옥에 있는 딜은 나와라 1 ㅇㅇ 223.38 2019-07-12 0
218765 일반 야이 브갤 새끼드랑 22 레스티 2019-07-12 0
218764 일반 백수긴 백수인데 쿰척쿰척 2019-07-12 0
218763 일반 앰생 백수새끼들 3 ㅇㅇ 223.33 2019-07-12 0
218762 일반 같이 놀사람 들어왕 1 발도참 2019-07-12 0
218761 일반 댓글30개 달릴시 신음소리낸다 41 블프 2019-07-12 0
218760 일반 야 아침에도 물어봤는데 픽조로 더미아바타 쓰면 6 유년기의끝 2019-07-12 0
218759 일반 MMD 모델 중 야한것들도 있던데 1 PornoHub 2019-07-12 0
218758 일반 둘중에 어떤게 취향임? 17 카스테라 2019-07-12 1
218757 일반 동공 그대로인거같다 쿰척쿰척 2019-07-12 0
218756 일반 미쿠단 상시 모집중 ∩(>ヮ<)q 2019-07-12 0
218755 일반 나도 빨리 풀트래킹 하고싶어 .EUN. 2019-07-12 0
218754 일반 조센이 일본에게 저지른 일곱개의 대죄...sin 1 ㅇㅇ 110.70 2019-07-12 1
218753 일반 미셰는 아이트래킹 고장나는거 어떻게고침 2 울테 2019-07-12 0
218752 VRC일기 그제랑 어제 역대급 재밌었음 1 커피존맛탱 2019-07-12 0
218751 일반 야노퍼지쓰는 ㅇㅇ 39.7 2019-07-12 0
218750 일반 얼리 버드 기상 6 묵언소녀 2019-07-12 0
218749 일반 이캐릭 퍼블릭이눙.. 1 딜런 2019-07-12 0
218748 일반 변태들 죽어 8 혀뇽 2019-07-12 0
218747 일반 아이트래킹 되는거같음?? 4 쿰척쿰척 2019-07-12 0
218746 일반 다캡쳐햇서 3 아저게안맞네 2019-07-12 0
218745 일반 브알챗 넘 재밌어 엘렝 2019-07-12 0
218744 일반 퍼블릭은 너무 혼란스럽다니깡 5 딜런 2019-07-12 0
218743 일반 과몰입왜함ㅋㅋ 1 MiKuBoT 2019-07-12 0
218742 일반 거울로 보면 차이가 없고 거울 말고 확인할 친구도 없고 쿰척쿰척 2019-07-12 0
218741 일반 좀 어이 없는 질문인데 12 푸른꽃추종자 59.20 2019-07-12 0
218740 일반 아이트래킹 확인 어케하지 3 쿰척쿰척 2019-07-12 0
218739 일반 점심 3 tntnt 2019-07-12 0
218738 질문 VRC 마이크 질문 2 ㅁㄴㅇㅁㅇㄴ 59.24 2019-07-12 0
218737 일반 복날이 개고기 먹는날 맞지? 2 흐린바다 2019-07-12 4
218736 일반 건강한 하루 되세요 4 미래 2019-07-12 0
218735 일반 유니티 안에서 아이트레킹 따로 설정해줘야하는게 있음? 2 쿰척쿰척 2019-07-12 0
218734 일반 유니티 버전 뭐였지?? 2 verdani 2019-07-12 0
218733 일반 과몰입글 넘 웃기다 2 머쓱 2019-07-12 1
218732 일반 메리 초복☆ 2 냐르 2019-07-12 0
218731 일반 어제~새벽에 찍은거 V 2019-07-12 0
218730 일반 일단 유니티에서 손가락 본 각도 수정시켜준걸로 해결보긴했는데 2 쿰척쿰척 2019-07-12 0
218729 일반 페도되가는거같음 6 아저게안맞네 2019-07-12 1
218728 일반 사다코 보고가 1 sing)Hana 2019-07-12 2
념글 삭제글 갤러리 랭킹