当前位置: 首页 > news >正文

帝国cms生成网站地图cetos做网站

帝国cms生成网站地图,cetos做网站,网站开发注意事项,中国寰球工程公司Electron学习3 使用serialport操作串口 一、准备工作二、 SerialPort 介绍1. 核心软件包(1) serialport(2) serialport/stream(3) serialport/bindings-cpp(4) serialport/binding-mock(5) serialport/bindings-interface 2. 解析器包3. 命令行工具 三、创建一个demo程序1. 创建…

Electron学习3 使用serialport操作串口

  • 一、准备工作
  • 二、 SerialPort 介绍
    • 1. 核心软件包
      • (1) serialport
      • (2) @serialport/stream
      • (3) @serialport/bindings-cpp
      • (4) @serialport/binding-mock
      • (5) @serialport/bindings-interface
    • 2. 解析器包
    • 3. 命令行工具
  • 三、创建一个demo程序
    • 1. 创建 electron 项目
    • 2. 安装 serialport
    • 3. 安装 electron-rebuild
    • 4. 使用 node-gyp 编译库
    • 5. 修改 main.js 配置
    • 8. 写测试程序
    • 7. 运行程序
  • 四、问题处理
    • 1. 安装python2.7虚拟环境
    • 2. 安装windows-build-tools

在这里插入图片描述

一、准备工作

本文将使用 nodejs 的 SerialPort 包来实现串口通讯功能。
Node SerialPort 是一个 JavaScript 库,用于连接到在 NodeJS 和 Electron 中工作的串行端口,以下是准备环境:

  • Electron 开发环境
  • 电脑有串口通讯能力,一般使用USB-串口转接板
  • windows 操作系统

本文操作过程来自:
https://girishjoshi.io/post/access-serialport-from-electron-application-and-creating-gui-for-micropython-repl-on-esp8266/

二、 SerialPort 介绍

文档地址:
https://serialport.io/docs/

1. 核心软件包

(1) serialport

主对象,使用流式传输支持跨平台的串行端口访问。

(2) @serialport/stream

为绑定提供的流式接口。

(3) @serialport/bindings-cpp

为nodejs、electron提供跨平台的绑定支持。

(4) @serialport/binding-mock

为测试实现模拟绑定功能。

(5) @serialport/bindings-interface

一个typescript 接口用来实现自己的绑定时使用。

2. 解析器包

解析器用来对原始的二进制数据转换成自己需要的消息格式。 包含以下解析器包,这里不进行详解:

  • @serialport/parser-byte-length
  • @serialport/parser-cctalk
  • @serialport/parser-delimiter
  • @serialport/parser-inter-byte-timeout
  • @serialport/parser-packet-length
  • @serialport/parser-readline
  • @serialport/parser-ready
  • @serialport/parser-regex
  • @serialport/parser-slip-encoder
  • @serialport/parser-spacepacket

3. 命令行工具

比较有用的命令行工具,包括:

  • @serialport/list
  • @serialport/repl
  • @serialport/terminal

三、创建一个demo程序

1. 创建 electron 项目

# Clone the Quick Start repository
$ git clone https://github.com/electron/electron-quick-start
# Go into the repository
$ cd electron-quick-start
# Install the dependencies and run
$ npm install && npm start

2. 安装 serialport

npm install --save serialport 

3. 安装 electron-rebuild

因为选择npm版本不同,这里要对库进行重编译,要先安装 electron-rebuild 工具。

npm install --save-dev electron-rebuild  
.\node_modules\.bin\electron-rebuild
npm rebuild

注意原文路径中用的 / , 我在windows 系统,改用 \

4. 使用 node-gyp 编译库

npm install node-gyp electron electron-rebuild serialport --build-from-source
./node_modules/.bin/electron-rebuild
npm start

5. 修改 main.js 配置

修改 WebPreferences 如下:

