| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
Vulkan.Extensions.VK_EXT_full_screen_exclusive
Synopsis
- getPhysicalDeviceSurfacePresentModes2EXT :: forall a io. (Extendss PhysicalDeviceSurfaceInfo2KHR a, PokeChain a, MonadIO io) => PhysicalDevice -> PhysicalDeviceSurfaceInfo2KHR a -> io (Result, "presentModes" ::: Vector PresentModeKHR)
- getDeviceGroupSurfacePresentModes2EXT :: forall a io. (Extendss PhysicalDeviceSurfaceInfo2KHR a, PokeChain a, MonadIO io) => Device -> PhysicalDeviceSurfaceInfo2KHR a -> io ("modes" ::: DeviceGroupPresentModeFlagsKHR)
- acquireFullScreenExclusiveModeEXT :: forall io. MonadIO io => Device -> SwapchainKHR -> io ()
- releaseFullScreenExclusiveModeEXT :: forall io. MonadIO io => Device -> SwapchainKHR -> io ()
- data SurfaceFullScreenExclusiveInfoEXT = SurfaceFullScreenExclusiveInfoEXT {}
- data SurfaceFullScreenExclusiveWin32InfoEXT = SurfaceFullScreenExclusiveWin32InfoEXT {}
- data SurfaceCapabilitiesFullScreenExclusiveEXT = SurfaceCapabilitiesFullScreenExclusiveEXT {}
- newtype FullScreenExclusiveEXT where- FullScreenExclusiveEXT Int32
- pattern FULL_SCREEN_EXCLUSIVE_DEFAULT_EXT :: FullScreenExclusiveEXT
- pattern FULL_SCREEN_EXCLUSIVE_ALLOWED_EXT :: FullScreenExclusiveEXT
- pattern FULL_SCREEN_EXCLUSIVE_DISALLOWED_EXT :: FullScreenExclusiveEXT
- pattern FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT :: FullScreenExclusiveEXT
 
