mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2024-11-30 16:10:53 +00:00
251e47f4d6
It works on only one layer and one mip, and assumes the provided texture data is compatible with the image, but does support sub-image updates (x, y location as parameters, width and height in the texture data).
42 lines
1.6 KiB
C
42 lines
1.6 KiB
C
#ifndef __QF_Vulkan_qf_texture_h
|
|
#define __QF_Vulkan_qf_texture_h
|
|
|
|
#include "QF/image.h"
|
|
#include "QF/Vulkan/qf_vid.h"
|
|
|
|
typedef struct qfv_tex_s {
|
|
VkDeviceMemory memory;
|
|
VkImage image;
|
|
VkImageView view;
|
|
} qfv_tex_t;
|
|
|
|
typedef struct texturectx_s {
|
|
VkDescriptorPool pool;
|
|
VkDescriptorSetLayout setLayout;
|
|
} texturectx_t;
|
|
|
|
void Vulkan_ExpandPalette (byte *dst, const byte *src, const byte *palette,
|
|
int alpha, int count);
|
|
qfv_tex_t *Vulkan_LoadTex (struct vulkan_ctx_s *ctx, tex_t *tex, int mip,
|
|
const char *name);
|
|
qfv_tex_t *Vulkan_LoadTexArray (struct vulkan_ctx_s *ctx, tex_t *tex,
|
|
int layers, int mip, const char *name);
|
|
qfv_tex_t *Vulkan_LoadEnvMap (struct vulkan_ctx_s *ctx, tex_t *tex,
|
|
const char *name);
|
|
qfv_tex_t *Vulkan_LoadEnvSides (struct vulkan_ctx_s *ctx, tex_t **tex,
|
|
const char *name);
|
|
VkImageView Vulkan_TexImageView (qfv_tex_t *tex) __attribute__((pure));
|
|
void Vulkan_UpdateTex (struct vulkan_ctx_s *ctx, qfv_tex_t *tex, tex_t *src,
|
|
int x, int y, int layer, int mip);
|
|
void Vulkan_UnloadTex (struct vulkan_ctx_s *ctx, qfv_tex_t *tex);
|
|
void Vulkan_Texture_Init (struct vulkan_ctx_s *ctx);
|
|
void Vulkan_Texture_Shutdown (struct vulkan_ctx_s *ctx);
|
|
VkDescriptorSet Vulkan_CreateCombinedImageSampler (struct vulkan_ctx_s *ctx,
|
|
VkImageView view,
|
|
VkSampler sampler);
|
|
VkDescriptorSet Vulkan_CreateTextureDescriptor (struct vulkan_ctx_s *ctx,
|
|
qfv_tex_t *tex,
|
|
VkSampler sampler);
|
|
void Vulkan_FreeTexture (struct vulkan_ctx_s *ctx, VkDescriptorSet texture);
|
|
|
|
#endif//__QF_Vulkan_qf_texture_h
|