java comm api_java基于RXTXcomm.jar的串口通信

java基于RXTXcomm.jar的串口通信

RXTX的下载及配置

首先确定你安装的JDK的位数,安装相应位数的jar包。

将rxtxSerial.dll、rxtxParallel.dll复制到\jre\bin目录下

将RXTXcomm.jar复制到\jre\lib\ext目录下

到eclipse中右击项目--->Build Path---> Configure Build Path --> Libraries --> Add External JARs...--->找到/jre/lib/ext目录下的RXTXcomm.jar--->打开-->OK。

到此为止所有的准备工作都已经做完了,开始学习吧!

0818b9ca8b590ca3270a3433284dd417.png

API概述

接口

CommDriver 可负载设备(the loadable device)驱动程序接口的一部分

CommPortOwnershipListener 传递各种通讯端口的所有权事件

ParallelPortEventListener 传递并行端口事件

SerialPortEventListener 传递串行端口事件

CommPort 通讯端口 CommDriver 可负载设备(the loadable device)驱动程序接口的一部分

CommPortOwnershipListener 传递各种通讯端口的所有权事件

ParallelPortEventListener 传递并行端口事件

SerialPortEventListener 传递串行端口事件

SerialPortEvent 异常类

NoSuchPortException 当驱动程序不能找到指定端口时抛出

PortInUseException 当碰到指定端口正在使用中时抛出

UnsupportedCommOperationException 驱动程序不允许指定操作时抛出

重要类详述

CommPort类

描述被底层系统支持的端口的抽象类。包含一些高层的IO控制方法,这些方法对于所有不同的通讯端口来说是通用的。SerialPort(串口) 和ParallelPort(并口)都是它的子类。

CommPortIdentifier

主要用于对串口进行管理和设置,是对串口进行访问控制的核心类。主要方法如下:addPortName(String, int, CommDriver) 添加端口名到端口列表里

addPortOwnershipListener(CommPortOwnershipListener) 添加端口拥有的监听器

removePortOwnershipListener(CommPortOwnershipListener) 移除端口拥有的监听器

getCurrentOwner() 得到当前占有端口的对象或应用程序

getName() 得到端口名称

getPortIdentifier(CommPort) 得到参数打开的端口的CommPortIdentifier类型对象

getPortIdentifier(String) 得到以参数命名的端口的CommPortIdentifier类型对象

getPortIdentifiers() 得到系统中的端口列表

getPortType() 得到端口的类型

isCurrentlyOwned() 判断当前端口是否被占用

open(FileDescriptor) 用文件描述的类型打开端口

open(String, int) 打开端口,两个参数:程序名称,延迟时间(毫秒数)

SerialPort

描述RS-232串行通信端口的底层接口,它定义了串口通信所需的最小功能集。可以直接对串口进行读、写及设置工作。

串口参数的函数getBaudRate() 得到波特率

getParity() 得到检验类型

getDataBits() 得到数据位数

getStopBits() 得到停止位数

setSerialPortParams(int, int, int, int) 设置串口参数依次为(波特率,数据位,停止位,奇偶检验)

close() 关闭串口

getOutputStream() 得到OutputStream类型的输出流

getInputStream() 得到InputStream类型的输入流

事件及事件方法isCD() 是否有载波

isCTS() 是否清除发送

isDSR() 数据是否准备就绪

isDTR() 数据终端是否准备就绪

isRI() 是否响铃侦测

isRTS() 是否要求发送

addEventListener(SerialPortEventListener) 向SerialPort对象中添加串口事件监听器

removeEventListener() 移除SerialPort对象中的串口事件监听器

getEventType() 得到发生的事件类型返回值为int型

sendBreak(int) 设置中断过程的时间,参数为毫秒值

setRTS(boolean) 设置或清除RTS位

setDTR(boolean) 设置或清除DTR位

notifyOnBreakInterrupt(boolean) 设置中断事件

notifyOnCarrierDetect(boolean) 设置载波监听事件

notifyOnCTS(boolean) 设置清除发送事件

notifyOnDataAvailable(boolean) 设置串口有数据的事件

notifyOnDSR(boolean) 设置数据备妥事件

notifyOnFramingError(boolean) 设置发生错误事件

notifyOnOutputEmpty(boolean) 设置发送缓冲区为空事件

notifyOnParityError(boolean) 设置发生奇偶检验错误事件

notifyOnRingIndicator(boolean) 设置响铃侦测事件

串口参数的静态成员变量成员变量 说明 成员变量 说明 成员变量 说明

DATABITS_5 数据位为5 STOPBITS_2 停止位为2 PARITY_ODD 奇检验

DATABITS_6 数据位为6 STOPBITS_1 停止位为1 PARITY_MARK 标记检验

DATABITS_7 数据位为7 STOPBITS_1_5 停止为1.5 PARITY_NONE 空格检验

DATABITS_8 数据位为8 PARITY_EVEN 偶检验 PARITY_SPACE 无检验

