Chrome API操作串口

NWJS使用chrome api连接/接收/发送串口数据

参考http://www.oschina.net/code/snippet_1379244_55248,本文对其代码进行注释和发表一些自己的见解

1.本机可以使用 串口虚拟串口程序(vspd 自行下载)
2.所需要环境node.js  并且安装模块:iconv-lite
3.nwjs所用的环境为nwjs13.* sdk版本

<script type="text/javascript">
    var onGetDevices = function(ports) {//遍历获取串口名称,一般只有一个串口判断if(ports.length==1){port=ports[0].path}即可
        for (var i = 0; i < ports.length; i++) {
            console.log(ports[i].path);
        }
    }
    chrome.serial.getDevices(onGetDevices);//获取串口设备名,并将串口设备信息当参数传入指定的onGetDevices函数
 
    var iconv = require('iconv-lite');//若传输英文字符串则无需转码,此处注释掉
    function convertArrayBufferToString(buf) {//将串口接收到的buffer数据转化成字符串
        var bufView = new Uint8Array(buf);
        var encodedString = String.fromCharCode.apply(null, bufView);
        //nodejs转编码(不可直接转utf-8否则乱码)
        return iconv.decode(encodedString, 'gbk');//若传输英文字符串则无需转码,此处直接返回
}
 
    var onReceiveCallback = function(info) {//串口数据接收函数
        console.log('received', convertArrayBufferToString(info.data));
    };
 
    //convertStringToArrayBuffer('hello')
    var convertStringToArrayBuffer = function(str) {//将字符串转化成buffer用于串口数据发送
        var buf = new ArrayBuffer(str.length);
        var bufView = new Uint8Array(buf);
        for (var i = 0; i < str.length; i++) {
            bufView[i] = str.charCodeAt(i);
        }
        return buf;
    };
 
    var onConnect = function(connectionInfo) {
        console.log(chrome.runtime.lastError, connectionInfo);//输出连接信息
        chrome.serial.onReceive.addListener(onReceiveCallback);//指定串口数据接收函数
        var connectionId = connectionInfo.connectionId;//输出串口连接id,用于区别多串口
        var buffer = new ArrayBuffer(1);
        var dataView = new DataView(buffer);
        dataView.setInt8(0, 0xaa);//构造buffer数据
 
        chrome.serial.send(connectionId, buffer, function() {//指定串口连接id,直接发送buffer数据,也可将字符串转化成buffer再发送convertStringToArrayBuffer("hello")
            chrome.serial.update(connectionId, {//改变波特率等参数
                bitrate: 9600
            }, function(result) {
                console.log(chrome.runtime.lastError, result);//改变执行结果
 
                chrome.serial.send(connectionId, buffer, console.log.bind(console));//发送数据
 
            });
 
        });
    };
 
    chrome.serial.connect('COM3', {//以波特率9600,连接串口3,指定连接函数onConnect
        bitrate: 9600
    }, onConnect);
    </script>

package.json文件内容://因为使用的是原生chrome api,个人认为不需要nodejs串口配置

{
    "name": "serialportDemo",
    "main": "index.html",
    "version": "0.0.1",
    "nodejs": true,
    "width": 100,
    "height": 200,
    "window": {
 
        "title": "windowdemo",
 
        "toolbar": true,
 
        "width": 800,
 
        "height": 600,
        "resizable": true,
 
        "show_in_taskbar": true,
 
        "frame": true,
 
        "kiosk": false
    },
"permissions": [
  "serial"
],
 
    "webkit": {
 
        "plugin": true
 
    }
}

20180219补充:

要在调试模式中的Cosole查看效果《Nodewebkit debug调试模式

串口调试工具接收到的数据应为十六进制显示

亲测截图如下




  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
Chrome API是一组由Google提供的应用程序接口,用于与Chrome浏览器进行交互和控制。通过Chrome API,开发者可以创建扩展程序或应用程序,以实现对浏览器的功能扩展和定制化。 Chrome API提供了丰富的功能和能力,包括但不限于以下几个方面: 1. 浏览器操作:可以通过Chrome API来控制浏览器的各种行为,例如打开新标签页、关闭标签页、刷新页面、获取当前标签页信息等。 2. 标签页管理:可以通过Chrome API来管理浏览器中的标签页,例如创建新标签页、切换标签页、获取标签页信息、发送消息给标签页等。 3. 网络请求:可以通过Chrome API来发送HTTP请求,获取网页内容或与服务器进行交互。还可以拦截和修改网络请求,实现自定义的网络请求处理逻辑。 4. 存储和同步:可以使用Chrome API来读写浏览器的本地存储,包括LocalStorage和IndexedDB。还可以使用Chrome同步服务将数据同步到用户的其他设备上。 5. 通知和提醒:可以使用Chrome API来创建桌面通知和提醒,向用户展示重要信息或提醒用户进行某些操作。 6. 权限管理:可以使用Chrome API来管理扩展程序或应用程序的权限,限制其对浏览器和用户数据的访问范围,提高安全性。 以上只是Chrome API的一部分功能,具体的使用方法和详细的API文档可以参考Google Chrome开发者文档。如果你有具体的问题或需要了解某个具体功能的实现方式,可以告诉我,我会尽力帮助你。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值