Shader buffer storage object management (ssbo) and rest of rlgl texture management functions.

This commit is contained in:
jussi
2023-11-18 23:54:16 +02:00
parent d19864947b
commit 50d0e15ff4
9 changed files with 527 additions and 18 deletions

View File

@@ -2733,7 +2733,7 @@ int lcoreUpdateCamera3DPro( lua_State *L ) {
/*
> buffer = RL.LoadBuffer( data{} buffer, int type )
Load Buffer. Type should be one of the Buffer types
Load Buffer. Type should be one of the Buffer types. Empty buffer will set data to NULL.
- Success return Buffer
*/
@@ -2746,6 +2746,13 @@ int lcoreLoadBuffer( lua_State *L ) {
};
int len = uluaGetTableLen( L, 1 );
if ( len == 0 ) {
buffer.size = 0;
buffer.data = NULL;
uluaPushBuffer( L, buffer );
return 1;
}
buffer.size = len * getBufferElementSize( &buffer );
buffer.data = malloc( buffer.size );

View File

@@ -2344,7 +2344,14 @@ void luaRegister() {
/* Textures management. */
assingGlobalFunction( "rlLoadTexture", lrlglLoadTexture );
assingGlobalFunction( "rlLoadTextureDepth", lrlglLoadTextureDepth );
assingGlobalFunction( "rlLoadTextureCubemap", lrlglLoadTextureCubemap );
assingGlobalFunction( "rlUpdateTexture", lrlglUpdateTexture );
assingGlobalFunction( "rlGetGlTextureFormats", lrlglGetGlTextureFormats );
assingGlobalFunction( "rlGetPixelFormatName", lrlglGetPixelFormatName );
assingGlobalFunction( "rlUnloadTexture", lrlglUnloadTexture );
assingGlobalFunction( "rlGenTextureMipmaps", lrlglGenTextureMipmaps );
assingGlobalFunction( "rlReadTexturePixels", lrlglReadTexturePixels );
assingGlobalFunction( "rlReadScreenPixels", lrlglReadScreenPixels );
/* Framebuffer management (fbo). */
assingGlobalFunction( "rlLoadFramebuffer", lrlglLoadFramebuffer );
assingGlobalFunction( "rlFramebufferAttach", lrlglFramebufferAttach );
@@ -2364,6 +2371,14 @@ void luaRegister() {
/* Compute shader management */
assingGlobalFunction( "rlLoadComputeShaderProgram", lrlglLoadComputeShaderProgram );
assingGlobalFunction( "rlComputeShaderDispatch", lrlglComputeShaderDispatch );
/* Shader buffer storage object management (ssbo) */
assingGlobalFunction( "rlLoadShaderBuffer", lrlglLoadShaderBuffer );
assingGlobalFunction( "rlUnloadShaderBuffer", lrlglUnloadShaderBuffer );
assingGlobalFunction( "rlUpdateShaderBuffer", lrlglUpdateShaderBuffer );
assingGlobalFunction( "rlBindShaderBuffer", lrlglBindShaderBuffer );
assingGlobalFunction( "rlReadShaderBuffer", lrlglReadShaderBuffer );
assingGlobalFunction( "rlCopyShaderBuffer", lrlglCopyShaderBuffer );
assingGlobalFunction( "rlGetShaderBufferSize", lrlglGetShaderBufferSize );
/* Buffer management */
assingGlobalFunction( "rlBindImageTexture", lrlglBindImageTexture );
/* Matrix state management. */
@@ -3175,6 +3190,9 @@ void uluaPushGlyphInfo( lua_State *L, GlyphInfo glyphInfo, Image *image ) {
}
void uluaPushBuffer( lua_State *L, Buffer buffer ) {
if ( buffer.size == 0 ) {
buffer.data = NULL;
}
Buffer *bufferP = lua_newuserdata( L, sizeof( Buffer ) );
*bufferP = buffer;
luaL_setmetatable( L, "Buffer" );

View File

@@ -1224,18 +1224,19 @@ int lrlglDrawVertexArrayElementsInstanced( lua_State *L ) {
*/
/*
> id = RL.rlLoadTexture( Vector2 size, int format, int mipmapCount )
> id = RL.rlLoadTexture( Buffer data, Vector2 size, int format, int mipmapCount )
Load texture in GPU
- Success return int
*/
int lrlglLoadTexture( lua_State *L ) {
Vector2 size = uluaGetVector2( L, 1 );
int format = luaL_checkinteger( L, 2 );
int mipmapCount = luaL_checkinteger( L, 3 );
Buffer *data = uluaGetBuffer( L, 1 );
Vector2 size = uluaGetVector2( L, 2 );
int format = luaL_checkinteger( L, 3 );
int mipmapCount = luaL_checkinteger( L, 4 );
lua_pushinteger( L, rlLoadTexture( NULL, size.x, size.y, format, mipmapCount ) );
lua_pushinteger( L, rlLoadTexture( data->data, size.x, size.y, format, mipmapCount ) );
return 1;
}
@@ -1256,17 +1257,154 @@ int lrlglLoadTextureDepth( lua_State *L ) {
return 1;
}
/*
> id = RL.rlLoadTextureCubemap( Buffer data, int size, int format )
Load texture cubemap
- Success return int
*/
int lrlglLoadTextureCubemap( lua_State *L ) {
Buffer *data = uluaGetBuffer( L, 1 );
int size = luaL_checkinteger( L, 2 );
int format = luaL_checkinteger( L, 3 );
lua_pushinteger( L, rlLoadTextureCubemap( data->data, size, format ) );
return 1;
}
/*
> RL.rlUpdateTexture( int id, Vector2 offset, Vector2 size, int format, Buffer data )
Update GPU texture with new data
*/
int lrlglUpdateTexture( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
Vector2 offset = uluaGetVector2( L, 2 );
Vector2 size = uluaGetVector2( L, 3 );
int format = luaL_checkinteger( L, 4 );
Buffer *data = uluaGetBuffer( L, 5 );
rlUpdateTexture( id, (int)offset.x, (int)offset.y, (int)size.x, (int)size.y, format, data->data );
return 1;
}
/*
> glInternalFormat, glFormat, glType = RL.rlGetGlTextureFormats( int format )
Get OpenGL internal formats
- Success return int, int, int
*/
int lrlglGetGlTextureFormats( lua_State *L ) {
int format = luaL_checkinteger( L, 1 );
unsigned int glInternalFormat, glFormat, glType;
rlGetGlTextureFormats( format, &glInternalFormat, &glFormat, &glType );
lua_pushinteger( L, glInternalFormat );
lua_pushinteger( L, glFormat );
lua_pushinteger( L, glType );
return 3;
}
/*
> name = RL.rlGetPixelFormatName( int format )
Get name string for pixel format
- Success return string
*/
int lrlglGetPixelFormatName( lua_State *L ) {
int format = luaL_checkinteger( L, 1 );
lua_pushstring( L, rlGetPixelFormatName( format ) );
return 1;
}
/*
> RL.rlUnloadTexture( int id )
Unload texture from GPU memory
*/
int lrlglUnloadTexture( lua_State *L ) {
rlUnloadTexture( luaL_checkinteger( L, 1 ) );
rlUnloadTexture( (unsigned int)luaL_checkinteger( L, 1 ) );
return 0;
}
/*
> mipmapCount = RL.rlGenTextureMipmaps( int id, Vector2 size, int format )
Generate mipmap data for selected texture
- Success return int
*/
int lrlglGenTextureMipmaps( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
Vector2 size = uluaGetVector2( L, 2 );
int format = luaL_checkinteger( L, 3 );
int mipmaps = 0;
rlGenTextureMipmaps( id, (int)size.x, (int)size.y, format, &mipmaps );
lua_pushinteger( L, mipmaps );
return 1;
}
/*
> data = RL.rlReadTexturePixels( int id, Vector2 size, int format )
Read texture pixel data
- Success return Buffer
*/
int lrlglReadTexturePixels( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
Vector2 size = uluaGetVector2( L, 2 );
int format = luaL_checkinteger( L, 3 );
size_t dataSize = GetPixelDataSize( size.x, size.y, format );
Buffer data = {
.type = BUFFER_UNSIGNED_CHAR,
.size = dataSize,
.data = malloc( dataSize )
};
data.data = rlReadTexturePixels( id, (int)size.x, (int)size.y, format );
uluaPushBuffer( L, data );
return 1;
}
/*
> data = RL.rlReadScreenPixels( Vector2 size )
Read screen pixel data (color buffer)
- Success return Buffer
*/
int lrlglReadScreenPixels( lua_State *L ) {
Vector2 size = uluaGetVector2( L, 1 );
size_t dataSize = (int)size.x * (int)size.y * 4 * sizeof(unsigned char);
Buffer data = {
.type = BUFFER_UNSIGNED_CHAR,
.size = dataSize,
.data = malloc( dataSize )
};
data.data = rlReadScreenPixels( (int)size.x, (int)size.y );
uluaPushBuffer( L, data );
return 1;
}
/*
## RLGL - Framebuffer management (fbo)
*/
@@ -1525,6 +1663,124 @@ int lrlglComputeShaderDispatch( lua_State *L ) {
return 0;
}
/*
## RLGL - Shader buffer storage object management (ssbo)
*/
/*
> buffer = RL.rlLoadShaderBuffer( int size, Buffer data, int usageHint )
Load shader storage buffer object (SSBO)
- Success return int
*/
int lrlglLoadShaderBuffer( lua_State *L ) {
unsigned int size = (unsigned int)luaL_checkinteger( L, 1 );
Buffer *data = uluaGetBuffer( L, 2 );
int usageHint = luaL_checkinteger( L, 3 );
lua_pushinteger( L, rlLoadShaderBuffer( size, data->data, usageHint ) );
return 1;
}
/*
> RL.rlUnloadShaderBuffer( int ssboId )
Unload shader storage buffer object (SSBO)
*/
int lrlglUnloadShaderBuffer( lua_State *L ) {
unsigned int ssboId = (unsigned int)luaL_checkinteger( L, 1 );
rlUnloadShaderBuffer( ssboId );
return 0;
}
/*
> RL.rlUpdateShaderBuffer( int id, Buffer data, int offset )
Update SSBO buffer data
*/
int lrlglUpdateShaderBuffer( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
Buffer *data = uluaGetBuffer( L, 2 );
unsigned int offset = (unsigned int)luaL_checkinteger( L, 3 );
rlUpdateShaderBuffer( id, data->data, data->size, offset );
return 0;
}
/*
> RL.rlBindShaderBuffer( int id, int index )
Bind SSBO buffer
*/
int lrlglBindShaderBuffer( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
unsigned int index = (unsigned int)luaL_checkinteger( L, 2 );
rlBindShaderBuffer( id, index );
return 0;
}
/*
> data = RL.rlReadShaderBuffer( int id, int count, int offset )
Read SSBO buffer data (GPU->CPU)
- Success return Buffer
*/
int lrlglReadShaderBuffer( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
unsigned int count = (unsigned int)luaL_checkinteger( L, 2 );
unsigned int offset = (unsigned int)luaL_checkinteger( L, 3 );
Buffer dest = {
.type = BUFFER_UNSIGNED_CHAR,
.size = count,
.data = malloc( count * sizeof( unsigned char ) )
};
rlReadShaderBuffer( id, &dest.data, count, offset );
uluaPushBuffer( L, dest );
return 1;
}
/*
> RL.rlCopyShaderBuffer( int destId, int srcId, int destOffset, int srcOffset, int count )
Copy SSBO data between buffers
*/
int lrlglCopyShaderBuffer( lua_State *L ) {
unsigned int destId = (unsigned int)luaL_checkinteger( L, 1 );
unsigned int srcId = (unsigned int)luaL_checkinteger( L, 2 );
unsigned int destOffset = (unsigned int)luaL_checkinteger( L, 3 );
unsigned int srcOffset = (unsigned int)luaL_checkinteger( L, 4 );
unsigned int count = (unsigned int)luaL_checkinteger( L, 5 );
rlCopyShaderBuffer( destId, srcId, destOffset, srcOffset, count );
return 0;
}
/*
> size = RL.rlGetShaderBufferSize( int id )
Get SSBO buffer size
- Success return int
*/
int lrlglGetShaderBufferSize( lua_State *L ) {
unsigned int id = (unsigned int)luaL_checkinteger( L, 1 );
lua_pushinteger( L, rlGetShaderBufferSize( id ) );
return 1;
}
/*
## RLGL - Buffer management
*/