Vulkan API는 결과를 표시하지 않고 사용할 수 있으므로 선택적 Vulkan 확장 기능을 사용하여 WSI를 제공합니다. 대부분의 구현에는 WSI 지원이 포함됩니다. WSI 설계는 각 플랫폼의 윈도우 메커니즘을 코어 Vulkan API에서 추상화하기 위해 만들어졌습니다.
VkSurfaceKHR
객체는 플랫폼에 구애받지 않으며 나머지 Vulkan API가 모든 WSI 연산에 사용할 수 있도록 설계되었습니다. 이 객체는 VK_KHR_surface
확장 기능을 사용하여 활성화할 수 있습니다.
Vulkan 서페이스를 지원하는 각 플랫폼은 플랫폼마다 고유의 API에서 VkSurfaceKHR
객체를 만드는 독자적인 방법을 가지고 있습니다.
-
Android - vkCreateAndroidSurfaceKHR
-
DirectFB - vkCreateDirectFBSurfaceEXT
-
Fuchsia - vkCreateImagePipeSurfaceFUCHSIA
-
iOS - vkCreateIOSSurfaceMVK
-
macOS - vkCreateMacOSSurfaceMVK
-
Metal - vkCreateMetalSurfaceEXT
-
VI - vkCreateViSurfaceNN
-
Wayland - vkWaylandSurfaceCreateInfoKHR
-
QNX - vkCreateScreenSurfaceQNX
-
Windows - vkCreateWin32SurfaceKHR
-
XCB - vkCreateXcbSurfaceKHR
-
Xlib - vkCreateXlibSurfaceKHR
-
Direct-to-Display - vkCreateDisplayPlaneSurfaceKHR
모바일 기기는 회전이 가능하므로 애플리케이션 창의 논리적 방향과 디스플레이의 물리적 방향이 일치하지 않을 수 있습니다. 애플리케이션은 세로모드(portrait)
와 가로모드(landscape)
2가지 모드로 작동할 수 있어야 합니다. 이 두 모드의 차이는 해상도의 변화로 단순화할 수 있습니다. 그러나 일부 디스펠리에 하위 시스템은 항상 디스플레이 패널의 “기본(native)” (또는 “물리적”) 방향에서 작동합니다. 장치가 회전되었으므로 원하는 효과를 얻으려면 애플리케이션 출력도 회전해야 합니다.
안드로이드와 같은 모바일 플랫폼에서 애플리케이션이 Vulkan을 최대한 활용하려면 사전 회전을 구현하는 것이 필수입니다. 스왑체인 생성 시 방향을 지정하여 서페이스 회전을 처리하는 방법을 설명하는 Google의 자세한 블로그 게시물이 있으며 독립 실행형 예제도 함께 제공됩니다. Vulkan-Samples에는 사전 회전이 문제가 되는 이유에 대한 훌륭한 글과 쉐이더에서 이를 해결하는 방법을 보여주는 실행 샘플도 있습니다. Adreno GPU 기반 기기를 사용하는 경우, 퀄컴(Qualcomm)은 VK_QCOM_render_pass_transform 확장 기능을 사용하여 사전 회전을 구현할 것을 권장합니다.