Texture pixels: Difference between revisions
|  (Add dds pixels format) | No edit summary | ||
| Line 22: | Line 22: | ||
| ----------- | ----------- | ||
| Pixels can also be loaded from any png/jpeg file just like this: | Pixels can also be loaded from any png/jpeg file just like this: | ||
| <syntaxhighlight lang="lua"> | |||
| local fileHandler = fileOpen("hello.jpg") | |||
| if (not fileHandler) then | |||
| 	return false | |||
| end | |||
| local fileSize = fileGetSize(fileHandler) | |||
| local filePixels = fileRead(fileHandler, fileSize) | |||
| fileClose(filePixels) | |||
| </syntaxhighlight> | |||
| Pixels can be used to create textures just like this: | Pixels can be used to create textures just like this: | ||
| <syntaxhighlight lang="lua"> | |||
| local myNewTexture = dxCreateTexture(pixelsData) | |||
| </syntaxhighlight> | |||
| Pixels can be used to save textures just like this: | Pixels can be used to save textures just like this: | ||
| <syntaxhighlight lang="lua"> | |||
| local texturePixels = dxGetTexturePixels(myRenderTarget) | |||
| local texturePixelsConverted = dxConvertPixels(texturePixels, "jpeg") | |||
| local fileHandler = fileCreate("piccy.jpg") | |||
| if (not fileHandler) then | |||
| 	return false | |||
| end | |||
| fileWrite(fileHandler, texturePixelsConverted) | |||
| fileClose(fileHandler) | |||
| </syntaxhighlight> | |||
| ====Pixels performance==== | ====Pixels performance==== | ||
Revision as of 19:13, 1 April 2025
Pixels
* MTA refers to the raw information that a texture contains as 'pixels'.
* Pixels can be retrieved from any texture type including render targets and screen sources by using the function dxGetTexturePixels.
* Pixels are just a string to Lua, so they can be saved to a file or even sent over the 'internet'.
Pixels properties
Pixels have two properties:
- dimensions (width and height) which is retrieved by using the function dxGetPixelsSize
- format (plain,jpeg,png,dds) which is retrieved by using the function dxGetPixelsFormat
- plain - Fastest and simplest - It's default format of the pixels returned by dxGetTexturePixels and the only one that can be used with dxSetTexturePixels, dxGetPixelColor and dxSetPixelColor. But it also uses a lot of bytes, so internet transfers will be longer. Also can't be read by Photoshop or browsers etc.
- png - A few less bytes, still quite big for net transfers. Can be saved to a file and read by Photoshop and browsers etc.
- jpeg - A lot less bytes, so best for net transfers. Can be saved to a file and read by Photoshop and browsers etc.
- dds - DirectDraw Surface. Game's native texture format with various compressed and uncompressed options. Used to store standard, cube or volume textures. Compressed pixels in this format can be loaded nearly instantly by dxCreateTexture.
 
To convert between the 3 different formats, use the function dxConvertPixels
Pixels more
Pixels can also be loaded from any png/jpeg file just like this:
local fileHandler = fileOpen("hello.jpg")
if (not fileHandler) then
	return false
end
local fileSize = fileGetSize(fileHandler)
local filePixels = fileRead(fileHandler, fileSize)
fileClose(filePixels)
Pixels can be used to create textures just like this:
local myNewTexture = dxCreateTexture(pixelsData)
Pixels can be used to save textures just like this:
local texturePixels = dxGetTexturePixels(myRenderTarget)
local texturePixelsConverted = dxConvertPixels(texturePixels, "jpeg")
local fileHandler = fileCreate("piccy.jpg")
if (not fileHandler) then
	return false
end
fileWrite(fileHandler, texturePixelsConverted)
fileClose(fileHandler)
Pixels performance
Getting/setting pixels from textures is not quick and not something you want to be doing every frame (in onClientRender for example). Setting pixels to a render target is especially slow. Pixels are ideal however for transferring composite images built on a render target into a normal texture for later use. For example, making a custom radar map.