TrainCarts/Signs

From BergerHealer Wiki
Jump to navigation Jump to search
No edit summary
No edit summary
 
(17 intermediate revisions by 2 users not shown)
Line 1: Line 1:
[[TrainCarts|« Go back]]
<languages/>
 
<translate>
<!--T:2-->
TrainCarts allows you to perform actions on trains or single cars using signs.
TrainCarts allows you to perform actions on trains or single cars using signs.


= Structure and Behaviour  =
= Structure and Behaviour  = <!--T:3-->
[[Image:TrainCarts signs intro image.png|thumb|right|A first glance at the sign format]]
[[Image:TrainCarts signs intro image.png|thumb|right|A first glance at the sign format]]


A sign is always structured the same way. The first line contains either *cart* or *train* depending on if you want to target each cart separately or the train as a whole. It is worth to note, that not every sign allows targeting of a single cart.
<!--T:4-->
A sign is always structured the same way. The first line contains either '''cart''' or '''train''' depending on if you want to target each cart separately or the train as a whole. You can then optionally specify the way the sign responds to redstone and what direction the train must be coming from.


== Redstone ==
== Redstone == <!--T:5-->


Signs can either be powered by or activate Redstone themself.
<!--T:6-->
<br>Some signs may require you to power them using Redstone. Some common examples are stations or spawners. In order to power them will you just need to put a power source next to the sign. A power source can be Redstone dust (Doesn't require to point into the sign), levers, buttons, etc.
'''TrainCarts signs require Redstone power to function.''' This means signs will not do anything unless you put a redstone torch or other power signal next to it. If you want to use signs without adding redstone torches, you can make use of a special syntax on the first line, which is the same for [train] and [cart]. Generally you will want to use '''[+train]''' to make the sign function.
<br>If you want to have the sign to be always active without the usage of Redstone can you either add an exclamation mark (!) or a plus (+) in front of ''train'' or ''cart'', becoming ''[!train]'' and ''[!cart]'' respectively. Note that both will alter how the sign may output a Redstone signal itself. For the exclamation mark will the input and output be inverted and for plus will it be constantly active while ignoring any outside Redstone input.
 
 
<!--T:27-->
{| class="wikitable" style="margin:auto"
|+ TrainCarts Sign Power Modes
|-
! First Line !! Explanation
|-
| [train] || The default mode. Sign only works when redstone power is provided
|-
| [+train] || Always on power mode. Signs works all the time regardless of whether redstone power is provided
|-
| [!train] || Inverted power mode. Sign works all the time and turns off when redstone power is provided. Works the same as [+train] when no redstone torch is used.
|-
| [-train] || Always off power mode. Signs don't respond to redstone power. Only useful for the [[TrainCarts/Signs/Switcher|switcher sign]].
|-
| [/train] || On-pulse power mode. Signs only activate once when redstone power goes from off to on, and don't respond to trains riding over it
|-
| [\train] || Off-pulse power mode. Signs only activate once when redstone power goes from on to off, and don't respond to trains riding over it
|-
| [/\train] || Redstone change power mode. Signs only activate once when redstone power switches state, and don't respond to trains riding over it
|}


In addition, may a sign also power Redstone, by having a lever attached to the block they are attached to themself. When a specific action is performed (i.e. a Trains stops on top of a station sign) will the lever be activated, allowing the Redstone or Redstone Component to get powered. As mentioned above, would using an exclamation mark before ''train'' or ''cart'' invert the Redstone state it would give. An ''active'' state would not give out any Redstone signal while an ''inactive'' will.
=== Lever Output === <!--T:28-->
Signs can output a redstone signal as well by attaching a '''lever''' to the same block the sign is also attached to. Only a few signs activate the lever, like the [[TrainCarts/Signs/Station|station]] sign that activates it when trains stop on top of the station.


You may further change what cart/train is targeted, by adding a colon (:) after either cart or train, followed by one or multiple [[TrainCarts/Signs/Direction|direction(s)]]. For example, ''[train:lr]'' on a switcher sign would activate a lever when a train enters from either the left or right direction and doesn't for the remaining ones.
== Activation Direction == <!--T:29-->
By default signs only activate when the train ''sees'' the front or sides of the sign. This means you should place signs facing the direction of train movement. To override this behavior you can set these activation directions by adding a colon (:) followed by one or more [[Special:MyLanguage/TrainCarts/Signs/Direction|directions]]. If you want the sign to always respond, just use '''[train:*]'''.


Depending on the sign can you add further customisation to target specific carts/trains or to perform certain things based on conditions. Please check the sign's specific page to check if it allows such further customisation.
<!--T:30-->
For example, '''[-train:lr]''' on a switcher sign would activate a lever when a train enters from either the sign-relative left or right direction and doesn't for the remaining ones. It uses '''-train''' [[TrainCarts/Signs/Switcher#Syntax|so that it does not switch the track]].


== Remote Control ==
== Remote Control == <!--T:10-->


A few sign systems support remote control: the ability to control trains by name. You then use the ''[train <name>]'' format, or the shorter alias ''[t <name>]''. Remotely controlled signs only respond to redstone changes, thus where you place them is not important. So far the property, destination, destroy, eject  and setblock sign systems support remote control.
<!--T:11-->
A few sign systems support remote control: the ability to control trains by name. You then use the ''[train <name>]'' format, or the shorter alias ''[t <name>]''. Remotely controlled signs only respond to redstone changes, thus where you place them is not important. The signs that support this feature are listed in the [[#Types|Types]] table down below.


<!--T:12-->
Remote control can also affect multiple trains. Just like the tag system, remote control uses *-signs to identify the trains to affect. For example, the following remote control sign will set the destination to ''home'' for all intercity trains:
Remote control can also affect multiple trains. Just like the tag system, remote control uses *-signs to identify the trains to affect. For example, the following remote control sign will set the destination to ''home'' for all intercity trains:


</translate>
{{sign|[train Intercity*]|property|destination|interhome}}
{{sign|[train Intercity*]|property|destination|interhome}}
<translate>


the setblock sign works too!
<!--T:14-->
You can use this to recall all your trains easily. If you use tags to navigate trains, you can also add a tag saying that the train should return.


You can use this to recall all your trains easily. If you use tags to navigate trains, you can also add a tag saying that the train should return. Remote control signs only respond to redstone changes.
= Placement  = <!--T:15-->
 
= Placement  =
[[Image:Track switcher example 1.png|thumb|right|Empty minecarts are blocked]]
[[Image:Track switcher example 1.png|thumb|right|Empty minecarts are blocked]]
[[Image:TrainCarts sign example 2.png|thumb|right|Trains are switched left and right using a 1:1 counter]]
[[Image:TrainCarts sign example 2.png|thumb|right|Trains are switched left and right using a 1:1 counter]]
Each sign targets a certain track piece above. Signs attached to walls take the block they are attached to and look up until they find a piece of track. That track is then used for that sign. Sign posts look up until they find a piece of track. There may not be blocks without signs between the bottom sign and the tracks.
Each sign targets a certain track piece above. Signs attached to walls take the block they are attached to and look up until they find a piece of track. That track is then used for that sign. Sign posts look up until they find a piece of track. There may not be blocks without signs between the bottom sign and the tracks.


<!--T:16-->
You can make a pillar of blocks below a single track piece and attach signs to it, to make a bundle of actions on a single track piece. Trains look down when they enter a new track piece to check for signs, so make sure you put the output signs above the signs that use this output for correct results.
You can make a pillar of blocks below a single track piece and attach signs to it, to make a bundle of actions on a single track piece. Trains look down when they enter a new track piece to check for signs, so make sure you put the output signs above the signs that use this output for correct results.


<!--T:17-->
A noticeable exception would be add-ons for the TrainCart plugin, which may change the (relative) position a sign would need to be placed on in order to work for the track. For example, would the ''TC Hang Rail'' add-on require you to add the signs '''above''' the Hang rail track to work, while the ''TCC'' (TrainCarts Coasters) add-on uses the block of a node for the sign, which can be moved to any other block.
A noticeable exception would be add-ons for the TrainCart plugin, which may change the (relative) position a sign would need to be placed on in order to work for the track. For example, would the ''TC Hang Rail'' add-on require you to add the signs '''above''' the Hang rail track to work, while the ''TCC'' (TrainCarts Coasters) add-on uses the block of a node for the sign, which can be moved to any other block.


For most signs the sign '''direction''' influences what happens:
<!--T:18-->
For most signs the sign '''direction''' influences what happens, as also discussed earlier (''Activation Direction''):


* The train '''has to face&nbsp;the text on the sign''' to make the sign respond  
<!--T:19-->
* The train '''has to face&nbsp;the text on the sign''' to make the sign respond
* Signs with the same alignment as the tracks (faces to or away from the tracks) '''always''' respond  
* Signs with the same alignment as the tracks (faces to or away from the tracks) '''always''' respond  
* The train is spawned in the direction the sign faces
* The train is spawned in the direction the sign faces


==Types==
*[[TrainCarts/Signs/Animate|Animator]] - play an animation configured in the train's attachments
*[[TrainCarts/Signs/Announce|Announce]] - sends a message to players in the cart and/or train above
*[[TrainCarts/Signs/Blocker|Blocker]] - blocks trains coming from a certain direction
*[[TrainCarts/Signs/BlockChanger|Block Changer]] - change the block types displayed in a minecart
*[[TrainCarts/Signs/Crafter|Crafter]] - crafts items inside the storage minecarts of a train using a nearby workbench
*[[TrainCarts/Signs/Destination|Destination]] - marks a destination for the path finding and sets the next destination for the train
*[[TrainCarts/Signs/Destroyer|Destroyer]] - destroy trains
*[[TrainCarts/Signs/Detector|Detector]] - detect trains on a set region of rails
*[[TrainCarts/Signs/Effect|Effect]] - plays a particle or sound effect at the minecart, train or sign
*[[TrainCarts/Signs/Ejector|Ejector]] - eject trains (let passengers exit)
*[[TrainCarts/Signs/Elevator|Elevator]] - teleports trains including passengers up and down to another elevator
*[[TrainCarts/Signs/Enter|Enter]] - lets nearby players and/or mobs enter the train
*[[TrainCarts/Signs/Flip|Flip]] - Lets you flip a cart 180 degrees. (Needs info)
*[[TrainCarts/Signs/Launcher|Launcher]] - launch or brake trains to start moving at a desired speed
*[[TrainCarts/Signs/Mutex|Mutex]] - acts as a cuboid barrier in which only a single train is ever allowed to be
*[[TrainCarts/Signs/Property|Property]] - set properties on the train such as tags, destinations&nbsp;and owners
*[[TrainCarts/Signs/Skip|Skip]] - skips execution of signs up ahead based on statements
*[[TrainCarts/Signs/Sound|Sound]] - plays a named sound effect
*[[TrainCarts/Signs/Spawner|Spawner]] - spawn an entire train, cart types can be set
*[[TrainCarts/Signs/Station|Station]] - stop and launch trains
*[[TrainCarts/Signs/Switcher|Switcher]] - switch levers and rails based on properties on the train
*[[TrainCarts/Signs/Teleporter|Teleporter]] - teleport trains including passengers (requires MyWorlds)
*[[TrainCarts/Signs/Transfer|Transfer]] - transfer items between trains and chests/furnaces/dispensers
*[[TrainCarts/Signs/Trigger|Trigger]] - display train information and a countdown of the arrival time&nbsp;of trains on signs (requires SignLink)
*[[TrainCarts/Signs/Ticket|Ticket]] - let passengers pay for a ride (requires Vault)
*[[TrainCarts/Signs/Waiter|Waiter]] - waits the train until the track is clear of other trains
===To-do===
Add 'chunks' to signs to replace 'keepchunksloaded'.
= Permissions  =


Each sign has a separate build permission. Below the permission nodes for the above sign types:  
==Types== <!--T:20-->


{| style="width: 391px; height: 276px" cellspacing="1" cellpadding="1" width="391" border="1"
<!--T:21-->
|-
{| class="wikitable" style="margin:left"
! scope="col" | Sign  
! Sign !! Description !! Remote Control
! scope="col" | Permission node
! scope="col" | Default
|-
|-
| bgcolor="#cccccc" | destructor
| [[Special:MyLanguage/TrainCarts/Signs/Animate|Animate]] || play an animation configured in the train's attachments || Yes
| bgcolor="#cccccc" | train.build.destructor
|-bgcolor="#dddddd"
| bgcolor="#cccccc" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Announce|Announce]] || sends a message to players in the cart and/or train above || Yes
|-
|-
| ejector
| [[Special:MyLanguage/TrainCarts/Signs/Blocker|Blocker]] || blocks trains coming from a certain direction || No
| train.build.ejector
|-bgcolor="#dddddd"
| OP
| [[Special:MyLanguage/TrainCarts/Signs/BlockChanger|Block Changer]] || change the block types displayed in a minecart || Yes
|-
|-
| bgcolor="#cccccc" | station
| [[Special:MyLanguage/TrainCarts/Signs/Crafter|Craft]] || crafts items inside the storage minecarts of a train using a nearby workbench || No
| bgcolor="#cccccc" | train.build.station
|-bgcolor="#dddddd"
| bgcolor="#cccccc" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Destination|Destination]] || marks a destination for the path finding and sets the next destination for the train || Yes
|-
|-
| property
| [[Special:MyLanguage/TrainCarts/Signs/Destroyer|Destroy]] || destroy trains || Yes
| train.build.property
|-bgcolor="#dddddd"
| OP
| [[Special:MyLanguage/TrainCarts/Signs/Detector|Detector]] || detect trains on a set region of rails || No
|-
|-
| bgcolor="#cccccc" | switcher
| [[Special:MyLanguage/TrainCarts/Signs/Effect|Effect]] || plays a particle or sound effect at the minecart, train or sign || Yes
| bgcolor="#cccccc" | train.build.switcher
|-bgcolor="#dddddd"
| bgcolor="#cccccc" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Ejector|Eject]] || eject trains (let passengers exit) || Yes
|-
|-
| rowspan="2" | transfer
| [[Special:MyLanguage/TrainCarts/Signs/Elevator|Elevator]] || teleports trains including passengers up and down to another elevator || No
| train.build.collector
|-bgcolor="#dddddd"
| rowspan="2" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Enter|Enter]] || lets nearby players and/or mobs enter the train || Yes
|-
|-
| train.build.depositor
| [[Special:MyLanguage/TrainCarts/Signs/Flip|Flip]] || Lets you flip a cart 180 degrees || Yes
|-bgcolor="#dddddd"
| [[Special:MyLanguage/TrainCarts/Signs/Launcher|Launcher]] || launch or brake trains to start moving at a desired speed || Yes
|-
|-
| bgcolor="#cccccc" | teleport
| [[Special:MyLanguage/TrainCarts/Signs/Mutex|(Smart) Mutex]] || prevents train collisions at intersections by blocking multiple trains from entering the same area || No
| bgcolor="#cccccc" | train.build.teleport
|-bgcolor="#dddddd"
| bgcolor="#cccccc" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Property|Property]] || set properties on the train such as tags, destinations, enter/exit toggle and more || Yes
|-
|-
| spawner
| [[Special:MyLanguage/TrainCarts/Signs/Skip|Skip]] || skips execution of signs up ahead based on statements || Yes
| train.build.spawner
|-bgcolor="#dddddd"
| OP
| [[Special:MyLanguage/TrainCarts/Signs/Sound|Sound]] || plays a named sound effect || Yes
|-
|-
| bgcolor="#cccccc" | trigger
| [[Special:MyLanguage/TrainCarts/Signs/Spawner|Spawn]] || spawn an entire train, cart types can be set || No
| bgcolor="#cccccc" | train.build.trigger
|-bgcolor="#dddddd"
| bgcolor="#cccccc" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Station|Station]] || stop and launch trains || No
|-
|-
| destination
| [[Special:MyLanguage/TrainCarts/Signs/Switcher|Switcher]] || switch levers and rails based on properties on the train || No
| train.build.destination
|-bgcolor="#dddddd"
| OP
| [[Special:MyLanguage/TrainCarts/Signs/Teleporter|Teleport]] || teleport trains including passengers (requires MyWorlds) || Yes
|-
|-
| bgcolor="#cccccc" | waiter
| [[Special:MyLanguage/TrainCarts/Signs/Transfer|Transfer]] || transfer items between trains and chests/furnaces/dispensers || No
| bgcolor="#cccccc" | train.build.waiter
|-bgcolor="#dddddd"
| bgcolor="#cccccc" | OP
| [[Special:MyLanguage/TrainCarts/Signs/Trigger|Trigger]] || display train information and a countdown of the arrival time&nbsp;of trains on signs (requires SignLink) || No
|-
|-
| crafter
| [[Special:MyLanguage/TrainCarts/Signs/Ticket|Ticket]] || let passengers pay for a ride (requires Vault) || No
| train.build.crafter
|-bgcolor="#dddddd"
| OP
| [[Special:MyLanguage/TrainCarts/Signs/Waiter|Waiter]] || waits the train until the track is clear of other trains || No
|-
| bgcolor="#cccccc" | elevator
| bgcolor="#cccccc" | train.build.elevator
| bgcolor="#cccccc" | OP
|}
|}
= Permissions = <!--T:24-->
<!--T:25-->
Each sign has a separate build permission. [[TrainCarts/Permissions#Building_Action_Signs|See the main permissions page]]. For using remote control, the player requires the <code>train.build.feature.remotecontrol</code> permission which is OP-only by default.
</translate>

Latest revision as of 09:37, 12 October 2025

TrainCarts allows you to perform actions on trains or single cars using signs.

Structure and Behaviour

A first glance at the sign format

A sign is always structured the same way. The first line contains either cart or train depending on if you want to target each cart separately or the train as a whole. You can then optionally specify the way the sign responds to redstone and what direction the train must be coming from.

Redstone

TrainCarts signs require Redstone power to function. This means signs will not do anything unless you put a redstone torch or other power signal next to it. If you want to use signs without adding redstone torches, you can make use of a special syntax on the first line, which is the same for [train] and [cart]. Generally you will want to use [+train] to make the sign function.


TrainCarts Sign Power Modes
First Line Explanation
[train] The default mode. Sign only works when redstone power is provided
[+train] Always on power mode. Signs works all the time regardless of whether redstone power is provided
[!train] Inverted power mode. Sign works all the time and turns off when redstone power is provided. Works the same as [+train] when no redstone torch is used.
[-train] Always off power mode. Signs don't respond to redstone power. Only useful for the switcher sign.
[/train] On-pulse power mode. Signs only activate once when redstone power goes from off to on, and don't respond to trains riding over it
[\train] Off-pulse power mode. Signs only activate once when redstone power goes from on to off, and don't respond to trains riding over it
[/\train] Redstone change power mode. Signs only activate once when redstone power switches state, and don't respond to trains riding over it

Lever Output

Signs can output a redstone signal as well by attaching a lever to the same block the sign is also attached to. Only a few signs activate the lever, like the station sign that activates it when trains stop on top of the station.

Activation Direction

By default signs only activate when the train sees the front or sides of the sign. This means you should place signs facing the direction of train movement. To override this behavior you can set these activation directions by adding a colon (:) followed by one or more directions. If you want the sign to always respond, just use [train:*].

For example, [-train:lr] on a switcher sign would activate a lever when a train enters from either the sign-relative left or right direction and doesn't for the remaining ones. It uses -train so that it does not switch the track.

Remote Control

A few sign systems support remote control: the ability to control trains by name. You then use the [train <name>] format, or the shorter alias [t <name>]. Remotely controlled signs only respond to redstone changes, thus where you place them is not important. The signs that support this feature are listed in the Types table down below.

Remote control can also affect multiple trains. Just like the tag system, remote control uses *-signs to identify the trains to affect. For example, the following remote control sign will set the destination to home for all intercity trains:

Signtemplate.png
[train Intercity*]
property
destination
interhome


You can use this to recall all your trains easily. If you use tags to navigate trains, you can also add a tag saying that the train should return.

Placement

Empty minecarts are blocked
Trains are switched left and right using a 1:1 counter

Each sign targets a certain track piece above. Signs attached to walls take the block they are attached to and look up until they find a piece of track. That track is then used for that sign. Sign posts look up until they find a piece of track. There may not be blocks without signs between the bottom sign and the tracks.

You can make a pillar of blocks below a single track piece and attach signs to it, to make a bundle of actions on a single track piece. Trains look down when they enter a new track piece to check for signs, so make sure you put the output signs above the signs that use this output for correct results.

A noticeable exception would be add-ons for the TrainCart plugin, which may change the (relative) position a sign would need to be placed on in order to work for the track. For example, would the TC Hang Rail add-on require you to add the signs above the Hang rail track to work, while the TCC (TrainCarts Coasters) add-on uses the block of a node for the sign, which can be moved to any other block.

For most signs the sign direction influences what happens, as also discussed earlier (Activation Direction):

  • The train has to face the text on the sign to make the sign respond
  • Signs with the same alignment as the tracks (faces to or away from the tracks) always respond
  • The train is spawned in the direction the sign faces


Types

Sign Description Remote Control
Animate play an animation configured in the train's attachments Yes
Announce sends a message to players in the cart and/or train above Yes
Blocker blocks trains coming from a certain direction No
Block Changer change the block types displayed in a minecart Yes
Craft crafts items inside the storage minecarts of a train using a nearby workbench No
Destination marks a destination for the path finding and sets the next destination for the train Yes
Destroy destroy trains Yes
Detector detect trains on a set region of rails No
Effect plays a particle or sound effect at the minecart, train or sign Yes
Eject eject trains (let passengers exit) Yes
Elevator teleports trains including passengers up and down to another elevator No
Enter lets nearby players and/or mobs enter the train Yes
Flip Lets you flip a cart 180 degrees Yes
Launcher launch or brake trains to start moving at a desired speed Yes
(Smart) Mutex prevents train collisions at intersections by blocking multiple trains from entering the same area No
Property set properties on the train such as tags, destinations, enter/exit toggle and more Yes
Skip skips execution of signs up ahead based on statements Yes
Sound plays a named sound effect Yes
Spawn spawn an entire train, cart types can be set No
Station stop and launch trains No
Switcher switch levers and rails based on properties on the train No
Teleport teleport trains including passengers (requires MyWorlds) Yes
Transfer transfer items between trains and chests/furnaces/dispensers No
Trigger display train information and a countdown of the arrival time of trains on signs (requires SignLink) No
Ticket let passengers pay for a ride (requires Vault) No
Waiter waits the train until the track is clear of other trains No

Permissions

Each sign has a separate build permission. See the main permissions page. For using remote control, the player requires the train.build.feature.remotecontrol permission which is OP-only by default.