参考代码:

package Dao;

import java.io.IOException;

import java.io.InputStream;

import java.io.OutputStream;

import java.util.Enumeration;

import java.util.HashSet;

import java.util.Set;

import java.util.TooManyListenersException;

import gnu.io.CommPortIdentifier;

import gnu.io.PortInUseException;

import gnu.io.SerialPort;

import gnu.io.SerialPortEvent;

import gnu.io.SerialPortEventListener;

import gnu.io.UnsupportedCommOperationException;

public class SerialPortDao implements Runnable, SerialPortEventListener {

private static boolean isOpen=false;

static Set portList=new HashSet();

final static String appName="MyApp";

private static InputStream is;

private static OutputStream os;

private static SerialPort serialPort;

byte[] readBuffer=new byte[100];

public Set getPortList(){

Enumeration tempPortList; //枚举类

CommPortIdentifier portIp;

tempPortList=CommPortIdentifier.getPortIdentifiers();

/*不带参数的getPortIdentifiers方法获得一个枚举对象,该对象又包含了系统中管理每个端口的CommPortIdentifier对象。

* 注意这里的端口不仅仅是指串口,也包括并口。

* 这个方法还可以带参数。

* getPortIdentifiers(CommPort)获得与已经被应用程序打开的端口相对应的CommPortIdentifier对象。

* getPortIdentifier(String portName)获取指定端口名(比如“COM1”)的CommPortIdentifier对象。

*/

while(tempPortList.hasMoreElements()){

//在这里可以调用getPortType方法返回端口类型,串口为CommPortIdentifier.PORT_SERIAL

portIp=(CommPortIdentifier) tempPortList.nextElement();

portList.add(portIp);

}

return portList;

}

public boolean openSerialPort(CommPortIdentifier portIp,int delay){

try {

serialPort=(SerialPort) portIp.open(appName, delay);

/* open方法打开通讯端口,获得一个CommPort对象。它使程序独占端口。

* 如果端口正被其他应用程序占用,将使用 CommPortOwnershipListener事件机制,传递一个PORT_OWNERSHIP_REQUESTED事件。

* 每个端口都关联一个 InputStream 和一个OutputStream。

* 如果端口是用open方法打开的,那么任何的getInputStream都将返回相同的数据流对象,除非有close 被调用。

* 有两个参数,第一个为应用程序名;第二个参数是在端口打开时阻塞等待的毫秒数。

*/

} catch (PortInUseException e) {

return false;

}

try {

is=serialPort.getInputStream();/*获取端口的输入流对象*/

os=serialPort.getOutputStream();/*获取端口的输出流对象*/

} catch (IOException e) {

return false;

}

try {

serialPort.addEventListener(this);/*注册一个SerialPortEventListener事件来监听串口事件*/

} catch (TooManyListenersException e) {

return false;

}

serialPort.notifyOnDataAvailable(true);/*数据可用*/

try {

/*设置串口初始化参数,依次是波特率,数据位,停止位和校验*/

serialPort.setSerialPortParams(4800, SerialPort.DATABITS_8,SerialPort.STOPBITS_1 , SerialPort.PARITY_NONE);

} catch (UnsupportedCommOperationException e) {

return false;

}

return true;

}

public boolean closeSerialPort(){

if(isOpen){

try {

is.close();

os.close();

serialPort.notifyOnDataAvailable(false);

serialPort.removeEventListener();

serialPort.close();

isOpen = false;

} catch (IOException e) {

return false;

}

}

return true;

}

public boolean sendMessage(String message){

try {

os.write(message.getBytes());

} catch (IOException e) {

return false;

}

return true;

}

@Override

public void serialEvent(SerialPortEvent event) {

/*

* 此处省略一下事件,可酌情添加

* SerialPortEvent.BI:/*Break interrupt,通讯中断

* SerialPortEvent.OE:/*Overrun error,溢位错误

* SerialPortEvent.FE:/*Framing error,传帧错误

* SerialPortEvent.PE:/*Parity error,校验错误

* SerialPortEvent.CD:/*Carrier detect,载波检测

* SerialPortEvent.CTS:/*Clear to send,清除发送

* SerialPortEvent.DSR:/*Data set ready,数据设备就绪

* SerialPortEvent.RI:/*Ring indicator,响铃指示

* SerialPortEvent.OUTPUT_BUFFER_EMPTY:/*Output buffer is empty,输出缓冲区清空

*/

if(event.getEventType()==SerialPortEvent.DATA_AVAILABLE){

/*Data available at the serial port,端口有可用数据。读到缓冲数组,输出到终端*/

try {

while(is.available()>0){

is.read(readBuffer);//收到的数据再此,可视情况处理

}

SPCommandDao.startDoMessage(new String (readBuffer));//这一句是我的自定义类,处理接受到的信息,可删除

} catch (IOException e) {

}

}

}

@Override

public void run() {

try {

Thread.sleep(50);//每次收发数据完毕后线程暂停50ms

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值