| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
- //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
- #pragma once
- #include "BsVulkanPrerequisites.h"
- #include "BsVulkanResource.h"
- #include "BsTexture.h"
- namespace BansheeEngine
- {
- /** @addtogroup Vulkan
- * @{
- */
- /** Wrapper around a Vulkan image object that manages its usage and lifetime. */
- class VulkanImage : public VulkanResource
- {
- public:
- VulkanImage(VulkanResourceManager* owner, VkImage image, VkDeviceMemory memory, VkImageLayout layout,
- const TextureProperties& props);
- ~VulkanImage();
- /** Returns the internal handle to the Vulkan object. */
- VkImage getHandle() const { return mImage; }
- /** Returns the layout the image is currently in. */
- VkImageLayout getLayout() const { return mLayout; }
- /** Notifies the resource that the current image layout has changed. */
- void setLayout(VkImageLayout layout) { mLayout = layout; }
- /** Returns an image view that covers all faces and mip maps of the texture. */
- VkImageView getView() const { return mMainView; };
- /** Returns an image view that covers the specified faces and mip maps of the texture. */
- VkImageView getView(const TextureSurface& surface) const;
- private:
- /** Creates a new view of the provided part (or entirety) of surface. */
- VkImageView createView(const TextureSurface& surface) const;
- /** Contains information about view for a specific surface(s) of this image. */
- struct ImageViewInfo
- {
- TextureSurface surface;
- VkImageView view;
- };
- VkImage mImage;
- VkDeviceMemory mMemory;
- VkImageLayout mLayout;
- VkImageView mMainView;
- mutable VkImageViewCreateInfo mImageViewCI;
- mutable Vector<ImageViewInfo> mImageInfos;
- };
- /** Vulkan implementation of a texture. */
- class VulkanTextureCore : public TextureCore
- {
- public:
- ~VulkanTextureCore();
- /**
- * Gets the resource wrapping the Vulkan image object, on the specified device. If texture device mask doesn't
- * include the provided device, null is returned.
- */
- VulkanImage* getResource(UINT32 deviceIdx) const { return mImages[deviceIdx]; }
- /**
- * Returns an image view that covers all faces and mip maps of the texture. Usable only on the specified device.
- * If texture device mask doesn't include the provided device, null is returned.
- */
- VkImageView getView(UINT32 deviceIdx) const;
- /**
- * Returns an image view that covers the specified faces and mip maps of the texture. Usable only on the specified
- * device. If texture device mask doesn't include the provided device, null is returned.
- */
- VkImageView getView(UINT32 deviceIdx, const TextureSurface& surface) const;
- protected:
- friend class VulkanTextureCoreManager;
- VulkanTextureCore(const TEXTURE_DESC& desc, const SPtr<PixelData>& initialData, GpuDeviceFlags deviceMask);
- /** @copydoc CoreObjectCore::initialize() */
- void initialize() override;
- /** @copydoc TextureCore::lockImpl */
- PixelData lockImpl(GpuLockOptions options, UINT32 mipLevel = 0, UINT32 face = 0, UINT32 deviceIdx = 0,
- UINT32 queueIdx = 0) override;
- /** @copydoc TextureCore::unlockImpl */
- void unlockImpl() override;
- /** @copydoc TextureCore::copyImpl */
- void copyImpl(UINT32 srcFace, UINT32 srcMipLevel, UINT32 destFace, UINT32 destMipLevel,
- const SPtr<TextureCore>& target, UINT32 queueIdx = 0) override;
- /** @copydoc TextureCore::readData */
- void readData(PixelData& dest, UINT32 mipLevel = 0, UINT32 face = 0, UINT32 deviceIdx = 0,
- UINT32 queueIdx = 0) override;
- /** @copydoc TextureCore::writeData */
- void writeData(const PixelData& src, UINT32 mipLevel = 0, UINT32 face = 0, bool discardWholeBuffer = false,
- UINT32 queueIdx = 0) override;
- private:
- /** Creates a new image for the specified device, matching the current properties. */
- VulkanImage* createImage(VulkanDevice& device, bool staging, bool readable);
- VulkanImage* mImages[BS_MAX_DEVICES];
- GpuDeviceFlags mDeviceMask;
- VkImageCreateInfo mImageCI;
- };
- /** @} */
- }
|