0

私は jSSC ライブラリを使用しており、RS-485 クライアントに接続する必要があるため、RTS 信号を実装する必要があるため、この信号を SN75176 の DE/RE に使用します。問題は、RTS 信号をアクティブまたは非アクティブにするときに、RTS がアクティブかどうかを示すために MAX232 と SN75176 の間に LED があることですが、必要に応じて動作していないようです。これはコードです:

package jssc_checkclientsandcables;

import jssc.SerialPort;
import jssc.SerialPortEvent;
import jssc.SerialPortEventListener;
import jssc.SerialPortException;

/**
 *
 * @author DeLeon
 */
public class JSSC_CheckClientsAndCables {

    /**
     * @param args the command line arguments
     */
    private static int[] vcClients, vcRele;
    private static int continuarProg;
    private static SerialPort serialPort;
    private static SerialPortEvent event;
    private static byte[] buffer;
    //private static int contadorcin;
    private static final int CANT_CLIENTS = 3;
    private static final int STREAM_LONG = 4;


    public static void main(String[] args) throws InterruptedException {
        // TODO code application logic here
        serialPort = new SerialPort("COM1");
        try {
            System.out.println("Port name: " + serialPort.getPortName());
            System.out.println("Port opened: " + serialPort.openPort());
            System.out.println("Params setted: " + serialPort.setParams(9600, 8, 1, 0));
            //System.out.println("Set Flow Control Mode setted: " + serialPort.setFlowControlMode(1 | 2));
            //System.out.println("Params setted: " + serialPort.setParams(9600, 8, 1, 0, false, false));
            //Preparamos la máscara
            //int mask = SerialPort.MASK_RXCHAR;<-<-<-<-< Estos dos estaban ON
            //Seteamos el Evento - No me queda muy claro como funciona este método
            //serialPort.setEventsMask(mask); -<-<-<-<
            System.out.println("Set Flow Control Mode setted: " + serialPort.setFlowControlMode(1 | 2));
            System.out.println("Get Flow Control Mode: " + serialPort.getFlowControlMode());
            //
            //serialPort.addEventListener(new SerialPortReader());
        }
        catch (SerialPortException ex){
            System.out.println(ex);
        }

        vcClients = new int[CANT_CLIENTS];
        vcRele = new int[CANT_CLIENTS];
        buffer = new byte[STREAM_LONG];

        System.out.println("Primer RTS tiene que ser False");
        try{
            //Desactivmaos la señal RTS
            System.out.println("RTS signal: " + serialPort.setRTS(false));
            System.out.println("CTS signal: " + serialPort.isCTS());
            //System.out.println("RTS signal: " + serialPort.setRTS(true));
        }
        catch (SerialPortException ex){
            System.out.println("Problemas al desactivar RTS Signal");
        }

        do{
            for(int i = 0; i < CANT_CLIENTS; i++){
                System.out.print("\n\nIngrese numero de cliente: ");
                vcClients[i] = Consola.readInt();
                System.out.print("\n\nIngrese rele que desea activar (A = 1, B = 2, M = 3, N = 4, OFF = 6): ");
                vcRele[i] = Consola.readInt();
            }


            for (int j = 0; j < CANT_CLIENTS; j++){
                    System.out.println("\n\nEnviando datos al Cliente numero " + vcClients[j]);
                    System.out.println("Segundo RTS tiene que ser True");
                    try{ 
                        //Ponemos en alto la señal RTS para que el SN75176 active el driver de transmisión
//                        System.out.println("RTS signal active: " + serialPort.setRTS(true));
//                        serialPort.setRTS(true);
//                        serialPort.setRTS(true);
//                        System.out.println("RTS signal active: " + serialPort.isRTS(true));
//                        //System.out.println("RTS signal: " + serialPort.setRTS(false));

                        try{
                            //Desactivmaos la señal RTS
                            System.out.println("RTS signal: " + serialPort.setRTS(true));                            
                            System.out.println("CTS signal: " + serialPort.isCTS());
                            //System.out.println("RTS signal: " + serialPort.setRTS(true));
                        }
                        catch (SerialPortException ex){
                            System.out.println("Problemas al desactivar RTS Signal");
                        }


                        // Controlar si no se necesita un retardo entre envios al serial <- <- <- <- <- 
                        System.out.println("Paso el segundo RTS (True) y esta por mandar");
                        serialPort.writeInt(0xa5);//Byte de START
                        serialPort.writeInt(vcClients[j]);
                        switch (vcRele[j]){
                            case 1:{
                                serialPort.writeInt(0xf1);
                                break;
                            }
                            case 2:{
                                serialPort.writeInt(0xf2);
                                break;
                            }
                            case 3:{
                                serialPort.writeInt(0xf3);
                                break;
                            }
                            case 4:{
                                serialPort.writeInt(0xf4);
                                break;
                            }
                            case 6:{
                                serialPort.writeInt(0xf6);      // Desactivar todos los Clientes
                                break;
                            }
                            default:{
                                System.out.println("No se enviaron datos validos al cliente " + vcClients[j] + " - Switch-Case = default");
                                break;
                            }
                        }

                        serialPort.writeInt(vcClients[j] + vcRele[j] + 0xf0);
                        System.out.println("Termino de mandar");
                   }
                   catch (SerialPortException ex){
                       System.out.println("No se pudo enviar informacion al puerto COM1");
                   }     
                        System.out.println("\nStream enviado al cliente " + vcClients[j]);
                        Thread.sleep(800);//Wait 0.8 seconds

//                   try{
//                        //Desactivmaos la señal RTS
//                        System.out.println("RTS signal: " + serialPort.setRTS(false));
//                        }
//                        catch (SerialPortException ex){
//                            System.out.println("Problemas al desactivar RTS Signal");
//                        }
                   System.out.println("Esperando respuesta del cliente " + vcClients[j]);
                   //Esperamos del cliente el valor entero que representa una confirmación, 0xac

                   do{
                        //if(event.isRXCHAR()){
                        //if(event.getEventValue() == 2){

                        /* MODIFICAR ESTO: Tenemos que recibir 3 caracteres, START+DATA+CHECKSUM */
                        try{
                            //Desactivmaos la señal RTS
                            System.out.println("Tercer RTS tiene que ser False");
                            //serialPort.setRTS(false);
                            System.out.println("RTS signal: " + serialPort.setRTS(false));
                            System.out.println("Paso el tercer RTS false");
                        }
                        catch (SerialPortException ex){
                            System.out.println("Problemas al desactivar RTS Signal");
                        }


                       System.out.println("Antes de esperar los datos al buffer de recep");
                        try {
                            byte buffer[] = serialPort.readBytes(STREAM_LONG);
                        }
                        catch (SerialPortException ex) {
                            System.out.println(ex);
                        }

                        System.out.println("Despues de esperar los datos al buffer de recep");

                        System.out.println("Primer  dato recibido: " + buffer[0]);
                        System.out.println("Segundo dato recibido: " + buffer[1]);
                        System.out.println("Tercer  dato recibido: " + buffer[2]);
                        System.out.println("Cuarto  dato recibido: " + buffer[3]);    

                   }while( ((buffer[3]) >= 0xf6) && ((buffer[3]) <= 0xf8));

                System.out.println("\n\nEl valor del 1º dato recibio es: " + buffer[0]);
                System.out.println("El valor del 2º dato recibio es: " + buffer[1]);
                System.out.println("El valor del 3º dato recibio es: " + buffer[2]);              
                System.out.println("El valor del 4º dato recibio es: " + buffer[3]);    
                //if( (buffer[0]+buffer[1]) == 0x151)
                    //System.out.println("Comunicación con el cliente correcta" );



                System.out.println("Desea continuar? [Si = 1 / No = 2]");
                continuarProg = Consola.readInt();
            }
        }while(continuarProg != 2);

        continuarProg = 0;

        try{
        //Cerramos el puerto COM1    
        System.out.println("Port closed: " + serialPort.closePort());
        }
        catch (SerialPortException ex){
            System.out.println("Problemas cerrando el COM o desactivando RTS Signal");
        }

そして、これは出力です:


run: ポート名: COM1 開いたポート: true Params setted: true Set Flow Control Mode setted: true Get Flow Control Mode: 3 Primer RTS tiene que ser False RTS signal: false

顧客数: 1

Ingrese rele que desea activar (A = 1、B = 2、M = 3、N = 4、OFF = 6): 1

クライアント数: 2

Ingrese rele que desea activar (A = 1、B = 2、M = 3、N = 4、OFF = 6): 2

クライアント数: 3

Ingrese rele que desea activar (A = 1、B = 2、M = 3、N = 4、OFF = 6): 3

Enviando datos al Cliente numero 1 Segundo RTS tiene que ser True RTS signal: false Paso el segundo RTS (True) y esta por mandar

BUILD STOPPED (合計時間: 57 分 38 秒)

私は何を間違っていますか?

不足している情報や不足している情報がある場合は、お気軽にお問い合わせください。不明です。

よろしくお願いいたします。

4

1 に答える 1