- type EXT_FULL_SCREEN_EXCLUSIVE_SPEC_VERSION = 4
- pattern EXT_FULL_SCREEN_EXCLUSIVE_SPEC_VERSION :: forall a. Integral a => a
- type EXT_FULL_SCREEN_EXCLUSIVE_EXTENSION_NAME = "VK_EXT_full_screen_exclusive"
- pattern EXT_FULL_SCREEN_EXCLUSIVE_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
- type HMONITOR = Ptr ()
- newtype SurfaceKHR = SurfaceKHR Word64
- newtype SwapchainKHR = SwapchainKHR Word64
- data PhysicalDeviceSurfaceInfo2KHR (es :: [Type]) = PhysicalDeviceSurfaceInfo2KHR {- next :: Chain es
- surface :: SurfaceKHR
 
- newtype PresentModeKHR where- PresentModeKHR Int32
- pattern PRESENT_MODE_IMMEDIATE_KHR :: PresentModeKHR
- pattern PRESENT_MODE_MAILBOX_KHR :: PresentModeKHR
- pattern PRESENT_MODE_FIFO_KHR :: PresentModeKHR
- pattern PRESENT_MODE_FIFO_RELAXED_KHR :: PresentModeKHR
- pattern PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR :: PresentModeKHR
- pattern PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR :: PresentModeKHR
 
- newtype DeviceGroupPresentModeFlagBitsKHR where- DeviceGroupPresentModeFlagBitsKHR Flags
- pattern DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR
- pattern DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR
- pattern DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR
- pattern DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR
 
- type DeviceGroupPresentModeFlagsKHR = DeviceGroupPresentModeFlagBitsKHR
Documentation
getPhysicalDeviceSurfacePresentModes2EXT Source #
Arguments
| :: forall a io. (Extendss PhysicalDeviceSurfaceInfo2KHR a, PokeChain a, MonadIO io) | |
| => PhysicalDevice | 
 | 
| -> PhysicalDeviceSurfaceInfo2KHR a | 
 | 
| -> io (Result, "presentModes" ::: Vector PresentModeKHR) | 
vkGetPhysicalDeviceSurfacePresentModes2EXT - Query supported presentation modes
Description
getPhysicalDeviceSurfacePresentModes2EXT behaves similarly to
 getPhysicalDeviceSurfacePresentModesKHR,
 with the ability to specify extended inputs via chained input
 structures.
Valid Usage (Implicit)
- physicalDevicemust be a valid- PhysicalDevicehandle
- pSurfaceInfomust be a valid pointer to a valid- PhysicalDeviceSurfaceInfo2KHRstructure
- pPresentModeCountmust be a valid pointer to a- uint32_tvalue
- If the value referenced by pPresentModeCountis not0, andpPresentModesis notNULL,pPresentModesmust be a valid pointer to an array ofpPresentModeCountPresentModeKHRvalues
Return Codes
See Also
PhysicalDevice,
 PhysicalDeviceSurfaceInfo2KHR,
 PresentModeKHR
getDeviceGroupSurfacePresentModes2EXT Source #
Arguments
| :: forall a io. (Extendss PhysicalDeviceSurfaceInfo2KHR a, PokeChain a, MonadIO io) | |
| => Device | 
 
 | 
| -> PhysicalDeviceSurfaceInfo2KHR a | 
 
 | 
| -> io ("modes" ::: DeviceGroupPresentModeFlagsKHR) | 
vkGetDeviceGroupSurfacePresentModes2EXT - Query device group present capabilities for a surface
Description
getDeviceGroupSurfacePresentModes2EXT behaves similarly to
 getDeviceGroupSurfacePresentModesKHR,
 with the ability to specify extended inputs via chained input
 structures.
Return Codes
See Also
Device,
 DeviceGroupPresentModeFlagsKHR,
 PhysicalDeviceSurfaceInfo2KHR
acquireFullScreenExclusiveModeEXT Source #
Arguments
| :: forall io. MonadIO io | |
| => Device | 
 | 
| -> SwapchainKHR | 
 | 
| -> io () | 
vkAcquireFullScreenExclusiveModeEXT - Acquire full-screen exclusive mode for a swapchain
Valid Usage
- swapchainmust not be in the retired state
- swapchainmust be a swapchain created with a- SurfaceFullScreenExclusiveInfoEXTstructure, with- fullScreenExclusiveset to- FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT
- swapchainmust not currently have exclusive full-screen access
A return value of SUCCESS indicates that
 the swapchain successfully acquired exclusive full-screen access. The
 swapchain will retain this exclusivity until either the application
 releases exclusive full-screen access with
 releaseFullScreenExclusiveModeEXT, destroys the swapchain, or if any
 of the swapchain commands return
 ERROR_FULL_SCREEN_EXCLUSIVE_MODE_LOST_EXT
 indicating that the mode was lost because of platform-specific changes.
If the swapchain was unable to acquire exclusive full-screen access to
 the display then
 ERROR_INITIALIZATION_FAILED is returned. An
 application can attempt to acquire exclusive full-screen access again
 for the same swapchain even if this command fails, or if
 ERROR_FULL_SCREEN_EXCLUSIVE_MODE_LOST_EXT
 has been returned by a swapchain command.
Valid Usage (Implicit)
- devicemust be a valid- Devicehandle
- swapchainmust be a valid- SwapchainKHRhandle
- Both of device, andswapchainmust have been created, allocated, or retrieved from the sameInstance
Return Codes
See Also
releaseFullScreenExclusiveModeEXT Source #
Arguments
| :: forall io. MonadIO io | |
| => Device | 
 | 
| -> SwapchainKHR | 
 
 
 | 
| -> io () | 
vkReleaseFullScreenExclusiveModeEXT - Release full-screen exclusive mode from a swapchain
Description
Note
Applications will not be able to present to swapchain after this call
 until exclusive full-screen access is reacquired. This is usually useful
 to handle when an application is minimised or otherwise intends to stop
 presenting for a time.
Valid Usage
See Also
data SurfaceFullScreenExclusiveInfoEXT Source #
VkSurfaceFullScreenExclusiveInfoEXT - Structure specifying the preferred full-screen transition behavior
Description
If this structure is not present, fullScreenExclusive is considered to
 be FULL_SCREEN_EXCLUSIVE_DEFAULT_EXT.
Valid Usage (Implicit)
See Also
Constructors
| SurfaceFullScreenExclusiveInfoEXT | |
| Fields 
 | |
Instances
data SurfaceFullScreenExclusiveWin32InfoEXT Source #
VkSurfaceFullScreenExclusiveWin32InfoEXT - Structure specifying additional creation parameters specific to Win32 fullscreen exclusive mode
Description
Note
If hmonitor is invalidated (e.g. the monitor is unplugged) during the
 lifetime of a swapchain created with this structure, operations on that
 swapchain will return
 ERROR_OUT_OF_DATE_KHR.
Note
It is the responsibility of the application to change the display settings of the targeted Win32 display using the appropriate platform APIs. Such changes may alter the surface capabilities reported for the created surface.
Valid Usage (Implicit)
See Also
Constructors
| SurfaceFullScreenExclusiveWin32InfoEXT | |
Instances
data SurfaceCapabilitiesFullScreenExclusiveEXT Source #
VkSurfaceCapabilitiesFullScreenExclusiveEXT - Structure describing full screen exclusive capabilities of a surface
Description
This structure can be included in the pNext chain of
 SurfaceCapabilities2KHR
 to determine support for exclusive full-screen access. If
 fullScreenExclusiveSupported is
 FALSE, it indicates that exclusive
 full-screen access is not obtainable for this surface.
Applications must not attempt to create swapchains with
 FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT set if
 fullScreenExclusiveSupported is
 FALSE.
Valid Usage (Implicit)
See Also
Constructors
| SurfaceCapabilitiesFullScreenExclusiveEXT | |
| Fields | |
Instances
newtype FullScreenExclusiveEXT Source #
VkFullScreenExclusiveEXT - Hint values an application can specify affecting full-screen transition behavior
See Also
Constructors
| FullScreenExclusiveEXT Int32 | 
Bundled Patterns
| pattern FULL_SCREEN_EXCLUSIVE_DEFAULT_EXT :: FullScreenExclusiveEXT | 
 | 
| pattern FULL_SCREEN_EXCLUSIVE_ALLOWED_EXT :: FullScreenExclusiveEXT | 
 | 
| pattern FULL_SCREEN_EXCLUSIVE_DISALLOWED_EXT :: FullScreenExclusiveEXT | 
 | 
| pattern FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT :: FullScreenExclusiveEXT | 
 | 
Instances
pattern EXT_FULL_SCREEN_EXCLUSIVE_SPEC_VERSION :: forall a. Integral a => a Source #
type EXT_FULL_SCREEN_EXCLUSIVE_EXTENSION_NAME = "VK_EXT_full_screen_exclusive" Source #
pattern EXT_FULL_SCREEN_EXCLUSIVE_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a Source #
newtype SurfaceKHR Source #
VkSurfaceKHR - Opaque handle to a surface object
Description
The VK_KHR_surface extension declares the SurfaceKHR object, and
 provides a function for destroying SurfaceKHR objects. Separate
 platform-specific extensions each provide a function for creating a
 SurfaceKHR object for the respective platform. From the application’s
 perspective this is an opaque handle, just like the handles of other
 Vulkan objects.
See Also
PhysicalDeviceSurfaceInfo2KHR,
 SwapchainCreateInfoKHR,
 createAndroidSurfaceKHR,
 createDisplayPlaneSurfaceKHR,
 createHeadlessSurfaceEXT,
 createIOSSurfaceMVK,
 createImagePipeSurfaceFUCHSIA,
 createMacOSSurfaceMVK,
 createMetalSurfaceEXT,
 createStreamDescriptorSurfaceGGP,
 createViSurfaceNN,
 createWaylandSurfaceKHR,
 createWin32SurfaceKHR,
 createXcbSurfaceKHR,
 createXlibSurfaceKHR,
 destroySurfaceKHR,
 getDeviceGroupSurfacePresentModesKHR,
 getPhysicalDevicePresentRectanglesKHR,
 getPhysicalDeviceSurfaceCapabilities2EXT,
 getPhysicalDeviceSurfaceCapabilitiesKHR,
 getPhysicalDeviceSurfaceFormatsKHR,
 getPhysicalDeviceSurfacePresentModesKHR,
 getPhysicalDeviceSurfaceSupportKHR
Constructors
| SurfaceKHR Word64 | 
Instances
newtype SwapchainKHR Source #
VkSwapchainKHR - Opaque handle to a swapchain object
Description
A swapchain is an abstraction for an array of presentable images that
 are associated with a surface. The presentable images are represented by
 Image objects created by the platform. One image
 (which can be an array image for multiview/stereoscopic-3D surfaces)
 is displayed at a time, but multiple images can be queued for
 presentation. An application renders to the image, and then queues the
 image for presentation to the surface.
A native window cannot be associated with more than one non-retired swapchain at a time. Further, swapchains cannot be created for native windows that have a non-Vulkan graphics API surface associated with them.
Note
The presentation engine is an abstraction for the platform’s compositor or display engine.
The presentation engine may be synchronous or asynchronous with respect to the application and/or logical device.
Some implementations may use the device’s graphics queue or dedicated presentation hardware to perform presentation.
The presentable images of a swapchain are owned by the presentation
 engine. An application can acquire use of a presentable image from the
 presentation engine. Use of a presentable image must occur only after
 the image is returned by
 acquireNextImageKHR, and before it
 is presented by queuePresentKHR.
 This includes transitioning the image layout and rendering commands.
An application can acquire use of a presentable image with
 acquireNextImageKHR. After
 acquiring a presentable image and before modifying it, the application
 must use a synchronization primitive to ensure that the presentation
 engine has finished reading from the image. The application can then
 transition the image’s layout, queue rendering commands to it, etc.
 Finally, the application presents the image with
 queuePresentKHR, which releases the
 acquisition of the image.
The presentation engine controls the order in which presentable images are acquired for use by the application.
Note
This allows the platform to handle situations which require out-of-order return of images after presentation. At the same time, it allows the application to generate command buffers referencing all of the images in the swapchain at initialization time, rather than in its main loop.
See Also
AcquireNextImageInfoKHR,
 BindImageMemorySwapchainInfoKHR,
 ImageSwapchainCreateInfoKHR,
 PresentInfoKHR,
 SwapchainCreateInfoKHR,
 acquireFullScreenExclusiveModeEXT,
 acquireNextImageKHR,
 createSharedSwapchainsKHR,
 createSwapchainKHR,
 destroySwapchainKHR,
 getPastPresentationTimingGOOGLE,
 getRefreshCycleDurationGOOGLE,
 getSwapchainCounterEXT,
 getSwapchainImagesKHR,
 getSwapchainStatusKHR,
 releaseFullScreenExclusiveModeEXT,
 setHdrMetadataEXT,
 setLocalDimmingAMD
Constructors
| SwapchainKHR Word64 | 
Instances
data PhysicalDeviceSurfaceInfo2KHR (es :: [Type]) Source #
VkPhysicalDeviceSurfaceInfo2KHR - Structure specifying a surface and related swapchain creation parameters
Description
The members of PhysicalDeviceSurfaceInfo2KHR correspond to the
 arguments to
 getPhysicalDeviceSurfaceCapabilitiesKHR,
 with sType and pNext added for extensibility.
Additional capabilities of a surface may be available to swapchains
 created with different full-screen exclusive settings - particularly if
 exclusive full-screen access is application controlled. These additional
 capabilities can be queried by adding a
 SurfaceFullScreenExclusiveInfoEXT
 structure to the pNext chain of this structure when used to query
 surface properties. Additionally, for Win32 surfaces with application
 controlled exclusive full-screen access, chaining a
 SurfaceFullScreenExclusiveWin32InfoEXT
 structure may also report additional surface capabilities. These
 additional capabilities only apply to swapchains created with the same
 parameters included in the pNext chain of
 SwapchainCreateInfoKHR.
Valid Usage
- If the pNextchain includes aSurfaceFullScreenExclusiveInfoEXTstructure with itsfullScreenExclusivemember set toFULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT, andsurfacewas created usingcreateWin32SurfaceKHR, aSurfaceFullScreenExclusiveWin32InfoEXTstructure must be included in thepNextchain
Valid Usage (Implicit)
- sTypemust be- STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR
- Each pNextmember of any structure (including this one) in thepNextchain must be eitherNULLor a pointer to a valid instance ofSurfaceFullScreenExclusiveInfoEXTorSurfaceFullScreenExclusiveWin32InfoEXT
- The sTypevalue of each struct in thepNextchain must be unique
- surfacemust be a valid- SurfaceKHRhandle
See Also
StructureType,
 SurfaceKHR,
 getDeviceGroupSurfacePresentModes2EXT,
 getPhysicalDeviceSurfaceCapabilities2KHR,
 getPhysicalDeviceSurfaceFormats2KHR,
 getPhysicalDeviceSurfacePresentModes2EXT
Constructors
| PhysicalDeviceSurfaceInfo2KHR | |
| Fields 
 | |
Instances
newtype PresentModeKHR Source #
VkPresentModeKHR - presentation mode supported for a surface
Description
The supported
 ImageUsageFlagBits of the
 presentable images of a swapchain created for a surface may differ
 depending on the presentation mode, and can be determined as per the
 table below:
| Presentation mode | Image usage flags | 
|---|---|
| PRESENT_MODE_IMMEDIATE_KHR | SurfaceCapabilitiesKHR::supportedUsageFlags | 
| PRESENT_MODE_MAILBOX_KHR | SurfaceCapabilitiesKHR::supportedUsageFlags | 
| PRESENT_MODE_FIFO_KHR | SurfaceCapabilitiesKHR::supportedUsageFlags | 
| PRESENT_MODE_FIFO_RELAXED_KHR | SurfaceCapabilitiesKHR::supportedUsageFlags | 
| PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR | SharedPresentSurfaceCapabilitiesKHR::sharedPresentSupportedUsageFlags | 
| PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR | SharedPresentSurfaceCapabilitiesKHR::sharedPresentSupportedUsageFlags | 
Presentable image usage queries
Note
For reference, the mode indicated by PRESENT_MODE_FIFO_KHR is
 equivalent to the behavior of {wgl|glX|egl}SwapBuffers with a swap
 interval of 1, while the mode indicated by
 PRESENT_MODE_FIFO_RELAXED_KHR is equivalent to the behavior of
 {wgl|glX}SwapBuffers with a swap interval of -1 (from the
 {WGL|GLX}_EXT_swap_control_tear extensions).
See Also
SwapchainCreateInfoKHR,
 getPhysicalDeviceSurfacePresentModes2EXT,
 getPhysicalDeviceSurfacePresentModesKHR
Constructors
| PresentModeKHR Int32 | 
Bundled Patterns
| pattern PRESENT_MODE_IMMEDIATE_KHR :: PresentModeKHR | 
 | 
| pattern PRESENT_MODE_MAILBOX_KHR :: PresentModeKHR | 
 | 
| pattern PRESENT_MODE_FIFO_KHR :: PresentModeKHR | 
 | 
| pattern PRESENT_MODE_FIFO_RELAXED_KHR :: PresentModeKHR | 
 | 
| pattern PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR :: PresentModeKHR | 
 | 
| pattern PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR :: PresentModeKHR | 
 | 
Instances
newtype DeviceGroupPresentModeFlagBitsKHR Source #
VkDeviceGroupPresentModeFlagBitsKHR - Bitmask specifying supported device group present modes
See Also
Constructors
| DeviceGroupPresentModeFlagBitsKHR Flags | 
Bundled Patterns
| pattern DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR | 
 | 
| pattern DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR | 
 | 
| pattern DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR | 
 | 
| pattern DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR :: DeviceGroupPresentModeFlagBitsKHR | 
 |