Saltar al contenido
Bits antidisturbios

Bits antidisturbios

  • Hogar
  • Noticias
  • Guías
  • Videoguías
  • Notas del parche
  • Reportar abuso
  • Alternar formulario de búsqueda
Tabletop Simulator

Tabletop Simulator – Trigger Game Action by Placing a Piece on a Tile

Publicado el 04/10/202204/10/2022 Por CareyMcDuff No hay comentarios en Tabletop Simulator – Trigger Game Action by Placing a Piece on a Tile
  • Título: Tabletop Simulator
  • Fecha de lanzamiento:
  • Revelador:
  • Editor:
Information about Tabletop Simulator is still incomplete. Por favor ayúdanos a completar los detalles del juego usando esto formulario de contacto.

Instead of using a button to trigger a script action, simulate the board game environment by triggering a script action by placing a game piece on a tile.

This intermediate guide assumes basic knowledge of lua scripting.

Generalmente, a mod will use a button to trigger a script action. This works well, but is not in keeping with TTS as a simulation of a board game.

Another approach is to use a custom tile or token. The player can trigger a script action by placing a specific game piece on the tile.

Basic Approach

This approach uses the onCollisionEnter() función. If this function is included in the object script attached to the tile, it will be called every time a game piece makes contact with the tile.

The onCollisionEnter() function must be in the object script for the tile. It will not work if it is in the global script.

A simple function looks like this:

function  onCollisionEnter(collision_info)
  -- collision_info table:
  -- collision_object    Object
  -- contact_points      Table     {Vector, ...}
  -- relative_velocity   Vector
  local piece = 'guidaa' -- the guid of the piece that triggers the action
  local guid = collision_info.collision_object.getGUID()
  if guid == piece then
    return Global:llamar('desiredAction') -- string name of the function to be called
  end
end


Note that the function is called any time that any object makes contact with the tile, so the first step of the function must be to check if the object making contact is the one that should trigger the action.

Instead of using the guid to identify the object making contact, you could use the object’s name, description or gmnotes using getName(), getDescription() or getGMNotes() in place of getGUID().

Different Pieces Trigger Different Actions

To take this approach a step further, you could set up different game pieces that trigger different actions when they are placed on the tile.

Use a function like this:

function  onCollisionEnter(collision_info)
  local piece = {['guidaa'] = 1, ['guidbb'] = 2, ['guidcc'] = 3}
  -- guids as keys in the table are easier to check
  local guid = collision_info.collision_object.getGUID()
  local somedata
  -- somedata to pass to the Global script,
  -- p.ej. the action to trigger
  -- include somedata as values in piece{}
 if piece[guía] then
    somedata = piece[guía]
    -- pass somedata to the Global script
    return Global:llamar('desiredAction', {somedata})
  end
end

Trigger Different Actions by Location Placed

Going further, you could also set up the tile so that the player can trigger different actions by placing a game piece on different places on the game tile.

Por ejemplo, you could design the image for the tile to be divided into four quadrants.

This function triggers different actions depending on which quadrant of the tile is contacted.

function  onCollisionEnter(collision_info)
  local piece = 'guidaa'
  -- shorthand reference to the contacting obj
  local obj = collision_info.collision_object
  local guid = obj.getGUID()
  local somedata
  if guid == piece then
    -- find the midpoint between contact points
    local hit1 = self.positionToLocal(obj.contact_points[1] or obj.contact_points[3])
    local hit3 = self.positionToLocal(obj.contact_points[3] or obj.contact_points[1])
    -- use 'or' in case the piece is not entirely on the tile
    local hitx = (hit1.x+hit3.x)/2
    local hitz = (hit1.z+hit3.z)/2
    -- típicamente, you could divide the tile into quarters using the x and z coordinates
    if hitz < 0 then if hitx > 0 then
        somedata = 1
      else
        somedata = 2
      end
    else
      if hitx > 0 then
        somedata = 3
      else
        somedata = 4
      end
    end
    -- pass somedata to the Global script
    return Global:llamar('desiredAction', {guía, somedata})
  end
end


This last step can be tricky, because it is not always intuitive how the x,y,z coordinates in TTS are determined. Por ejemplo, it can depend on how the tile is rotated or flipped. You may need to experiment a bit. You could add the line log(hitx..» «..hitz) to the function to output the values to the console as you experiment.

Variation

The purpose of the approach described here is to trigger a game action when a player places a relevant piece on the tile. That is why this approach uses the onCollisionEnter() función.

If instead you want the function to activate only when it is called in the script, you could use a slightly different approach. Por ejemplo, you may want the script to check an option that a player has chosen. The guide linked below describes that approach.

Solucionar problemas

El onCollisionEnter() function may be triggered multiple times if a piece jostles against the tile. A fix for this is to avoid triggering the function if not enough time has passed since the tile was last contacted. para hacer esto, include this code at the beginning of the function.

if Time.time - (segundos o 0) < 1 then
  return
else
  seconds = Time.time
end

Note that the variable for seconds has to be a global variable. Si no es, it may be reset every time the function is called. Watch out for conflicts with other global variables.

Eso es todo lo que estamos compartiendo hoy para este Tabletop Simulator guía. Esta guía fue originalmente creada y escrita por CareyMcDuff. En caso de que no actualicemos esta guía, puede encontrar la última actualización siguiendo este enlace.

Si cree que alguno de los contenidos de este sitio viola sus derechos, incluyendo sus derechos de propiedad intelectual, por favor contáctenos inmediatamente usando nuestro formulario de contacto.
Guías Etiquetas:Tabletop Simulator

Navegación de entradas

Publicación anterior: LEGO Star Wars The Skywalker Saga – Easy Stud Farming Guide
Publicación siguiente: Tabletop Simulator – Use Description to Show Objects Beneath an Object

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

  • Título: Tabletop Simulator
  • Fecha de lanzamiento:
  • Revelador:
  • Editor:
Information about Tabletop Simulator is still incomplete. Por favor ayúdanos a completar los detalles del juego usando esto formulario de contacto.

Descargo de responsabilidad

Todo el contenido citado se deriva de sus respectivas fuentes.. Si cree que hemos utilizado su contenido sin permiso, asegúrese de comunicarse con nosotros y lo tomaremos en serio.
  • Sobre nosotros
  • Contáctenos
  • política de privacidad
  • Términos de servicio

Derechos de autor © 2025 Bits antidisturbios.

Funciona con Tema PressBook Noticias para WordPress