SetElementModel: Difference between revisions

From Multi Theft Auto: Wiki
Jump to navigation Jump to search
No edit summary
m (Edited language change)
 
(7 intermediate revisions by 4 users not shown)
Line 8: Line 8:
bool setElementModel ( element theElement, int model )
bool setElementModel ( element theElement, int model )
</syntaxhighlight>
</syntaxhighlight>
{{OOP||[[element]]:setModel|model|getElementModel}}


===Required Arguments===
===Required Arguments===
Line 21: Line 22:
==Example==
==Example==
<section class="server" name="Example 1 (Server)" show="true">
<section class="server" name="Example 1 (Server)" show="true">
This example allows players to change their own skin with a command (/skin [ID])
<syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
addCommandHandler ( "changeveh",
local spam = {}
    function ( thePlayer, command, newModel )
 
        local theVehicle = getPedOccupiedVehicle ( thePlayer ) -- get the vehicle the player is in
function setSkin(player, cmd, skin)
         newModel = tonumber ( newModel )                         -- try to convert the string argument to a number
    if spam[player] and getTickCount() - spam[player] < 4000 then
         if theVehicle and newModel then                           -- make sure the player is in a vehicle and specified a number
         return outputChatBox("You cannot change skin that often!", player, 255, 0, 0)
            setElementModel ( theVehicle, newModel )
    end
         end
 
    skin = skin and tonumber(skin)
 
    if getElementModel(player) == skin or isPedDead(player) then
         return
    end
 
    if skin and skin <= 99999 then -- what do we know about dynamic ped ID range?
        setElementModel(player, skin)
         spam[player] = getTickCount()
    else
        outputChatBox("Invalid skin ID!", player, 255, 0, 0)
    end
end
addCommandHandler("skin", setSkin)
 
function cleanUp()
    if spam[source] then
        spam[source] = nil
     end
     end
)
end
addEventHandler("onPlayerQuit", root, cleanUp)
</syntaxhighlight>
</syntaxhighlight>
After the above code is executed, a player can get in any vehicle and execute e.g. the command "/changeveh 520" to change it into a hydra.
</section>
</section>
<section class="server" name="Example 2 (Server)" show="true">
<section class="server" name="Example 2 (Server)" show="true">
This will continually change an object model every 2.5 seconds at the location -1084.52, -1634.81, 76.36 (Truth's farm).
This example allows players to transform their current vehicle into another vehicle model.
<syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
myobject = createObject ( 5822, -1084.52, -1634.81, 76.36 )
local spam = {}
-- We create an initial object element. I choose object model 5822 to begin with.
 
function changeMyVehicle(player, command, newModel)
if spam[player] and getTickCount() - spam[player] < 2500 then
return outputChatBox("Don't spam vehicle changes!", player, 255, 0, 0)
end
 
local theVehicle = getPedOccupiedVehicle(player)
if not (theVehicle and getVehicleController(theVehicle) == player) then
return outputChatBox("You must be driving a vehicle in order to change it!", player, 255, 0, 0)
end
 
if isValidModel(newModel) and isElement(theVehicle) then
setElementModel(theVehicle, newModel)
spam[player] = getTickCount()
else
outputChatBox("Invalid vehicle ID!", player, 255, 0, 0)
end
end
addCommandHandler("changeveh", changeMyVehicle)


function objectRandomization ()
function isValidModel(modelID)
    local randomobjectnumber = math.random(1, 18000)
modelID = tonumber(modelID)
    -- Choose a random number between 1 and 18000 as a whole integer and assign it to
if modelID and modelID >= 400 and modelID <= 611 then
    -- the variable 'randomobjectnumber'
return true
    setElementModel ( myobject, randomobjectnumber )
end
    -- Change our object appearance by applying a new model ID
return false
end
end


setTimer ( objectRandomization, 2500, 0 )
function cleanUp()
-- Every 2.5 seconds, the function 'objectRandomization' is called by this timer.
if spam[source] then
-- Each time the function runs, it changes the object model by applying a new whole-
spam[source] = nil
-- integer random object ID. This timer is called an infinite amount of times since 
end
-- its repeat value is set to 0.
end
addEventHandler("onPlayerQuit", root, cleanUp)
</syntaxhighlight>
</syntaxhighlight>
</section>
</section>
Line 58: Line 98:
==See Also==
==See Also==
{{Element functions}}
{{Element functions}}
[[ru:setElementModel]]

Latest revision as of 17:36, 6 June 2022

Sets the model of a given element. This allows you to change the model of a player (or ped), a vehicle or an object.

Syntax

bool setElementModel ( element theElement, int model )

OOP Syntax Help! I don't understand this!

Method: element:setModel(...)
Variable: .model
Counterpart: getElementModel


Required Arguments

  • theElement: the element you want to change.
  • model: the model ID to set.
    • For players/peds: A GTASA player model (skin) ID. See Character Skins.
    • For vehicles: The vehicle ID of the vehicle being changed.
    • For objects/projectiles/weapons: An int specifying the model id.

Returns

Returns true if successful, false otherwise.

Example

Click to collapse [-]
Example 1 (Server)

This example allows players to change their own skin with a command (/skin [ID])

local spam = {}

function setSkin(player, cmd, skin)
    if spam[player] and getTickCount() - spam[player] < 4000 then
        return outputChatBox("You cannot change skin that often!", player, 255, 0, 0)
    end

    skin = skin and tonumber(skin)

    if getElementModel(player) == skin or isPedDead(player) then
        return
    end

    if skin and skin <= 99999 then -- what do we know about dynamic ped ID range?
        setElementModel(player, skin)
        spam[player] = getTickCount()
    else
        outputChatBox("Invalid skin ID!", player, 255, 0, 0)
    end
end
addCommandHandler("skin", setSkin)

function cleanUp()
    if spam[source] then
        spam[source] = nil
    end
end
addEventHandler("onPlayerQuit", root, cleanUp)
Click to collapse [-]
Example 2 (Server)

This example allows players to transform their current vehicle into another vehicle model.

local spam = {}

function changeMyVehicle(player, command, newModel)
	if spam[player] and getTickCount() - spam[player] < 2500 then
		return outputChatBox("Don't spam vehicle changes!", player, 255, 0, 0)
	end

	local theVehicle = getPedOccupiedVehicle(player)
	
	if not (theVehicle and getVehicleController(theVehicle) == player) then
		return outputChatBox("You must be driving a vehicle in order to change it!", player, 255, 0, 0)
	end

	if isValidModel(newModel) and isElement(theVehicle) then
		setElementModel(theVehicle, newModel)
		spam[player] = getTickCount()
	else
		outputChatBox("Invalid vehicle ID!", player, 255, 0, 0)
	end
end
addCommandHandler("changeveh", changeMyVehicle)

function isValidModel(modelID)
	modelID = tonumber(modelID)
	if modelID and modelID >= 400 and modelID <= 611 then
		return true
	end
	return false
end

function cleanUp()
	if spam[source] then
		spam[source] = nil
	end
end
addEventHandler("onPlayerQuit", root, cleanUp)

See Also