Class LnReporter
- java.lang.Object
- 
- jmri.implementation.AbstractNamedBean
- 
- jmri.implementation.AbstractReporter
- 
- jmri.implementation.AbstractIdTagReporter
- 
- jmri.jmrix.loconet.LnReporter
 
 
 
 
- 
- All Implemented Interfaces:
- java.lang.Comparable<NamedBean>,- PropertyChangeProvider,- CollectingReporter,- IdTagListener,- NamedBean,- PhysicalLocationReporter,- Reporter
 
 public class LnReporter extends AbstractIdTagReporter implements CollectingReporter Extend jmri.AbstractIdTagReporter for LocoNet layouts.This implementation reports Transponding messages from LocoNet-based "Reporters". For LocoNet connections, a "Reporter" represents either a Digitrax "transponding zone", a Lissy "measurement zone" or a Lissy RFID reader location. 
 The messages from these Reporters are handled by this code.
 The LnReporterManager is responsible for decode of appropriate LocoNet messages and passing only those messages to the Reporter which match its Reporter address.
 Each transponding message creates a new current report. The last report is always available, and is the same as the contents of the last transponding message received. Based on the report, for new tags a new Id Tag is created by the LnReporter.Reports are Strings, formatted as - NNNN enter - locomotive address NNNN entered the transponding zone. Short vs long address is indicated by the NNNN value
- NNNN exits - locomotive address NNNN left the transponding zone.
- NNNN seen northbound - LISSY measurement
- NNNN seen southbound - LISSY measurement
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface jmri.NamedBeanNamedBean.BadNameException, NamedBean.BadSystemNameException, NamedBean.BadUserNameException, NamedBean.DisplayOptions, NamedBean.DuplicateSystemNameException
 - 
Nested classes/interfaces inherited from interface jmri.PhysicalLocationReporterPhysicalLocationReporter.Direction
 
- 
 - 
Field SummaryFields Modifier and Type Field Description (package private) intlastLoco- 
Fields inherited from class jmri.implementation.AbstractReporter_currentReport, _lastReport
 - 
Fields inherited from class jmri.implementation.AbstractNamedBeanlistenerRefs, mSystemName, register
 - 
Fields inherited from interface jmri.NamedBeanDISPLAY_NAME_FORMAT, INCONSISTENT, PROPERTY_COMMENT, PROPERTY_ENABLED, PROPERTY_KNOWN_STATE, PROPERTY_STATE, PROPERTY_USERNAME, QUOTED_NAME_FORMAT, UNKNOWN
 - 
Fields inherited from interface jmri.ReporterPROPERTY_CURRENT_REPORT, PROPERTY_LAST_REPORT
 
- 
 - 
Constructor SummaryConstructors Constructor Description LnReporter(int number, LnTrafficController tc, java.lang.String prefix)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description java.util.Collection<java.lang.Object>getCollection()PhysicalLocationReporter.DirectiongetDirection(java.lang.String rep)Gets the direction (ENTER/EXIT) of the report.LocoAddressgetLocoAddress(java.lang.String rep)Get the locomotive address we're reporting about from the current report.intgetLocoAddrFromTranspondingMsg(LocoNetMessage l)extract long or short address from transponding message Assumes that the LocoNet message is a valid transponding message.intgetNumber()PhysicalLocationgetPhysicalLocation()Get the PhysicalLocation of the Reporter Reports its own location, for now.PhysicalLocationgetPhysicalLocation(java.lang.String s)Get the PhysicalLocation of the Reporter.intgetState()Provide an int value for use in scripts, etc.booleanisTranspondingFindReport(LocoNetMessage l)Check if message is a Transponding Find Report message A Transponding Location Report message is sent by transponding hardware in response to a Transponding Find Request message when the addressed decoder is within a transponding zone and the decoder is transponding-enabled.booleanisTranspondingLocationReport(LocoNetMessage l)Check if message is a Transponding Location Report message A Transponding Location Report message is sent by transponding hardware when a transponding mobile decoder enters or leaves a transponding zone.(package private) voidlissyReport(LocoNetMessage l)Handle LISSY message(package private) voidlissyRfidReport(LocoNetMessage l)Handle LISSY RFID-7 and RFID-5 messagesvoidmessageFromManager(LocoNetMessage l)Process LocoNet message handed to us from the LnReporterManagervoidsetState(int s)Provide generic access to internal state.(package private) voidtranspondingReport(LocoNetMessage l)Handle transponding message passed to us by the LnReporting Manager Assumes that the LocoNet message is a valid transponding message.- 
Methods inherited from class jmri.implementation.AbstractIdTagReporterdescribeState, notify
 - 
Methods inherited from class jmri.implementation.AbstractReportergetBeanType, getCurrentReport, getLastReport, setReport
 - 
Methods inherited from class jmri.implementation.AbstractNamedBeanaddPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, addPropertyChangeListener, compareSystemNameSuffix, dispose, equals, firePropertyChange, getComment, getDisplayName, getDisplayName, getListenerRef, getListenerRefs, getNumPropertyChangeListeners, getProperty, getPropertyChangeListeners, getPropertyChangeListeners, getPropertyChangeListenersByReference, getPropertyKeys, getSystemName, getUserName, hashCode, removeProperty, removePropertyChangeListener, removePropertyChangeListener, setComment, setProperty, setUserName, toString, toStringSuffix, updateListenerRef, vetoableChange
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface jmri.NamedBeanaddPropertyChangeListener, addPropertyChangeListener, compareSystemNameSuffix, compareTo, describeState, dispose, getBeanType, getComment, getDisplayName, getDisplayName, getListenerRef, getListenerRefs, getNumPropertyChangeListeners, getProperty, getPropertyChangeListenersByReference, getPropertyKeys, getRecommendedToolTip, getSystemName, getUsageReport, getUserName, removeProperty, setComment, setProperty, setUserName, toString, updateListenerRef, vetoableChange
 - 
