PR

ロボット制御⑩ Arduino UNO R4 Wifi を使ってみる
今回は、無線が使えるようになったArduino UNO R4 Wifiを購入して使ってみました。

制御

Arduino UNO R4 Wifi を購入したので、使ってみることにしました。
いつものArduino IDEではなく、Arduino Cloudを使って、LEDマトリックスであそんだり、WIFI機能を使ってシンプルなWebサーバを立てたりしてみました。

Arduino UNO R4 Wifi について

今回もスイッチサイエンスで購入しました。

【仕様】

項目仕様
マイコンRenesas RA4M1(Arm® Cortex®-M4)
Armv7E-M アーキテクチャ
・ 最大動作周波数 48MHz
・ 32bit CPU (4GBアドレス空間サポート)
・ 256KB コードフラッシュメモリ
・ 32KB SRAM
・ 8KB データフラッシュメモリ (EEPROM)
Wi-Fi・Bluetooth用マイコンEsprssif ESP32-S3 (Cadence Xtensa® LX7)
・ 最大動作周波数 240MHz
・ 384KB ROM
・ 512KB SRAM
USB接続USB-C (プログラミングポート / HID)
動作電圧5V
Wi-Fi802.11 b/g/n standard
・ 帯域 2.4GHz
・ 最大 150Mbps
BluetoothBluetooth%reg; 5
ピン・ 14 x デジタルI/O
・ 6 x アナログ入力(14ビット)
・ 1 x DAC(最高12ビット)
・ 6 x PWM
通信・ 1 x UART (ピン D0, D1)
・ 1 x SPI (ピン D10-D13, ICSP ヘッダー)
・ 1 x I2C (ピン A4, A5, SDA, SCL)
・ 1 x CAN (ピン D4, D5, 要外部トランシーバー)
※ Wi-Fi、Bluetooth を除く
電源入力電圧(VIN): 6~24 V
DC電流(各I/Oピン毎、最大値): 8mA
寸法68.85 mm x 53.34 mm(幅 x 長さ)
Arduino UNO R4 Wifi スペック

ピンアウト(ABX00087データシートより)

基本的なピンは、Arduino UNO R3 と同様です。

開封&接続してみました。

右下は、LEDマトリックスが付いていますが、静止画像&明るいところだと見えにくいですね。

↑ Arduino の公式サイトに載っているLEDが付いて見える画像です。

Arduino IDE でプログラムを書き込んでみる

まずは、Arduino IDE を繋いでみたいと思います。
Arduino IDE で 「Arduino UNO R4 Wifi」に接続するには、ボードマネージャで新しいボードを登録する必要があります。

ボードマネージャで上図のように「Arduino UNO R4 Boards」をインストールします。

すると、ボードメニューに「Arduino UNO R4 Minima」と「Arduino UNO R4 Wifi」が選択出来るようになりました。
とりあえず簡単なシリアルモニタに「Hello World!」と表示するプログラムを作って書き込んでみます。

/*
  Hellow World!
*/

void setup() {
  Serial.begin(115200);
  delay(500);
}

void loop() {
  Serial.println("Hello World!");
}
C++

書き込み時の出力がR3の時から変わっていますね。

シリアルモニタに永遠に「Hello World!」を出力し続けます。

Arduino Cloud を使ってみる

Arduino UNO R4 Wifi」は、Arduino IoT に対応しているということで、まずは、とっかかりを得るために Arduino Cloud を使ってみることにしました。

Device の追加

Arduino Cloud を使うためには、Arduino 公式サイトにユーザ登録してログインする必要があります。
ユーザ登録を行ってログインしようとしましたが、上手くいかなかったので、Googleアカウントでログインを行うと、あっけなくログイン出来て以下のサイトが開きました。

なぜ「日本語」翻訳で使わないのか?
何もかも翻訳してしまうのです。ファイル名さえも…
翻訳は、WEB読むだけの時は便利ですがCloudツールでは、不要な翻訳までしてしまうので、かえって不便に感じてしまいます。

まずは、Device を追加する必要があります。「Devices」メニューから「+ Device」を押します。
Deviceを追加するには、Arduino Cloud Agent というプログラムをダウンロード&インストールして、ボードの状態を監視する必要があります。

ダウンロードした最新の「Arduino Cloud Agent」をインストールします。

元の画面に戻るとデバイスとの接続画面に変わっています。

上図の画面の状態で約5分ほど待ちます。

次へ進む前に、一度、デバイスをコンピュータから外して、もう一度、接続します。

デバイスの名前を付けます。
外国の人の名前のようですが、候補を何回か見て、読みやすそうな「Nadia」にしました。
これは、何を選んでも、使用には影響もないものだと思います。

デバイス一覧に「Nadia」が表示されました。
デバイスの追加が完了しました。

簡単なプログラムを作ってみる

Arduino IDE の時と同じように「Hello World!」を書き込むプログラムを作ってみます。

またもや永遠にHello World! を吐き続けます。

LED Matrix で遊んでみる

まずは、公式サイトのDOCSを確認してみます。

読むだけだと、翻訳は、本当に大変便利です。(先ほどは不便と書いてごめんなさい)

さて、本題に戻ります。Arduino UNO R4 のLEDマトリックスでは、12 x 8 のLEDを点灯させて文字や絵を表現することが出来ます。マトリックスの座標は、以下の写真のような配置になっています。

実際にマッピングするときには、0から始まって95まで指定します。
各LEDの点灯、消灯の指定は、1ビットの0:オフ、1:オンで表現することが出来ます。

ハートを表示してみる

まず、LED Matrix を使うためには、Arduino_LED_MatrixライブラリをINCLUDEする必要があります。ライブラリを開いて「LED Matrix」で検索します。

INCLUDEボタンを押すと先頭にインクルード文が2行追加されました。
下側の「#includr <gallery.h」は、不要です。消して配置を整えます。
まずは、Byte型配列でLED Matrix にハートを書いてみます。

led_matrix_01.ino

/*
  LED Matrix Sample Programe 01
  for Arduino UNO R4 Wifi
*/
#include <Arduino_LED_Matrix.h>

ArduinoLEDMatrix matrix;

byte frame[8][12] = {
  { 0, 0, 1, 1, 0, 0, 0, 1, 1, 0, 0, 0 },
  { 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 0 },
  { 0, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0 },
  { 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0 },
  { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0 },
  { 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0 },
  { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 },
  { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }
};

void setup() {
  Serial.begin(115200);
  matrix.begin();
}

void loop() {
  matrix.renderBitmap(frame, 8, 12);
  delay(1000);
  matrix.clear();
  delay(1000);
}
C++

まずは、Arduino_LED_Matrix.h をインクルードします。
ArduinoLEDMatrixクラスのインスタンスmatrixを作成します。
続いて、表示するLEDMatrixのframe配列にバイト型で1:オン、0:オフを設定しています。
setup() の中では、初期化のために「matrix.begin()」を呼び出します。
matrix.renderBitmap(frame, 8, 12);」でハートを表示
matrix.clear();」で全てのLED Matrixを消しています。

続いて32ビットの正の整数でフレームを定義してみます。

led_matrix_02.ino

/*
  LED Matrix Sample Program 02.
  for Arduino UNO R4 Wifi
*/
#include <Arduino_LED_Matrix.h>

ArduinoLEDMatrix matrix;

unsigned long frame[] = {
  0x3184a444,
  0x42081100,
  0xa0040000
};

void setup() {
  Serial.begin(115200);
  matrix.begin();
  for (int b = 0; b < 3; b++) {
    Serial.println(frame[b], BIN);
  }
}

void loop() {
  matrix.loadFrame(frame);
  delay(500);
  matrix.clear();
  delay(500);
}
C++

シンプルですね。frame配列には、32ビット×3の96ビットの値が保持されています。
もっとも効率的にフレームを保持する方法です。

スケッチ作成から動作確認まで動画を作ってみました。
どうも著作権の関係で一部の動画がカットされてしまいました。

アニメーションを作ってみる

画像の点滅だけでは、面白くないので、動くアニメーションを作ってみたいと思います。

まずは、アニメーションのフレームを作っていきます。
フレーム作成は、LED Matrix Editor を利用します。

このようなアニメーションを作成しました。
右上の「</>」ボタンを押すとアニメーション定義用のヘッダーファイルを作成してくれます。

実際にプログラムを作っていきます。

led_matrix_03.ino

/*
  LED Matrix Sample Program 03.
  for Arduino UNO R4 Wifi
*/
#include <Arduino_LED_Matrix.h>
#include "animation.h"

ArduinoLEDMatrix matrix;

void setup() {
  Serial.begin(115200);
  matrix.loadSequence(animation);
  matrix.begin();
  matrix.play(true);
}

void loop() {
  delay(500);
  Serial.println(millis());
}
C++

animation.h

const uint32_t animation[][4] = {
	{
		0x4,
		0x0,
		0x0,
		66
	},
	{
		0xe,
		0x400000,
		0x0,
		66
	},
	{
		0x1b01f,
		0xe00400,
		0x0,
		66
	},
	{
		0x1103b83f,
		0x81f00e00,
		0x40000000,
		66
	},
	{
		0x3187bc7f,
		0xc3f81f00,
		0xe0040000,
		66
	},
	{
		0x71cfbeff,
		0xe7fc3f81,
		0xf00e0040,
		66
	},
	{
		0xfbefffff,
		0xfffe7fc3,
		0xf81f00e0,
		66
	},
	{
		0xfbefffff,
		0xffffffe7,
		0xfc3f81f0,
		66
	},
	{
		0xffffffff,
		0xffffffff,
		0xfe7fc3f8,
		66
	},
	{
		0xffffffff,
		0xffffffff,
		0xffffe7fc,
		66
	},
	{
		0xffffffff,
		0xffffffff,
		0xfffffffe,
		66
	},
	{
		0xffffffff,
		0xffffffff,
		0xffffffff,
		66
	}
};
C++
Expand

スケッチ作成から動作確認まで動画を作ってみました。

テキストをスクロールしてみる

今度は、テキストをスクロールしてみます。
基本的には、LED Matrix の文字表示は、ArduinoGraphicsライブラリがサポートしています。

led_matrix_04.ino

/*
  LED Matrix Sample Program 04.
  for Arduino UNO R4 Wifi.
  Scrolling Text Example.
*/
#include <ArduinoGraphics.h>
#include <Arduino_LED_Matrix.h>

ArduinoLEDMatrix matrix;

void setup() {
  Serial.begin(115200);
  matrix.begin();

  matrix.beginDraw();
  matrix.stroke(0xFFFFFFFF);
  const char text[] = "UNO r4";
  matrix.textFont(Font_4x6);
  matrix.beginText(0, 1, 0xFFFFFF);
  matrix.println(text);
  matrix.endText();
  matrix.endDraw();
  delay(2000);
}

void loop() {
  matrix.beginDraw();
  matrix.stroke(0xFFFFFFFF);
  matrix.textScrollSpeed(50);

  // add the text
  const char text[] = "    Hello World!    ";
  matrix.textFont(Font_5x7);
  matrix.beginText(0, 1, 0xFFFFFF);
  matrix.println(text);
  matrix.endText(SCROLL_LEFT);

  matrix.endDraw();
}
C++
Expand

matrix.beginDraw();」「matrix.stroke(0xFFFFFFFF);」はおまじないのようなものでテキストを表示する場合には、定型文として記述します。
文字の大きさは、「matrix.textFont(フォントサイズ);」で指定します。ここでは、Font_4x6Font_5x7 が出てきます。
テキストの開始位置は「matrix.beginText(x,y, 0xFFFFFF)」で指定します。0xFFFFFF は、文字色でArduino UNO R4 Wifi では、白(0xFFFFFF)固定になります。

スケッチ作成から動作確認まで動画を作ってみました。

WiFiを使って簡単なWebServerを作ってみる

Arduino UNO R4 WiFi には、WiFiとBluetooth用のマイコンが標準で搭載されています。
マイコンは、Espressif の ESP32-S3 です。ESP32で始まるマイコン用チップと、それを載せた開発用ボードは、かなりメジャーでインターネット上に情報が沢山あります。
仕様については、このページの最初の方で掲載したので割愛しますが、2.4GHz帯域であるということだけは覚えておく必要があります。つまり、5G帯域のアクセスポイントには接続できません。

まずは、公式サイトのDOCSを確認してみます。

今回も Arduino Cloud を使ってサンプルプログラムを作っていきます。
スケッチを新規作成して、WiFiを使う上で必要なライブラリをインクルードします。

検索ボックスに「WiFiS3」と入力して検索します。
これは、ESP32-S3用のライブラリになります。
DOCSを参考にプログラムコードを記述してコンパイル&アップロードを行います。

なお、「arduino_secrets.h」は、自宅のSSIDと接続用パスワードを記載しています。

//arduino_secrets.h header file
#define SECRET_SSID "yournetwork"
#define SECRET_PASS "yourpassword"
C++

上記の “yournetwork” 部分を自宅のSSIDに変更、“yourpassword” 部分をパスワードに変更します。

