일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- observer pattern
- 옵저버
- 멀티코어 프로그래밍
- Atomic
- 복사생성자
- 옵저버 패턴
- EFFECTIVE C++
- Multithread
- c++
- 유니크포인터
- vector
- 멀티쓰레드
- 멀티코어
- 메모리관리
- Design Pattern
- C
- Unreal
- 디자인패턴
- 프레임워크
- 스마트포인터
- 쓰레드
- stl
- sequential
- 한국산업기술대학교
- multi-core
- MultiCore
- random access
- thread
- material
- 게임공학과
- Today
- Total
태크놀로지
[Material] Electronic Fence Effect (Opacity Mask, 이미시브 컬러) (2) 본문
오늘목표
이미시브컬러에 Gen Pattern, Noise Pattern 추가
실습
우선 여러개의 대각선을 만들어 봅시다. u,v좌표를 더하면 대각선이 만들어집니다.
다음으로 시간변수를 더하여 여러개의 대각선 대각선 방향으로 움직이도록 합니다.
*곱하게 될시 대각선들이 엄청나게 많이 생기니 주의!
다음으로 울타리 모양에 따라 발생하는 노이즈를 추가해봅시다. 이전에 만들었던 울타리 패턴을 복사해 가져옵니다.
Glitch효과를 구현할때 만들었던 노이즈 패턴과 비슷하게 제작합니다.
우선 노이즈 텍스쳐샘플링을 불러와 타임값을 적용하여 움직이도록 해봅시다.
*Append로 중간과정을 확인할수 있습니다.
노이즈 패턴을 복사해왔던 울타리패턴에 더해서 적용해줍니다. 하지만 현재 너무 노이즈 크기가 커 어색하니, 크기를 줄이도록 합시다.
텍스쳐 샘플에 power를 사용하여 거듭제곱한 결과를 연결해줍니다.
너무 노이즈가 보이지 않네요, multiply를 하여 노이즈 빈도를 늘려줍시다. 이렇게 노이즈 패턴까지 완성시켰습니다.
이제 만들었던 각 패턴들을 적용해봅시다. 대각선 움직이는 패턴은 lerp를 사용하여 a채널은 검은색, b채널(노이즈패턴이 적용될때의 색)은 밝은색을 적용해줍니다.
그리고 두개의 텍스쳐를 블랜딩하기 위해 노이즈 패턴과 대각선 움직이는 패턴을 곱해줍니다.
하지만 대각선 영역이외에도 노이즈값이 적용되고 있습니다. 이는 sine함수의 음수값이 넘어와서 이를 clamp로 양수만 출력하도록 합시다.
마지막으로 블랜딩된 값을 이미시브 컬러에 적용해주면 대각선으로 움직이는 노이즈 패턴이 적용된것을 볼수 있습니다.
하지만 울타리의 검은색부분이 뚫려있도록 표현하고 싶습니다. 울타리패턴을 오파시티 마스크에 연결해줍니다.
최종결과
출처
한국산업기술대학교 게임공학과 이택희 교수님 고급그래픽스효과 강의 - Opacity mask, normal, electronic fence
'고급 그래픽스 효과' 카테고리의 다른 글
[Material] Lava Effect(용암효과)(2) (0) | 2020.06.28 |
---|---|
[Material] Lava Effect(용암효과)(1) (0) | 2020.06.28 |
[Material] Electronic Fence Effect (Opacity Mask) (1) (0) | 2020.06.27 |
[Material] Displacement, Normal Mapping (0) | 2020.06.27 |
[Material] Glitch 효과 만들기(3) (0) | 2020.06.27 |