今まで見かけていた「p5.js でシリアル通信を使うライブラリ」というと、公式ページで紹介されている「p5-serial/p5.serialport」があったのですが、それとは別の最近リリースされたっぽいライブラリを見かけました。
そこで、その新しいライブラリを p5.js Web Editor上で試してみた、というのがこの記事の内容です。
ongzzzzzz/p5.web-serial の仕組みについて
今回試してみるのは「ongzzzzzz/p5.web-serial」というライブラリです。
上記の「p5-serial/p5.serialport」との違いは、Webページ上でシリアル通信を実現する方法です。
「p5-serial/p5.serialport」のほうは、「p5.serialcontrol application または p5.serialserver」という仲介役となるアプリを動かしつつ、それと別に p5.js のプログラムを動かす構成になるようです。
一方、「ongzzzzzz/p5.web-serial」のほうはブラウザの Web Serial API を用いており、そのような仲介役になるアプリを別に用意することなくシリアル通信を行えます。ただし、Web Serial API をサポートしているブラウザは限定的(基本的に Chrome系のみ)であるため、その点は注意が必要です。
【余談】 Web Serial APIについて
余談ですが、Web Serial API を利用した通信について、過去にいくつか記事を書いているので、Web Serial API が気になるという方は、よろしければご覧ください。
- 過去に書いた記事
ongzzzzzz/p5.web-serial を使ってみる
それでは、p5.js Web Editor上で ongzzzzzz/p5.web-serial を使ってみます(ブラウザは Google Chrome を利用します)。
簡単な動作確認まで行う
まずは、index.html に以下の行を追加します(※ 公式の GitHubリポジトリで紹介されているリンクです)。
<script src="https://cdn.jsdelivr.net/gh/ongzzzzzz/p5.web-serial/lib/p5.web-serial.js"></script>
そして、script.js のほうで公式のサンプルを動かしてみます。
// additional code here...
と書かれた部分は何も修正せずという状態で、動作確認だけを行います。
let port, reader, writer;
async function setup() {
createCanvas(400, 400);
// additional code here...
noLoop();
({ port, reader, writer } = await getPort());
loop();
}
function draw() {
background(220);
}
上記のプログラムを実行すると、プレビュー画面のほうに以下の表示が行われます。
そして、表示された2つのボタンのうちの左側のものを押すと、以下のように Web Serial API の利用許可を求めるダイアログが表示されました。
ここで本来は、シリアル通信に使いたいシリアルポートを選択する操作を行うのですが、今時点ではシリアル通信をさせたいデバイスをつないでないので、表示が出ることだけ確認しておきます。
デバイスとの通信を行ってみる(ブラウザからの書き込み)
Sending data from the browser to the Arduino という部分を見つつ、ブラウザからの書き込みを試してみます。
p5.js側のプログラム
ちなみに、公式ページには以下の例が書かれています。
async function draw() {
if (port) {
try {
if (mouseIsPressed) {
// do something...
await writer.write("clicked!\n");
}
else {
// do something...
await writer.write("not clicked!\n");
}
} catch (e) { console.error(e) }
}
}
こちらは、デバイスとの間でのシリアル通信できる状態で、マウスのボタンを押しているかどうかによって、異なる文字列を書きこむもののようです。
先ほど動作確認を行ったプログラムに混ぜ込みつつ、少し変更を加えて動かしてみます。
まず、sketch.js は以下にしました。
let port, reader, writer;
async function setup() {
createCanvas(400, 400);
noLoop();
({ port, reader, writer } = await getPort());
loop();
frameRate(4);
}
async function draw() {
if (port) {
try {
if (mouseIsPressed) {
background("BLUE");
await writer.write("AAA\n");
} else {
background("BLACK");
}
} catch (e) {
console.error(e);
}
}
}
micro:bit側のプログラム
あとはデバイス側の準備です。
p5.web-serial/examples/web-to-arduino/main.ino に Arduino用のサンプルプログラムが掲載されていますが、自分は過去の Web Serial API のお試しで使った micro:bit を使います。
micro:bit用のプログラムは、以下の内容のものを MakeCode で作りました。
それでは micro:bit へプログラムを書きこみましょう。
実際の動作の様子
プログラムを書き込み済みの micro:bit と PC を USB で接続した状態で、p5.js のプログラムを実行します。
プレビュー画面に表示される以下の画面で、「Add a device」と書かれたボタンを押し、その後に表示されるダイアログ上に micro:bit という名前を含むものがあると思いますので、それを選んでください。
そして、「Connect!」と書かれたほうのボタンを押します。
そうすると、プレビュー画面が以下のような表示になるので、プレビュー画面上をマウスでクリックしてください。マウスをクリックしてない時は黒背景で、クリックをした時に青背景になると思います。
そして、クリックをした時には micro:bit側で、以下の動画にあるような LED表示の変化が起こると思います。
#p5js のプログラムと #microbit との Web Serial API を使ったシリアル通信!(mouseIsPressed に反応する形)
— you (@youtoy) April 2, 2022
↑記事も書いた
●Web Serial API を利用できる p5.js用のライブラリ「p5.web-serial」で micro:bit とのシリアル通信(p5.js Web Editor・MakeCodeを利用)
https://t.co/3vsdSUi5xV pic.twitter.com/i7hymLvFDV
無事、意図通りに動いたことを確認できました。