176 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			176 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <kinc/global.h>
 | |
| 
 | |
| #include <kinc/backend/graphics5/constantbuffer.h>
 | |
| 
 | |
| #include <kinc/math/matrix.h>
 | |
| #include <kinc/math/vector.h>
 | |
| 
 | |
| /*! \file constantbuffer.h
 | |
|     \brief Provides support for managing buffers of constant-data for shaders.
 | |
| */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| typedef struct kinc_g5_constant_buffer {
 | |
| 	uint8_t *data;
 | |
| 	ConstantBuffer5Impl impl;
 | |
| } kinc_g5_constant_buffer_t;
 | |
| 
 | |
| /// <summary>
 | |
| /// Initializes a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="buffer">The buffer to initialize</param>
 | |
| /// <param name="size">The size of the constant-data in the buffer in bytes</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_init(kinc_g5_constant_buffer_t *buffer, int size);
 | |
| 
 | |
| /// <summary>
 | |
| /// Destroys a buffer.
 | |
| /// </summary>
 | |
| /// <param name="buffer">The buffer to destroy</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_destroy(kinc_g5_constant_buffer_t *buffer);
 | |
| 
 | |
| /// <summary>
 | |
| /// Locks all of a constant-buffer to modify its contents.
 | |
| /// </summary>
 | |
| /// <param name="buffer">The buffer to lock</param>
 | |
| /// <returns>The contents of the buffer</returns>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_lock_all(kinc_g5_constant_buffer_t *buffer);
 | |
| 
 | |
| /// <summary>
 | |
| /// Locks part of a constant-buffer to modify its contents.
 | |
| /// </summary>
 | |
| /// <param name="buffer">The buffer to lock</param>
 | |
| /// <param name="start">The offset of where to start the lock in bytes</param>
 | |
| /// <param name="count">The number of bytes to lock</param>
 | |
| /// <returns>The contents of the buffer, starting at start</returns>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_lock(kinc_g5_constant_buffer_t *buffer, int start, int count);
 | |
| 
 | |
| /// <summary>
 | |
| /// Unlocks a constant-buffer so the changed contents can be used.
 | |
| /// </summary>
 | |
| /// <param name="buffer">The buffer to unlock</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_unlock(kinc_g5_constant_buffer_t *buffer);
 | |
| 
 | |
| /// <summary>
 | |
| /// Figures out the size of the constant-data in the buffer.
 | |
| /// </summary>
 | |
| /// <param name="buffer">The buffer to figure out the size for</param>
 | |
| /// <returns>Returns the size of the constant-data in the buffer in bytes</returns>
 | |
| KINC_FUNC int kinc_g5_constant_buffer_size(kinc_g5_constant_buffer_t *buffer);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns a bool at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value">The value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_bool(kinc_g5_constant_buffer_t *buffer, int offset, bool value);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns an integer at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value">The value to assign to the constant/uniform</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_int(kinc_g5_constant_buffer_t *buffer, int offset, int value);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns two integers at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value1">The first value to write into the buffer</param>
 | |
| /// <param name="value2">The second value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_int2(kinc_g5_constant_buffer_t *buffer, int offset, int value1, int value2);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns three integers at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value1">The first value to write into the buffer</param>
 | |
| /// <param name="value2">The second value to write into the buffer</param>
 | |
| /// <param name="value3">The third value to write into the buffer/param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_int3(kinc_g5_constant_buffer_t *buffer, int offset, int value1, int value2, int value3);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns four integers at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value1">The first value to write into the buffer</param>
 | |
| /// <param name="value2">The second value to write into the buffer</param>
 | |
| /// <param name="value3">The third value to write into the buffer/param>
 | |
| /// <param name="value4">The fourth value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_int4(kinc_g5_constant_buffer_t *buffer, int offset, int value1, int value2, int value3, int value4);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns a bunch of integers at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="location">The location of the constant/uniform to assign the values to</param>
 | |
| /// <param name="value">The values to write into the buffer</param>
 | |
| /// <param name="value">The number of values to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_ints(kinc_g5_constant_buffer_t *buffer, int offset, int *values, int count);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns a float at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value">The value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_float(kinc_g5_constant_buffer_t *buffer, int offset, float value);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns two floats at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value1">The first value to write into the buffer</param>
 | |
| /// <param name="value2">The second value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_float2(kinc_g5_constant_buffer_t *buffer, int offset, float value1, float value2);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns three floats at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value1">The first value to write into the buffer</param>
 | |
| /// <param name="value2">The second value to write into the buffer</param>
 | |
| /// <param name="value3">The third value to write into the buffer/param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_float3(kinc_g5_constant_buffer_t *buffer, int offset, float value1, float value2, float value3);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns four floats at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value1">The first value to write into the buffer</param>
 | |
| /// <param name="value2">The second value to write into the buffer</param>
 | |
| /// <param name="value3">The third value to write into the buffer/param>
 | |
| /// <param name="value4">The fourth value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_float4(kinc_g5_constant_buffer_t *buffer, int offset, float value1, float value2, float value3, float value4);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns a bunch of floats at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="location">The location of the constant/uniform to assign the values to</param>
 | |
| /// <param name="value">The values to write into the buffer</param>
 | |
| /// <param name="value">The number of values to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_floats(kinc_g5_constant_buffer_t *buffer, int offset, float *values, int count);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns a 3x3-matrix at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value">The value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_matrix3(kinc_g5_constant_buffer_t *buffer, int offset, kinc_matrix3x3_t *value);
 | |
| 
 | |
| /// <summary>
 | |
| /// Assigns a 4x4-matrix at an offset in a constant-buffer.
 | |
| /// </summary>
 | |
| /// <param name="offset">The offset at which to write the data</param>
 | |
| /// <param name="value">The value to write into the buffer</param>
 | |
| KINC_FUNC void kinc_g5_constant_buffer_set_matrix4(kinc_g5_constant_buffer_t *buffer, int offset, kinc_matrix4x4_t *value);
 | |
| 
 | |
| KINC_FUNC extern bool kinc_g5_transposeMat3;
 | |
| KINC_FUNC extern bool kinc_g5_transposeMat4;
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |