Auteur Sujet: Communication JMRI/ARduino  (Lu 458 fois)

ares13

  • Newbie
  • *
  • Messages: 5
    • Voir le profil
Communication JMRI/ARduino
« le: décembre 29, 2019, 12:17:17 am »
Bonjour à tous.
Je suis nouveau et ai expérimenté quelques projet de votre fabuleux locoduino.
comme: https://www.locoduino.org/spip.php?article232 et https://www.locoduino.org/spip.php?article182
Bravo pour tous ce travail!
J'ai monté la centrale DCC avec JMRI (qui fonctionne très bien y compris en wifi) et j'essaie depuis un certain temps de connecter les capteur et aiguillages avec panel pro mais sans succes.
Je fais référence à ce fil (http://forum.locoduino.org/index.php?topic=680.0 ) , il ce passe la même chose que pour "msport", pas de retour d'info des capteurs dans JMRI et pas de de changement d’état sur un arduino nano lorsque l’état des aiguillages changent dans JMRI.
merci pour votre aide.
Cordialement.
Andrès

msport

  • Hero Member
  • *****
  • Messages: 761
  • HO avec DCC++ en DIY Réseaux très éphémères
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #1 le: décembre 29, 2019, 10:10:02 am »
Bonjour,
déjà un an depuis ces essais !
En fait le problème venait du non respect complet de la procédure (dans  l'ordre !) et en particulier de :
" il faut utiliser impérativement le reset du Mega et le script SensorSerialClose.py "
Cordialement

nopxor

  • Jr. Member
  • **
  • Messages: 93
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #2 le: décembre 29, 2019, 05:20:46 pm »
Bonjour,

Peut être faudrait il tester avec un mega plutôt qu'un nano.

ares13

  • Newbie
  • *
  • Messages: 5
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #3 le: décembre 29, 2019, 07:55:09 pm »
Bonsoir.
Malgré pas mal de tentatives, en respectant les étapes:
- reconstruction de toutes les tables( aiguillages,capteurs et cantons)
- puis panneau du réseau (une ligne droite avec une voie d’évitement)
- reset du mega(pour les sensors, pas un clone, le mega!) avant de relancer le scripte sensor scan.py.
- coté aiguillage j'ai utilisé un nano(pas un clone non plus). (pas mieux!)
Bref j'ai fait scrupuleusement comme vous dites...
Toujours aucun retour d'info dans les tableaux.
Je vois remonter les évènements "sensor" via "panneaux">>"moniteur de connexion" de JMRI.(voir fichier joint)
J'ai un peu jardiné dans les scripts sans succès....
Passons à la description des versions soft utilisées/ PC Win10; java version 8 maj 231; JMRI 4.16 R6f machin...
Tiens d'ailleurs pourquoi JMRI utilise une V13.0.1 de JAVA?
Plus trop d'idée hormis essayer sur mon portable boulot...(à voir!)

Merci encore.

Cordialement.

A



ares13

  • Newbie
  • *
  • Messages: 5
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #4 le: janvier 03, 2020, 01:14:50 pm »
Bonne année à tous!

Pour le sensor scan qui ne fonctionnait pas, il fallait avoir de bons yeux et soit mettre ":" après AR dans "nom d'utilisateur" lors de la recréation soit virer les deux points du script "AR:".
Pour les aiguillages c'est en cours...

A+

ares13

  • Newbie
  • *
  • Messages: 5
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #5 le: janvier 07, 2020, 11:17:29 pm »
Bonjour.
Suite de mes investigations pour connecter JMRI au Mega pour les aiguillages...
Quelqu'un aurait il eu ce message au lancement du script TurnoutDataTransfer.py dans la console systeme de JMRI.
Le problème ne semble pas venir du script mais plutot du "javapackage".
Merci d'avance pour votre aide.
Andrès

2020-01-07 23:03:29,581 jython.RunJythonScript                ERROR - Unable to execute script. [AWT-EventQueue-0]
javax.script.ScriptException: AttributeError: 'javapackage' object has no attribute 'beans' in <script> at line number 32
   at org.python.jsr223.PyScriptEngine.scriptException(PyScriptEngine.java:222)
   at org.python.jsr223.PyScriptEngine.eval(PyScriptEngine.java:59)
   at org.python.jsr223.PyScriptEngine.eval(PyScriptEngine.java:64)
   at java.scripting/javax.script.AbstractScriptEngine.eval(AbstractScriptEngine.java:249)
   at jmri.script.JmriScriptEngineManager.eval(JmriScriptEngineManager.java:394)
   at jmri.script.JmriScriptEngineManager.eval(JmriScriptEngineManager.java:331)
   at jmri.jmrit.jython.RunJythonScript.invoke(RunJythonScript.java:111)
   at jmri.jmrit.jython.RunJythonScript.actionPerformed(RunJythonScript.java:84)
   at java.desktop/javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1967)
   at java.desktop/javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2308)
   at java.desktop/javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:405)
   at java.desktop/javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:262)
   at java.desktop/javax.swing.AbstractButton.doClick(AbstractButton.java:369)
   at java.desktop/javax.swing.plaf.basic.BasicMenuItemUI.doClick(BasicMenuItemUI.java:1020)
   at java.desktop/javax.swing.plaf.basic.BasicMenuItemUI$Handler.mouseReleased(BasicMenuItemUI.java:1064)
   at java.desktop/java.awt.Component.processMouseEvent(Component.java:6636)
   at java.desktop/javax.swing.JComponent.processMouseEvent(JComponent.java:3342)
   at java.desktop/java.awt.Component.processEvent(Component.java:6401)
   at java.desktop/java.awt.Container.processEvent(Container.java:2263)
   at java.desktop/java.awt.Component.dispatchEventImpl(Component.java:5012)
   at java.desktop/java.awt.Container.dispatchEventImpl(Container.java:2321)
   at java.desktop/java.awt.Component.dispatchEvent(Component.java:4844)
   at java.desktop/java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4918)
   at java.desktop/java.awt.LightweightDispatcher.processMouseEvent(Container.java:4547)
   at java.desktop/java.awt.LightweightDispatcher.dispatchEvent(Container.java:4488)
   at java.desktop/java.awt.Container.dispatchEventImpl(Container.java:2307)
   at java.desktop/java.awt.Window.dispatchEventImpl(Window.java:2762)
   at java.desktop/java.awt.Component.dispatchEvent(Component.java:4844)
   at java.desktop/java.awt.EventQueue.dispatchEventImpl(EventQueue.java:772)
   at java.desktop/java.awt.EventQueue$4.run(EventQueue.java:721)
   at java.desktop/java.awt.EventQueue$4.run(EventQueue.java:715)
   at java.base/java.security.AccessController.doPrivileged(AccessController.java:391)
   at java.base/java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:85)
   at java.base/java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:95)
   at java.desktop/java.awt.EventQueue$5.run(EventQueue.java:745)
   at java.desktop/java.awt.EventQueue$5.run(EventQueue.java:743)
   at java.base/java.security.AccessController.doPrivileged(AccessController.java:391)
   at java.base/java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:85)
   at java.desktop/java.awt.EventQueue.dispatchEvent(EventQueue.java:742)
   at java.desktop/java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:203)
   at java.desktop/java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:124)
   at java.desktop/java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:113)
   at java.desktop/java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:109)
   at java.desktop/java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
   at java.desktop/java.awt.EventDispatchThread.run(EventDispatchThread.java:90)
Caused by: Traceback (most recent call last):
  File "<script>", line 32, in <module>
AttributeError: 'javapackage' object has no attribute 'beans'

   at org.python.core.Py.AttributeError(Py.java:207)
   at org.python.core.PyObject.noAttributeError(PyObject.java:1032)
   at org.python.core.PyObject.__getattr__(PyObject.java:1027)
   at org.python.pycode._pyx1.f$0(<script>:64)
   at org.python.pycode._pyx1.call_function(<script>)
   at org.python.core.PyTableCode.call(PyTableCode.java:171)
   at org.python.core.PyCode.call(PyCode.java:18)
   at org.python.core.Py.runCode(Py.java:1614)
   at org.python.core.__builtin__.eval(__builtin__.java:497)
   at org.python.core.__builtin__.eval(__builtin__.java:501)
   at org.python.util.PythonInterpreter.eval(PythonInterpreter.java:259)
   at org.python.jsr223.PyScriptEngine.eval(PyScriptEngine.java:57)
   ... 43 more

ares13

  • Newbie
  • *
  • Messages: 5
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #6 le: janvier 08, 2020, 12:28:05 am »
Voilà.
C'est tombé en marche, en ajoutant "import java.beans" au debut du script TurnoutDataTransfer.py. ça fonctionne, en espérant que ce ne soit pas un expédient!
Par la même occasion pour réinitialiser tous les aiguillage à "Direct" j'ai utilisé le script de la livraison JMRI "TurnoutReset.py" ( qui m'a permis d'initialiser "java.beans"...)

# Reset a turnout to Closed every time it's clicked Thrown
#
# This might be used so that a turnout icon on a panel sits
# in one position, ready to be clicked and fire a route
#
# The top of the file defines the needed code.  There are some
# lines near the bottom you should edit to adapt it to your
# particular layout.
#
# Author: Bob Jacobsen, copyright 2005
# Part of the JMRI distribution
# updated )3dBc( 8/1/2020

import jmri
import java
import java.beans

# First, define the listener. 
class MyListener(java.beans.PropertyChangeListener):
  def propertyChange(self, event):
    if ( event.propertyName == "KnownState" ) :
        if ( event.newValue == THROWN ) :
            turnouts.provideTurnout(event.source.systemName).setState(CLOSED)

# Define a routine to make it easy to attach listeners
def SetTurnoutToReset(name) :
    t = turnouts.provideTurnout(name)
    t.setState(CLOSED)
    t.addPropertyChangeListener(MyListener())

# Attach listeners to the desired turnouts
# (Edit the following to apply to your layout)
for t in range (2,70):
    SetTurnoutToReset("AT"+str(t))
#Reset all Turnouts of the table

Cheers

Andrès

fcot2002

  • Jr. Member
  • **
  • Messages: 79
    • Voir le profil
Re : Communication JMRI/ARduino
« Réponse #7 le: janvier 08, 2020, 10:32:27 am »
Salut @ tous !

Je ne sais pas comment vous faites pour avoir autant de messages d'erreurs. :o :o :o

Chapeaux bas les gars