webPreferences: {preload: path.join(__dirname, 'preload.js'),nodeIntegration: true,contextIsolation: false
}

8. 写测试程序

<!DOCTYPE html>
<html>
<head><meta charset="UTF-8"><title>Electron test serialport</title>
</head>
<body>
<h1>Serial terminal</h1><script>//load serialport moduleconst {SerialPort} = require('serialport');SerialPort.list().then(_=>{console.info(_);});const serialPort = new SerialPort({path:'COM3', baudRate: 115200}, function (err) {if(err) {console.error(err);}});console.info(serialPort);serialPort.write("abc", (err)=>{if (err) {return console.log('Error on write: ', err.message)}console.log('message written')});serialPort.on('error', function(err) {console.log('Error: ', err.message)});serialPort.on('data', function (data){console.info('data', data);});</script>
<script>require('./renderer.js')
</script>
</body>
</html>

7. 运行程序

npm start

项目结构:
在这里插入图片描述

四、问题处理

在执行electron-rebuild时,可能需要安装windows-build-tools。新版本的windows-build-tools支持Python3.*版本,但使用Python2.7比较保险。

1. 安装python2.7虚拟环境

如果本机没有Python2.7,则可以使用MiniAnaconda配置虚拟环境 。 先下载安装MiniAnaconda工具,然后用命令行创建虚拟环境 :

conda create -n py27 python=2.7
conda activate py27

2. 安装windows-build-tools

直接安装windows-build-tools大概率会失败,可按以下流程操作:

在执行npm install -g node-gpy后使用命令:

npm install -g --production windows-build-tools@4.0.0
  1. 当命令行界面开始不动时,打开任务管理器,把Build Tools结束任务;
  2. 再打开.windows-build-tools文件夹中的build-tools-log.txt,添加Variable: IsInstalled = 1,保存,关闭;
    解决方案参考:https://blog.csdn.net/web15085181368/article/details/123192964

更多关于serialport的功能可参考官方文档。

http://www.yayakq.cn/news/542367/

相关文章:

  • 北京王府井在哪个区常用的seo工具
  • 微信商城和微网站wordpress 禁止地区ip
  • 泰安公司网站建设wordpress 首页动画
  • 郑州网站建设汉狮网站后台的建设
  • 河北网站制作公司哪家好济宁哪里有网站建设
  • 汉台网站制作哪些网站可以做养殖的广告
  • 企业做网站需要什么手续吗大岭山网站
  • 社区信息建设网站网站建设7个基本流程步骤有哪些
  • 无上光东莞网站深圳做官网公司
  • 如何用网站做推广深圳软件系统开发
  • 做淘宝客最好的网站是什么网站深圳vi设计公司全力设计
  • 自己搭建一个网站英文公司网站模板
  • 重庆市建设工程信息网官网安全监督信息网北京网络seo推广公司
  • 十大下载网站免费安装合肥做网站的公
  • 免费建立网站软件陕西省建设安全协会网站
  • 网做英文网站网站如何进行优化
  • 网站中的下拉菜单茶叶怎么做网站销售
  • 新网站应该怎么做电商培训机构排名前十
  • 民治做网站联系电话和拓者设计吧类似的网站
  • 软文素材网站工作邮箱认证提额
  • 网站icon图标怎么设置网站规划和建设的基本要求
  • 高淳 网站建设温州网牌电线电缆有限公司
  • 建设h网站风险大吗上海外贸网站制作
  • 住房和城乡建设部网站质保金网络营销方式
  • 网站建设 骏域网络建设专家广州摄影师做展示的网站
  • 拿自己爱人做网站网站二维码链接怎么做
  • 深圳苏州旅游网站建设服务个人主页格式
  • 建设一个公司网站大概多少钱廊坊网站建设联系青橙网络
  • 网站开发怎么兼容pc和移动端织梦网站如何做二级导航
  • 多样化的网站建设公司微官网与手机网站首页