(실습) Overlap Event를 활용한 포탈 생성시키기
data:image/s3,"s3://crabby-images/badfd/badfd6c09516d76673d5947695d4291648b626d8" alt=""
위 사진의 블루프린트는 레벨상에 있는 코인을 전부 획득 하였을때 포탈을 생성시키는 블루프린트이다
data:image/s3,"s3://crabby-images/8a40a/8a40a216372bc33e7c57babc4004b18daed28df0" alt=""
콘텐츠에 새로운 블루프린트 폴더를 만들어준다
data:image/s3,"s3://crabby-images/06186/0618635d70b7ad6cc1fefc382ad1ce7b9e633968" alt=""
폴더에 코인과 포탈의 기능을 할 블루프린트 액터 두개를 생성해준다
data:image/s3,"s3://crabby-images/609d0/609d0500c47891c1b31f225108d6ee51c174d0c9" alt=""
data:image/s3,"s3://crabby-images/9fab2/9fab2fa50201381c06d15c3bd199411ee4259309" alt=""
액터중 하나를 코인의 형태로 만들어주고 스피어 콜리전을 생성해 크기에 맞게 적용시켜준다
data:image/s3,"s3://crabby-images/6f76c/6f76c1d7af2466e38c18a4dd1a622baf0c6abd63" alt=""
나머지 액터 하나도 포탈의 형태로 생성해준다
data:image/s3,"s3://crabby-images/b73b7/b73b7069d5e7e581260c59c920202c329ff2ce7e" alt=""
이후 코인의 블루프린트로 들어가 Event Tick에 AddWorldRotation에 static Mesh형으로 연결시켜 z축을 3도 회전하게 만들어준다
(게임속 코인처럼 회전하게 만들어주는 노드)
data:image/s3,"s3://crabby-images/3bda0/3bda06546d1d177b7d2c7e1ca572c24a3543d19d" alt=""
이후 포탈의 이벤트 그래프 창으로 들어가 코인이 처음 시작하면서 보이지않게 설정해주는 노드를 연결한다 begin play event에서 Set Visibility 를 Sphere 형으로 연결해준다
data:image/s3,"s3://crabby-images/4a137/4a1374a23d3716b9bf9bdab150a7155b9454b737" alt=""
이후 레벨로 돌아와 만들어준 코인과 포탈을 배치한다 실습에서는 코인의 개수를 3개로 설정함
이제 우리는 본격적으로 레벨에 배치된 3개의 코인을 다 획득하였을 때 포탈을 생성시키는 노드를 구현할 것이다
data:image/s3,"s3://crabby-images/4773c/4773cf2011606cf440f560aa127c9541d4e502a3" alt=""
우선 포탈에 Check All Coin Hide라는 새로운 함수를 생성해준다
data:image/s3,"s3://crabby-images/58d23/58d23996445539aea4f142cf81b2a96ba64604ec" alt=""
그 후 Coins라는 새로운 변수를 하나 생성해주고 배열 형태로 BP_Coin과 연결해준다
data:image/s3,"s3://crabby-images/08386/08386f665adac1cf6b9898aeeef4fff96a46e7f5" alt=""
코인즈 옆에 눈을 열어주고
data:image/s3,"s3://crabby-images/35716/3571695eda257d285c929da9b4343d129e932292" alt=""
레벨로 돌아와서 기본/디폴트 패널에서 배열 3개를 만들어준다
data:image/s3,"s3://crabby-images/1ceb0/1ceb02ef861f17951093388f127497956be4f0f0" alt=""
이후 포탈 블루프린트창으로 들어가서 Portal이라는 변수를 BP_portal과 연결시켜주고 coins와 마찬가지로 눈을 열어준다 (눈을 열어주면 편집 가능)
data:image/s3,"s3://crabby-images/b1eb9/b1eb9a3784dd42aef3d3a2b525c5b7060662b823" alt=""
그러면 기본/디폴트 부분에 Portal이라는 항목이 생성된 걸 알 수 있고 모두 BP_Portal로 설정해준다
이렇게 설정을 하면 이제 포탈과 각 코인들이 서로 상호작용 할 수 있는 상태가 된다
data:image/s3,"s3://crabby-images/3941e/3941ef84387da9d4986e88a8515a23095a47fe45" alt=""
아까 만들어준 CHeck All Coin Hide 함수로 돌아와서 For Each Loop를 생성하고 Coins 변수들과 배열로 연결시켜준다
data:image/s3,"s3://crabby-images/50a10/50a10409a79d6dfaa0b19f1d81562f1023c32cc4" alt=""
그리고 다시 Coin 블루프린트로 돌아와서 is Hide라는 bool형의 변수를 생성해준다
data:image/s3,"s3://crabby-images/e4b86/e4b864e2a6c92a5e44d9abddb592ce18bb3ac38c" alt=""
다음 Check All Coin Hide 함수로 돌아와서 For Each Loop의 Array Element를 드래그해서 Branch와 is Hide로 연결시켜준다
data:image/s3,"s3://crabby-images/3d719/3d719ee455e2dd3671390ea55ee0ed970fd2d2be" alt=""
Check All Coin Hide함수의 반환 노드를 2개 생성해주고 출력 명을 is ALl Hide라고 설정해준다
이렇게 우리는 플레이어가 코인을 다 획득하였는지 확인하는 Check All Coin Hide라는 함수의 구현을 완성했다
data:image/s3,"s3://crabby-images/e08d8/e08d8f43f26e43e480a4e08ddc04e048bb57dcd1" alt=""
이후 다시 Event Get Coin이라는 코인을 전부 획들했을 때 포탈을 생성시키는 함수를 생성할 것이다
data:image/s3,"s3://crabby-images/98c7d/98c7db29d72129d36b0279c64912d5b377bb7e2d" alt=""
코인을 획득했을 때 Event Get Coin ! 이라는 문자열을 출력하게 해주고
data:image/s3,"s3://crabby-images/cbcef/cbcef8674ee4cca006632f3789482e1e3d2ffff2" alt=""
우리가 방금 만들어준 Check All Coin Hide 함수를 가져와서 입력값을 BP Coin 배열 형태로 설정해주고 coins와 연결시켜준다
data:image/s3,"s3://crabby-images/88421/88421041035064850b39fa4291592a5813a79a01" alt=""
마지막으로 Set Visibility (액터를 보여줄지 말지 결정하는 노드)를 Sphere형태로 생성해주고 Check All Coin Hide의 Is All Hide와 New Visibility를 연결해준다
이제 이렇게 만들어준 함수들을 Coin 블루프린트에서 구현시켜 작동되게 만들어보자
data:image/s3,"s3://crabby-images/831e7/831e783fd92ba652f3ee32ec9158b769c388ec03" alt=""
data:image/s3,"s3://crabby-images/96bbb/96bbb2f2222a3b2e48b162101a8e185b8066306e" alt=""
data:image/s3,"s3://crabby-images/a1311/a131169bdc065542769323fa8518868cf90a8c72" alt=""
Coin 블루프린트에서 Sphere을 선택한 상태로 우측 하단의 On Component Begin Overlap을 눌러줘 생성시켜준다
data:image/s3,"s3://crabby-images/cdd39/cdd39f033612fa047570bfb86eb51ecd4565dc0d" alt=""
Overlap Event에 Set Visibiliy를 static Mesh형태로 연결시켜줘서 오버랩이 발생했을시 코인이 사라지게 만든다(New visibility 버튼의 체크로 설정 가능)
data:image/s3,"s3://crabby-images/d5125/d5125147684719599c40fd392e0187b315c3fc98" alt=""
이후 Set Collision Enabled를 sphere 형태로 연결시켜주고(콜리전을 No Collision으로 설정해 일회성으로 만들어줌)
data:image/s3,"s3://crabby-images/4959b/4959b6a6724a884c2dc6cde76bd9e07de260a594" alt=""
마지막으로 is Hide 변수를 Set으로 가져와서 Event Get Coin을 가져와 이어준다, Event Get Coin은 Portal의 함수이다
이제 실행시켜보면
data:image/s3,"s3://crabby-images/6b174/6b174b09b9920d52966e7be7c5ce18c88e5abe46" alt=""
다음과 같이 코인을 획득할 때마다 Event Get Coin !을 출력하고 마지막에 포탈을 생성한 것을 확인할 수 있다
이렇게 Overlap Event를 이용한 포탈 생성 실습을 마친다