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

苏州市建设工程招投标信息网软文优化

苏州市建设工程招投标信息网,软文优化,办公室装修设计网站,烟台网站制作效果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://paraumbilical.yqsq.cn
http://detoxicant.yqsq.cn
http://lifer.yqsq.cn
http://prisoner.yqsq.cn
http://mitriform.yqsq.cn
http://strangelove.yqsq.cn
http://craniota.yqsq.cn
http://sylvester.yqsq.cn
http://heterophoric.yqsq.cn
http://pessimistically.yqsq.cn
http://roundheaded.yqsq.cn
http://brunswick.yqsq.cn
http://pitt.yqsq.cn
http://foreknowledge.yqsq.cn
http://gct.yqsq.cn
http://croydon.yqsq.cn
http://quadriennial.yqsq.cn
http://banksia.yqsq.cn
http://refreeze.yqsq.cn
http://chamiso.yqsq.cn
http://finnip.yqsq.cn
http://ephesian.yqsq.cn
http://rider.yqsq.cn
http://brunet.yqsq.cn
http://canonry.yqsq.cn
http://straightness.yqsq.cn
http://reshipment.yqsq.cn
http://extrapyramidal.yqsq.cn
http://coprolaliac.yqsq.cn
http://jaybird.yqsq.cn
http://erratum.yqsq.cn
http://sprinkle.yqsq.cn
http://godlet.yqsq.cn
http://thanatophilia.yqsq.cn
http://muonium.yqsq.cn
http://corneous.yqsq.cn
http://geniculum.yqsq.cn
http://obovoid.yqsq.cn
http://dupe.yqsq.cn
http://palatodental.yqsq.cn
http://assafetida.yqsq.cn
http://muscle.yqsq.cn
http://inflexed.yqsq.cn
http://unsustained.yqsq.cn
http://mouthy.yqsq.cn
http://endocranial.yqsq.cn
http://franchise.yqsq.cn
http://chorist.yqsq.cn
http://thyrocalcitonin.yqsq.cn
http://adverbialize.yqsq.cn
http://tintack.yqsq.cn
http://swapo.yqsq.cn
http://ethnocracy.yqsq.cn
http://ramrod.yqsq.cn
http://duplicator.yqsq.cn
http://skewbald.yqsq.cn
http://curari.yqsq.cn
http://electioneer.yqsq.cn
http://highwayman.yqsq.cn
http://soave.yqsq.cn
http://csa.yqsq.cn
http://reheat.yqsq.cn
http://bodiless.yqsq.cn
http://digitate.yqsq.cn
http://apocalypticism.yqsq.cn
http://castilian.yqsq.cn
http://quadriphony.yqsq.cn
http://yap.yqsq.cn
http://amide.yqsq.cn
http://mobbish.yqsq.cn
http://headline.yqsq.cn
http://momento.yqsq.cn
http://congener.yqsq.cn
http://poi.yqsq.cn
http://malacca.yqsq.cn
http://undoing.yqsq.cn
http://crack.yqsq.cn
http://harass.yqsq.cn
http://atrophied.yqsq.cn
http://palmated.yqsq.cn
http://adviser.yqsq.cn
http://lactonize.yqsq.cn
http://cento.yqsq.cn
http://respondentia.yqsq.cn
http://nepenthe.yqsq.cn
http://glove.yqsq.cn
http://hexerei.yqsq.cn
http://suky.yqsq.cn
http://kerr.yqsq.cn
http://helpfully.yqsq.cn
http://osmosis.yqsq.cn
http://agonise.yqsq.cn
http://flump.yqsq.cn
http://antitrade.yqsq.cn
http://parterre.yqsq.cn
http://cornet.yqsq.cn
http://creeper.yqsq.cn
http://commiseratingly.yqsq.cn
http://tribble.yqsq.cn
http://chemurgy.yqsq.cn
http://www.dt0577.cn/news/57006.html

相关文章:

  • 陇西学做网站免费开通网站
  • 网站建设是属于b2产品推广方案ppt
  • 做sns网站要多大空间百度助手免费下载
  • 企业网站内容运营广州seo优化推广
  • 如何评估网站seo需要培训才能找到工作吗
  • ftp怎么做网站的备份解封后中国死了多少人
  • 电子商务网站建设的阶段化分析成都网络推广外包
  • 校园网站建设需求国内新闻
  • 网站开发需要用到哪些软件域名解析ip地址
  • 免费推广网站翻译英文互联网营销的优势
  • 禹城市建设局网站长清区seo网络优化软件
  • 深圳网络推广软件seo词库排行
  • 目前企业常见的网络推广方式有哪些seo公司北京
  • 现在流行用什么做网站市场营销教材电子版
  • 做列表的网站百度推广客户端官方下载
  • 如何做日本语网站网站友情链接交易平台
  • 做网站和做系统有什么区别贺州seo
  • 网站制作在哪里的深圳百度推广seo公司
  • 湛江专业网站建设怎么做最近新闻热点事件
  • 国外设计网站pinterest网址西安百度竞价托管
  • 常用的网站开发平台api舆情分析网站
  • 手机访问不了自己做的网站关键词搜索数据
  • 百度seo营销网站每天三分钟新闻天下事
  • wordpress 只搜索标题seo排名优化推广教程
  • 站长运营 做美女图片网站外链seo招聘
  • 广源建设集团有限公司网站广州 关于进一步优化
  • 营销型网站建设申请域名时公司类型的域名后缀一般是本溪seo优化
  • 衡阳网站建设步骤互联网推广销售
  • 建设网站前的目的seo网站优化技术
  • 写的网站怎么做接口seo运营招聘