[UE4] VR에서 Widget에서 물건을 꺼내보세요
12234 단어 위 4OculusRiftVR
(UE4:4.24.1 Oculus Rift와 Touch 사용하고 있습니다.)
[UE4] Widget Interaction 컴퍼넌트를 사용해 VR로 접하는 UI를 제작해 본다!
이쪽의 블로그를 읽어 보고, 문득 Widget Interaction으로부터 물건을 내보낼 수 없는가, 라고 생각해 만들어 보았습니다.
data:image/s3,"s3://crabby-images/0de97/0de97de85c96ddbd5931918678f8bae561c87072" alt=""
동영상은 여기에서
만드는 방법
Widget의 Spawn에 대해 이 블로그를 참고했습니다.
UE4 : 위젯에서 드래그 앤 드롭으로 액터 스폰
먼저 Widget과 그것을 추가한 Actor를 만듭니다. 위의 블로그와 거의 같은 만들기이므로 세세한 설명은 할애.
data:image/s3,"s3://crabby-images/d58eb/d58eb2067c243d84aa49c0aee0c68454af9dc9f0" alt=""
이름: WidgetInteraction
data:image/s3,"s3://crabby-images/04b1a/04b1abfa553bce9c262958f2e662f5973074f8b4" alt=""
이름: BP_WidgetInteraction
이제 Widget Interaction을 BP_MotionController에 추가합니다. 둘 다 "Hidden In Game"을 True로 두십시오. Widget Interaction은 "Enable Hit Testing"을 false로 두십시오.
data:image/s3,"s3://crabby-images/b8593/b8593f689af207728da374f782051ebbc4262339" alt=""
Widget Interaction은 「Show Debug」를 True로 해 두면 좋을지도
이것들을 표시하기 위한 함수를 만듭니다.
data:image/s3,"s3://crabby-images/436ed/436ed7b35a956813391d607f6281fbf201f48e05" alt=""
data:image/s3,"s3://crabby-images/5f369/5f369022b33a2b7a0ed150c3e66a1c2a8e81a319" alt=""
data:image/s3,"s3://crabby-images/c34c0/c34c0ac8df69c4bd451f3babbb797de55a2f79c2" alt=""
data:image/s3,"s3://crabby-images/2a5b4/2a5b4ad8be5b989fa0767330ea59f2fcd11796a7" alt=""
그 후, 「프로젝트 설정」→「인풋」으로부터 액션 인풋에 「VisiblePauseMenu」를 추가해, 적당한 버튼을 할당합니다. 여기에서는 Touch의 Y, B 버튼을 할당했습니다.
data:image/s3,"s3://crabby-images/5b00c/5b00c36ff1e5740ad720f1bf581da026d234e8ce" alt=""
MotionControllerPawn으로 이동하여 다음과 같이 BP를 조립합니다.
data:image/s3,"s3://crabby-images/c2895/c2895ff31187172c857b2d7226f0192459c9a79c" alt=""
이런 식으로 Widget을 낼 수 있습니다.
data:image/s3,"s3://crabby-images/417d0/417d0e3f10c6fe72c83f38383858bbef907acf1b" alt=""
다음으로 Spawn하는 용의 Actor를 만들어 갑니다. 이름은 'BP_SM'입니다. 여기도 상기의 블로그와 거의 같은 만들기이므로 세세한 것은 할애.
data:image/s3,"s3://crabby-images/491e5/491e585bd887a6bdb5585a831fcff5fa5e31c04a" alt=""
data:image/s3,"s3://crabby-images/d9b5c/d9b5c069d914c687837e9eba822e2e277e57cb0e" alt=""
BP_MotionController로 돌아가서 BP_SM을 Attach하기 위한 SphereCollision을 추가합니다. 크기는 작고, 콜리전 프리셋을 「NoCollision」으로 하는 것을 잊지 않고.
data:image/s3,"s3://crabby-images/52b3d/52b3d0a7d286e214d08510d971aaaacd3a311622" alt=""
이벤트 그래프를 열고 다음과 같이 BP를 조립합니다. 여기도 위의 블로그와 거의 같기 때문에 할애.
data:image/s3,"s3://crabby-images/5f60f/5f60f7b5f7081f5f94544bc9355e7aa2f2794d35" alt=""
data:image/s3,"s3://crabby-images/55586/55586fb30fe92d5dcadb26cda8e48e79e75d3654" alt=""
data:image/s3,"s3://crabby-images/ca843/ca843b600f8a52e8f81a5dddc53aef00b4da790b" alt=""
data:image/s3,"s3://crabby-images/09c24/09c24d1324cee0d38bb2d7a0fb40d3b890bb7306" alt=""
Widget을 Press하기 위한 함수도 만들어 갑니다. 열거형 「PressReleaseEnum」을 작성해, 이하와 같이 합니다.
data:image/s3,"s3://crabby-images/cd98a/cd98a2499b3dfc3884eb347c22f68d74a01f71d5" alt=""
"BP_MotionController"로 돌아가서 다음과 같이 함수를 구성합니다.
data:image/s3,"s3://crabby-images/23443/23443f605c0f5a23111a71a53ae1d953635dbcde" alt=""
다음에 Widget을 Press했을 때에 「BP_SM」을 Spawn 시키도록 합니다. 프로젝트 설정 → 입력에서 ActionInput에 PauseMenuPress를 추가합니다. 여기에서는 "Oculus Touch (R) Trigger"를 할당합니다.
data:image/s3,"s3://crabby-images/7f962/7f962573aec50c143cc1b5af15121a40cda3ee3e" alt=""
MotionControllerPawn을 열고 다음과 같이 BP를 조립합니다. 여기서 함수도 만들고 있습니다만, 이것은 Widget으로 처리를 짜는데 사용합니다.
data:image/s3,"s3://crabby-images/cbee8/cbee885d91a062dce0322ae383b4d3f9de903ae5" alt=""
data:image/s3,"s3://crabby-images/cc65b/cc65b633b0c9527282594597caa46702dcac3fc8" alt=""
Widget을 열고 변수 "AttachLocation"(Vector, 인스턴트 편집 가능을 True로 한다)을 만든 후, Button이 Press되었을 때의 BP를 짜냅니다.
data:image/s3,"s3://crabby-images/90fd2/90fd2698baabe83cf24a1c9ccf67b6f2f878a13d" alt=""
위젯을 추가한 액터를 열고 다음과 같이 BP를 구성합니다.
data:image/s3,"s3://crabby-images/41f75/41f75da4e169d209328a74260d93577b54c01d09" alt=""
data:image/s3,"s3://crabby-images/f0175/f01753661cfdfa262b38d4d3f14afde5f0c0c346" alt=""
이것으로 완성입니다.
Reference
이 문제에 관하여([UE4] VR에서 Widget에서 물건을 꺼내보세요), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/suihanki/items/5dc7b0e55e2249c51629텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)