Resource:Object preview: Difference between revisions
| No edit summary | mNo edit summary | ||
| (13 intermediate revisions by 6 users not shown) | |||
| Line 13: | Line 13: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| Creates the preview for provided world,ped or vehicle element. | Creates the preview for provided world,ped or vehicle element. | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:createObjectPreview(element object, float rotX rotY, rotZ, projPosX, projPosY, projSizeX, projSizeY [, bool isRelative = false, postGUI = false, isSecRT = true])</syntaxhighlight>   | <syntaxhighlight lang="lua">bool exports.object_preview:createObjectPreview(element object, float rotX, float rotY, float rotZ, float projPosX, float projPosY, float projSizeX, float projSizeY [, bool isRelative = false, postGUI = false, isSecRT = true])</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''float rotX, rotY, rotZ:''' Object rotation in camera space. | *'''float rotX, rotY, rotZ:''' Object rotation in camera space. | ||
| Line 20: | Line 20: | ||
| ===Optional Arguments=== | ===Optional Arguments=== | ||
| *'''bool isRelative:''' Are the projector parameters relative. | *'''bool isRelative:''' Are the projector parameters relative. | ||
| *'''bool postGUI:''' Should the  | *'''bool postGUI:''' Should the object be drawn before or after MTA GUI elements. | ||
| *'''isSecRT:''' Should  | *'''isSecRT:''' Should the object be drawin to second render target. | ||
| ===Returns=== | ===Returns=== | ||
| The function returns the element if set successfully, 'false' otherwise. | The function returns the element if set successfully, 'false' otherwise. | ||
| Line 50: | Line 50: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function sets object rotation. | This function sets object rotation. | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:setRotation(element objectPreviewElement,float rotX,  | <syntaxhighlight lang="lua">bool exports.object_preview:setRotation(element objectPreviewElement, float rotX, float rotY, float rotZ)</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''element objectPreviewElement:''' A previously declared preview element. | *'''element objectPreviewElement:''' A previously declared preview element. | ||
| *'''float rotX,  | *'''float rotX, rotY, rotZ:''' Object rotation in camera space. | ||
| ===Returns=== | ===Returns=== | ||
| The function returns true if set successfully, false otherwise. | The function returns true if set successfully, false otherwise. | ||
| Line 61: | Line 61: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function sets object on screen position and size. | This function sets object on screen position and size. | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:setProjection(element objectPreviewElement, float projPosY, projSizeX, projSizeY [, bool isRelative = false])</syntaxhighlight>   | <syntaxhighlight lang="lua">bool exports.object_preview:setProjection(element objectPreviewElement, float projPosX, float projPosY, float projSizeX, float projSizeY [, bool isRelative = false])</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''element objectPreviewElement:''' A previously declared preview element. | *'''element objectPreviewElement:''' A previously declared preview element. | ||
| Line 75: | Line 75: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function sets object alpha transparency. | This function sets object alpha transparency. | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:setAlpha(element objectPreviewElement,int alpha)</syntaxhighlight>   | <syntaxhighlight lang="lua">bool exports.object_preview:setAlpha(element objectPreviewElement, int alpha)</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''element objectPreviewElement:''' A previously declared preview element. | *'''element objectPreviewElement:''' A previously declared preview element. | ||
| Line 86: | Line 86: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function returns a renderTarget (Only when drawing to second render target is enabled) | This function returns a renderTarget (Only when drawing to second render target is enabled) | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:getRenderTarget( | <syntaxhighlight lang="lua">bool exports.object_preview:getRenderTarget()</syntaxhighlight> | ||
| ===Returns=== | ===Returns=== | ||
| The function returns render target if set successfully, false otherwise. | The function returns render target if set successfully, false otherwise. | ||
| Line 96: | Line 94: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function sets the difference between object to camera distance set by MTA and that set by shader. | This function sets the difference between object to camera distance set by MTA and that set by shader. | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:setDistanceSpread(element objectPreviewElement,float zSpread)</syntaxhighlight>   | <syntaxhighlight lang="lua">bool exports.object_preview:setDistanceSpread(element objectPreviewElement, float zSpread)</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''element objectPreviewElement:''' A previously declared preview element. | *'''element objectPreviewElement:''' A previously declared preview element. | ||
| Line 107: | Line 105: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function sets object position to camera offsets (standard is 0,0,0) | This function sets object position to camera offsets (standard is 0,0,0) | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:setPositionOffsets(element objectPreviewElement,float posX,  | <syntaxhighlight lang="lua">bool exports.object_preview:setPositionOffsets(element objectPreviewElement, float posX, float posY, float posZ)</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''element objectPreviewElement:''' A previously declared preview element. | *'''element objectPreviewElement:''' A previously declared preview element. | ||
| *'''float posX,  | *'''float posX, posY, posZ:''' Object position to camera offsets. | ||
| ===Returns=== | ===Returns=== | ||
| The function returns true if set successfully, false otherwise. | The function returns true if set successfully, false otherwise. | ||
| Line 118: | Line 116: | ||
| <section name="Client" class="client" show="true"> | <section name="Client" class="client" show="true"> | ||
| This function sets object rotation centre offsets (standard is 0,0,0) | This function sets object rotation centre offsets (standard is 0,0,0) | ||
| <syntaxhighlight lang="lua">bool exports.object_preview:setRotationOffsets(element objectPreviewElement,float  | <syntaxhighlight lang="lua">bool exports.object_preview:setRotationOffsets(element objectPreviewElement, float rotX, float rotY, float rotZ)</syntaxhighlight>   | ||
| ===Required Arguments===   | ===Required Arguments===   | ||
| *'''element objectPreviewElement:''' A previously declared preview element. | *'''element objectPreviewElement:''' A previously declared preview element. | ||
| *'''float  | *'''float rotX, rotY, rotZ:''' Object rotation centre offsets. | ||
| ===Returns=== | ===Returns=== | ||
| The function returns true if set successfully, false otherwise. | The function returns true if set successfully, false otherwise. | ||
| </section> | </section> | ||
| == | ==Example==   | ||
| <syntaxhighlight lang="lua">local scx, scy = guiGetScreenSize () | <syntaxhighlight lang="lua"> | ||
| local myObject,myElement, guiWindow = nil, nil, nil | local scx, scy = guiGetScreenSize() | ||
| local myRotation = {0,0,0} | local myObject, myElement, guiWindow = nil, nil, nil | ||
| local myRotation = {0, 0, 0} | |||
| addEventHandler("onClientResourceStart",  | addEventHandler("onClientResourceStart", resourceRoot, function() | ||
| 	local x1, y1, z1 = getCameraMatrix() | 	local x1, y1, z1 = getCameraMatrix() | ||
| 	myElement = createVehicle ( | 	myElement = createVehicle(416, x1, y1, z1) | ||
| 	myObject =  | 	myObject = exports.object_preview:createObjectPreview(myElement,0, 0, 0, 0.5, 0.5, 1, 1, true, true, true) | ||
| 	guiWindow = guiCreateWindow((scx/2)-100,(scy/2) - 100,200,200, "Test area", false, false) | 	guiWindow = guiCreateWindow((scx/2)-100,(scy/2) - 100,200,200, "Test area", false, false) | ||
| 	guiSetAlpha(guiWindow, 0.05 + 0.2) | 	guiSetAlpha(guiWindow, 0.05 + 0.2) | ||
| Line 144: | Line 143: | ||
| 	bindKey ( "num_4", "down", function() myRotation[1] = myRotation[1] - 5 end) | 	bindKey ( "num_4", "down", function() myRotation[1] = myRotation[1] - 5 end) | ||
|     bindKey ( "num_6", "down", function() myRotation[1] = myRotation[1] + 5 end) | |||
| 	bindKey ( "num_add", "down", function() myRotation[2] = myRotation[2] - 5 end) | 	bindKey ( "num_add", "down", function() myRotation[2] = myRotation[2] - 5 end) | ||
|     bindKey ( "num_sub", "down", function() myRotation[2] = myRotation[2] + 5 end) | |||
| 	bindKey ( "num_2", "down", function() myRotation[3] = myRotation[3] - 5 end) | 	bindKey ( "num_2", "down", function() myRotation[3] = myRotation[3] - 5 end) | ||
| 	bindKey ( "num_8", "down", function() myRotation[3] = myRotation[3] + 5 end) | 	bindKey ( "num_8", "down", function() myRotation[3] = myRotation[3] + 5 end) | ||
| Line 156: | Line 157: | ||
| 	local projPosX, projPosY = guiGetPosition(guiWindow,true) | 	local projPosX, projPosY = guiGetPosition(guiWindow,true) | ||
| 	local projSizeX, projSizeY = guiGetSize(guiWindow, true) | 	local projSizeX, projSizeY = guiGetSize(guiWindow, true) | ||
|     exports.object_preview:setProjection(myObject,projPosX, projPosY, projSizeX, projSizeY, true, true) | |||
|     exports.object_preview:setRotation(myObject, unpack(myRotation));  | |||
| end, true, "high" ) | end, true, "high" ) | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| This creates a vehicle, applies object preview and scales it using dimensions of a window element. | This creates a vehicle, applies object preview and scales it using dimensions of a window element. | ||
| Line 168: | Line 165: | ||
| Of course when you want to use these functions in your resources you have to include | Of course when you want to use these functions in your resources you have to include | ||
| the object_preview resource in meta. | the object_preview resource in meta. | ||
| ==See Also== | |||
| [https://community.multitheftauto.com/index.php?p=resources&s=details&id=11836 Object Preview resource on community] | |||
Latest revision as of 17:35, 25 April 2025
This resource lets you create an object that will be drawn on the screen provided size and position - just like when drawing an image. This way it is easy to create object preview on GUI (supports drawing in a separate render target). Works with peds, world objects and vehicles.
Overview
The resource itself adds exported client-side functions:
Exported functions
createObjectPreview
Creates the preview for provided world,ped or vehicle element.
bool exports.object_preview:createObjectPreview(element object, float rotX, float rotY, float rotZ, float projPosX, float projPosY, float projSizeX, float projSizeY [, bool isRelative = false, postGUI = false, isSecRT = true])
Required Arguments
- float rotX, rotY, rotZ: Object rotation in camera space.
- float projPosX, projPosY: Projector left corner on the screen.
- float projSizeX, projSizeY: Projector size.
Optional Arguments
- bool isRelative: Are the projector parameters relative.
- bool postGUI: Should the object be drawn before or after MTA GUI elements.
- isSecRT: Should the object be drawin to second render target.
Returns
The function returns the element if set successfully, 'false' otherwise.
destroyObjectPreview
Destroys previously created preview - without destroying the object it was applied to.
bool exports.object_preview:destroyObjectPreview(element objectPreviewElement)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
Returns
The function returns true if set successfully, false otherwise.
saveRTToFile
Save render target to png file. (Only when drawing to second render target is enabled)
bool exports.object_preview:saveRTToFile(element objectPreviewElement, string path)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- string path: An exact client resource path the file is to be saved to.
Returns
The function returns true if set successfully, false otherwise. It saves the image in client resource path.
setRotation
This function sets object rotation.
bool exports.object_preview:setRotation(element objectPreviewElement, float rotX, float rotY, float rotZ)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- float rotX, rotY, rotZ: Object rotation in camera space.
Returns
The function returns true if set successfully, false otherwise.
setProjection
This function sets object on screen position and size.
bool exports.object_preview:setProjection(element objectPreviewElement, float projPosX, float projPosY, float projSizeX, float projSizeY [, bool isRelative = false])
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- float projPosX, projPosY: Projector left corner on the screen.
- float projSizeX, projSizeY: Projector size.
Optional Arguments
- bool isRelative: Are the projector parameters relative.
Returns
The function returns true if set successfully, false otherwise.
setAlpha
This function sets object alpha transparency.
bool exports.object_preview:setAlpha(element objectPreviewElement, int alpha)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- int alpha: Object alpha (0 - 255).
Returns
The function returns true if set successfully, false otherwise.
getRenderTarget
This function returns a renderTarget (Only when drawing to second render target is enabled)
bool exports.object_preview:getRenderTarget()
Returns
The function returns render target if set successfully, false otherwise.
setDistanceSpread
This function sets the difference between object to camera distance set by MTA and that set by shader.
bool exports.object_preview:setDistanceSpread(element objectPreviewElement, float zSpread)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- float zSpread: Object Distance spread.
Returns
The function returns true if set successfully, false otherwise.
setPositionOffsets
This function sets object position to camera offsets (standard is 0,0,0)
bool exports.object_preview:setPositionOffsets(element objectPreviewElement, float posX, float posY, float posZ)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- float posX, posY, posZ: Object position to camera offsets.
Returns
The function returns true if set successfully, false otherwise.
setRotationOffsets
This function sets object rotation centre offsets (standard is 0,0,0)
bool exports.object_preview:setRotationOffsets(element objectPreviewElement, float rotX, float rotY, float rotZ)
Required Arguments
- element objectPreviewElement: A previously declared preview element.
- float rotX, rotY, rotZ: Object rotation centre offsets.
Returns
The function returns true if set successfully, false otherwise.
Example
local scx, scy = guiGetScreenSize()
local myObject, myElement, guiWindow = nil, nil, nil
local myRotation = {0, 0, 0}
addEventHandler("onClientResourceStart", resourceRoot, function()
	local x1, y1, z1 = getCameraMatrix()
	myElement = createVehicle(416, x1, y1, z1)
	myObject = exports.object_preview:createObjectPreview(myElement,0, 0, 0, 0.5, 0.5, 1, 1, true, true, true)
	guiWindow = guiCreateWindow((scx/2)-100,(scy/2) - 100,200,200, "Test area", false, false)
	guiSetAlpha(guiWindow, 0.05 + 0.2)
	local projPosX, projPosY = guiGetPosition(guiWindow,true)
	local projSizeX, projSizeY = guiGetSize(guiWindow, true)	
	exports.object_preview:setProjection(myObject,projPosX, projPosY, projSizeX, projSizeY,true,true)
	exports.object_preview:setRotation(myObject,myRotation[1], myRotation[2], myRotation[3])
	
	bindKey ( "num_4", "down", function() myRotation[1] = myRotation[1] - 5 end)
    bindKey ( "num_6", "down", function() myRotation[1] = myRotation[1] + 5 end)
    
	bindKey ( "num_add", "down", function() myRotation[2] = myRotation[2] - 5 end)
    bindKey ( "num_sub", "down", function() myRotation[2] = myRotation[2] + 5 end)
    
	bindKey ( "num_2", "down", function() myRotation[3] = myRotation[3] - 5 end)
	bindKey ( "num_8", "down", function() myRotation[3] = myRotation[3] + 5 end)
	bindKey ( "o", "down", function() exports.object_preview:saveRTToFile(myObject,math.random(100)..".png") end)
end)
addEventHandler("onClientPreRender", root, function()
	if not myElement or not myObject then return end
	local projPosX, projPosY = guiGetPosition(guiWindow,true)
	local projSizeX, projSizeY = guiGetSize(guiWindow, true)
    exports.object_preview:setProjection(myObject,projPosX, projPosY, projSizeX, projSizeY, true, true)
    exports.object_preview:setRotation(myObject, unpack(myRotation)); 
end, true, "high" )
This creates a vehicle, applies object preview and scales it using dimensions of a window element.
Of course when you want to use these functions in your resources you have to include the object_preview resource in meta.