Methods inherited from interface jmri.beans.PropertyChangeProvideraddPropertyChangeListener, addPropertyChangeListener, getPropertyChangeListeners, getPropertyChangeListeners, removePropertyChangeListener, removePropertyChangeListener
 - 
Methods inherited from interface jmri.ReportergetCurrentReport, getLastReport, setReport
 
- 
 
- 
- 
- 
Field Detail- 
lastLocoint lastLoco 
 
- 
 - 
Constructor Detail- 
LnReporterpublic LnReporter(int number, LnTrafficController tc, java.lang.String prefix) 
 
- 
 - 
Method Detail- 
getNumberpublic int getNumber() - Returns:
- the LocoNet address number for this reporter.
 
 - 
messageFromManagerpublic void messageFromManager(LocoNetMessage l) Process LocoNet message handed to us from the LnReporterManager- Parameters:
- l- - a LocoNetMessage.
 
 - 
isTranspondingLocationReportpublic final boolean isTranspondingLocationReport(LocoNetMessage l) Check if message is a Transponding Location Report message A Transponding Location Report message is sent by transponding hardware when a transponding mobile decoder enters or leaves a transponding zone.- Parameters:
- l- LocoNet message to check
- Returns:
- true if message is a Transponding Location Report, else false.
 
 - 
isTranspondingFindReportpublic final boolean isTranspondingFindReport(LocoNetMessage l) Check if message is a Transponding Find Report message A Transponding Location Report message is sent by transponding hardware in response to a Transponding Find Request message when the addressed decoder is within a transponding zone and the decoder is transponding-enabled.- Parameters:
- l- LocoNet message to check
- Returns:
- true if message is a Transponding Find Report, else false.
 
 - 
transpondingReportvoid transpondingReport(LocoNetMessage l) Handle transponding message passed to us by the LnReporting Manager Assumes that the LocoNet message is a valid transponding message.- Parameters:
- l- - incoming loconetmessage
 
 - 
getLocoAddrFromTranspondingMsgpublic int getLocoAddrFromTranspondingMsg(LocoNetMessage l) extract long or short address from transponding message Assumes that the LocoNet message is a valid transponding message.- Parameters:
- l- LocoNet message
- Returns:
- loco address
 
 - 
lissyReportvoid lissyReport(LocoNetMessage l) Handle LISSY message- Parameters:
- l- Message from which to extract LISSY content
 
 - 
lissyRfidReportvoid lissyRfidReport(LocoNetMessage l) Handle LISSY RFID-7 and RFID-5 messages- Parameters:
- l- Message from which to extract RFID content (UID)
 
 - 
getStatepublic int getState() Provide an int value for use in scripts, etc. This will be the numeric locomotive address last seen, unless the last message said the loco was exiting. Note that there may still some other locomotive in the transponding zone!
 - 
setStatepublic void setState(int s) Provide generic access to internal state.This generally shouldn't be used by Java code; use the class-specific form instead (e.g. setCommandedState in Turnout). This is provided to make scripts access easier to read. - Specified by:
- setStatein interface- NamedBean
- Overrides:
- setStatein class- AbstractIdTagReporter
- Parameters:
- s- the state
 
 - 
getLocoAddresspublic LocoAddress getLocoAddress(java.lang.String rep) Get the locomotive address we're reporting about from the current report.- Specified by:
- getLocoAddressin interface- PhysicalLocationReporter
- Overrides:
- getLocoAddressin class- AbstractIdTagReporter
- Parameters:
- rep- ignored, IdTag Reporters don't send String type reports.
 
 - 
getDirectionpublic PhysicalLocationReporter.Direction getDirection(java.lang.String rep) Gets the direction (ENTER/EXIT) of the report.Because of the way IdTag Reporters work, all reports are ENTER type. - Specified by:
- getDirectionin interface- PhysicalLocationReporter
- Overrides:
- getDirectionin class- AbstractIdTagReporter
 
 - 
getPhysicalLocationpublic PhysicalLocation getPhysicalLocation() Get the PhysicalLocation of the Reporter Reports its own location, for now. Not sure if that's the right thing or not. NOT DONE YET- Specified by:
- getPhysicalLocationin interface- PhysicalLocationReporter
- Overrides:
- getPhysicalLocationin class- AbstractIdTagReporter
 
 - 
getPhysicalLocationpublic PhysicalLocation getPhysicalLocation(java.lang.String s) Get the PhysicalLocation of the Reporter.- Specified by:
- getPhysicalLocationin interface- PhysicalLocationReporter
- Overrides:
- getPhysicalLocationin class- AbstractIdTagReporter
- Parameters:
- s- unused.
 
 - 
getCollectionpublic java.util.Collection<java.lang.Object> getCollection() - Specified by:
- getCollectionin interface- CollectingReporter
- Returns:
- the collection of elements associated with this reporter.
 
 
- 
 
-