作るプログラムは、Arduino UNO R4 WiFi にシンプルなウェブサーバ起動させて、アクセスしたクライアントからビルトインのLEDを点灯したり消灯したりするものです。

wifi_simple_webserver.ino

/*
  WiFi Sample Program 01
  for Arduino UNO R4 Wifi.
  Simple Webserver
*/
#include <WiFiS3.h>
#include "arduino_screts.h"

char ssid[] = SECRET_SSID;    // your network ssid (name)
char pass[] = SECRET_PASS;    // your network password (use for WPA/WAP2, or use as key for WEP)
int keyIndex = 0;             // your network key index number (needed only for WEP)

int led = LED_BUILTIN;
int status = WL_IDLE_STATUS;
WiFiServer server(80);

void setup() {
  Serial.begin(115200);
  pinMode(led, OUTPUT);

  // check for the WiFi module:
  if (WiFi.status() == WL_NO_MODULE) {
    Serial.println("Communication with WiFi module failed!");
    while (true);    // don't continue
  }
  String fv = WiFi.firmwareVersion();
  if (fv < WIFI_FIRMWARE_LATEST_VERSION) {
    Serial.println("Please upgrade the firmware");
  }

  // attempt to connect to WiFi network:
  while (status != WL_CONNECTED) {
    Serial.print("Attempting to connect to Network named: ");
    Serial.println(ssid);
    // Connect to WPA/WPA2 network.
    status = WiFi.begin(ssid, pass);
    delay(10000);   // wait 10 seconds for connection;
  }
  server.begin();
  printWifiStatus();
}

void loop() {
  WiFiClient client = server.available();  // listen for incoming clients
  if (client) {
    Serial.println("new client");
    String currentLine = "";
    while (client.connected()) {
      char c = client.read();
      Serial.write(c);
      if (c == '\n') {
        if (currentLine.length() == 0) {
          // the headers of the HTTP response:
          client.println("HTTP/1.1 200 OK");
          client.println("Context-type:text/html");
          client.println();
          // the content of the HTTP response:
          client.print("<p style=\"font-size:7vw;\">Click <a href=\"/H\">here</a> turn the LED on<br></p>");
          client.print("<p style=\"font-size:7vw;\">Click <a href=\"/L\">here</a> turn the LED off<br></p>");
          client.println();
          // break out of the while loop:
          break;
        } else {
          // then clear currentLine:
          currentLine = "";
        }
      } else if (c != '\r') {
        currentLine += c;
      }

      // Check to see if the client request was "GET /H" or "GET /L":
      if (currentLine.endsWith("GET /H")) {
        digitalWrite(led, HIGH);
      }
      if (currentLine.endsWith("GET /L")) {
        digitalWrite(led, LOW);
      }
    }
    // close the connection
    client.stop();
    Serial.println("client disconnected");
  }
}

void printWifiStatus() {
  // print the SSID of the network you're attached to:
  Serial.print("SSID: ");
  Serial.println(WiFi.SSID());
  // print your board's IP address:
  IPAddress ip = WiFi.localIP();
  Serial.print("IP Address: ");
  Serial.println(ip);
  // print the received signal strength:
  long rssi = WiFi.RSSI();
  Serial.print("signal strength (RSSI): ");
  Serial.print(rssi);
  Serial.println(" dBm");
  // print where to go in a browser:
  Serial.print("To see this page in action, open a browser to http://");
  Serial.println(ip);
}
C++
Expand

コンパイル&アップロードすると、シリアルモニタに以下のように表示されます。

Attempting to connect to Network named: XXXXXX
SSID: XXXXXX
IP Address: XXX.XXX.XXX.XXX
signal strength (RSSI): -44 dBm
To see this page in action, open a browser to http://XXX.XXX.XXX.XXX

最後のメッセージに合わせて、http://XXX.XXX.XXX.XXX(←Arduino UNO R4のローカルIP)のURLをブラウザで指定してアクセスします。

上記のように表示されます。少し文字が大きいですね。
「Click here turn the LED on」の here をクリックすると Arduino のLEDが点灯し、
「Click here turn the LED off」の here をクリックすると Arduino のLEDが消灯します。

LED on の here をクリック
LED off の here をクリック

以上です。

コメント

  1. zoritoler imol より:

    I truly appreciate this post. I have been looking all over for this! Thank goodness I found it on Bing. You’ve made my day! Thx again

タイトルとURLをコピーしました