Class SE8cSignalHead

All Implemented Interfaces:
VetoableChangeListener, Comparable<NamedBean>, EventListener, PropertyChangeProvider, LocoNetListener, NamedBean, Signal, SignalHead

public class SE8cSignalHead
extends DefaultSignalHead
implements LocoNetListener
Extend jmri.SignalHead for signals implemented by an SE8C.

This implementation writes out to the physical signal when it's commanded to change appearance, and updates its internal state when it hears commands from other places.

To get a complete set of aspects, we assume that the SE8C board has been configured such that the 4th aspect is "dark". We then do flashing aspects by commanding the lit appearance to change.

This is a grandfathered implementation that is specific to LocoNet systems. A more general implementation, which can work with any system(s), is available in SE8cSignalHead. This package is maintained so that existing XML files can continue to be read. In particular, it only works with the first LocoNet connection (names LHnnn, not L2Hnnn etc).

The algorithms in this class are a collaborative effort of Digitrax, Inc and Bob Jacobsen.

Some of the message formats used in this class are Copyright Digitrax, Inc. and used with permission as part of the JMRI project. That permission does not extend to uses in other software products. If you wish to use this code, algorithm or these message formats outside of JMRI, please contact Digitrax Inc for separate permission.

  • Field Details

  • Constructor Details

  • Method Details

    • init

      void init​(int pNumber)
    • getNumber

      public int getNumber()
    • updateOutput

      protected void updateOutput()
      Description copied from class: DefaultSignalHead
      Type-specific routine to handle output to the layout hardware.

      Does not notify listeners of changes; that's done elsewhere. Should use the following variables to determine what to send:

      • mAppearance
      • mLit
      • mFlashOn
      Specified by:
      updateOutput in class DefaultSignalHead
    • message

      public void message​(LocoNetMessage l)
      Description copied from interface: LocoNetListener
      Member function that will be invoked by a LocoNetInterface implementation to forward a LocoNet message from the layout.
      Specified by:
      message in interface LocoNetListener
      Parameters:
      l - The received LocoNet message. Note that this same object may be presented to multiple users. It should not be modified here.
    • dispose

      public void dispose()
      Description copied from interface: NamedBean
      Deactivate this object, so that it releases as many resources as possible and no longer effects others.

      For example, if this object has listeners, after a call to this method it should no longer notify those listeners. Any native or system-wide resources it maintains should be released, including threads, files, etc.

      It is an error to invoke any other methods on this object once dispose() has been called. Note, however, that there is no guarantee about behavior in that case.

      Afterwards, references to this object may still exist elsewhere, preventing its garbage collection. But it's formally dead, and shouldn't be keeping any other objects alive. Therefore, this method should null out any references to other objects that this NamedBean contained.

      Specified by:
      dispose in interface NamedBean
      Overrides:
      dispose in class AbstractNamedBean