wiki:WS2822S

WS2822SシリアルLEDの使い方

関連商品

WS2822Sの特徴

フルカラーシリアルLEDのWS2822SはEEPROMを内蔵していてそこにアドレス情報を保存することができます。
それぞれのLEDがアドレスを持つことで、複数のLEDを1本の信号線で制御できます。
信号線は色信号に1本、アドレス信号に1本の合計2本が必要です。
WS2822Sの利点、WS2812Sとの比較はこちら

 

通信方法

WS2822Sの通信方法にはDMX512という通信規格の拡張方式を用いています。
DMX512とは舞台照明や演出機器などのコントロールに使われる規格で、512チャンネルx8bitの情報を扱えます。
WS2822Sの通信規格では3072チャンネルx8bitの情報を扱えます。WS2822Sの色情報は赤緑青の3色x8bitなので、1LEDあたりに3チャンネル分の情報が必要です。
つまり最大で1024個のLEDが1本の信号線でコントロール可能です。

・色信号

色制御信号のフォーマットは次のようになっています。

色の制御信号は全てのLEDに並列に接続されているので、全てのLEDに同時に届きます。
アドレスが1番に設定されたLEDは1、2、3番目の情報を取り込みます。
アドレスが4番に設定されたLEDは4、5、6番目の情報を取り込みます。

・アドレス信号

アドレス設定信号のフォーマットは次のようになっています。

アドレスの設定信号は色の信号と違って並列ではなくLED同士が直列に数珠繋ぎになっています。
ADRIピンにアドレスの情報が入力され、アドレス情報を受け取ったLEDは次につながっているLEDのためのアドレス情報をADROから出力します。
次の例は先頭のLEDにアドレス4番、その次のLEDに7番を書き込む時の先頭LEDのADRIとADROの波形を表しています。

アドレスの値は3byteの情報で表され、組み合わせは次の表のようになっています。

ライブラリ

Arduino用WS2822Sライブラリを作成しました。
このライブラリはATmega328Pを搭載したArduino用です。動作検証はArduino Uno R3で行いました。

インストール方法

ダウンロード ←をクリックするとWS2822S-master.zipというZIPファイルをダウンロードします。
ZIPファイルを解凍して、フォルダ名をWS2822S-masterからWs2822sに変更します。(しなくても問題はありません。)

Ws2822sフォルダの中身は次のようになっています。

Ws2822sフォルダごとArduinoのライブラリフォルダにコピーします。
コピーする場所ははArduino IDE本体があるフォルダのlibrariesです。

Arduino IDEを起動します。(すでに起動していた場合は再起動)

スケッチ → ライブラリを使用 → Ws2822s
Ws2822sが入っている事が確認できたらライブラリのインストールは完了です。

使い方

まず最初にアドレスをLEDに書き込みます。

//*****************************************************************
// WS2822S
//
// アドレス設定  setAddress(LEDの先頭番号、LEDの末尾番号)
//******************************************************************

#include "Ws2822s.h"
#define PIXEL_NUM 10    //使用するWS2822Sの数
#define LED_PIN 13      //WS2822SのDAIピンにつなげるArduinoのピン番号
#define ADR_PIN 12      //WS2822SのADRIピンにつなげるArduinoのピン番号

Ws2822s LED(LED_PIN , ADR_PIN, PIXEL_NUM);

void setup()
{
    
}
void loop()
{       
    LED.setAddress(0,9); // 先頭から0,1,2... 8,9とアドレスを書き込み
                         // 一度アドレスを書き込んだらLEDの電源をOFFに
    delay(5000);
}

このスケッチをArduino Unoで実行しました。WS2822SのDAIピンをArduino Unoの13番ピンに、ADRIピンをArduino Unoの12番ピンに接続してあります。
LEDの先頭から順番にアドレスをつけていくと1、4、7…となりますが、ライブラリ上では0、1、2…となるようにしてあります。
setAddress(0,9); とすると先頭から0123456789と順番にアドレスを割り振ります。

アドレスの書き込みに成功するとLEDが白く光ります。一度アドレス書き込みが成功したら電源を切ります。電源を切ってもアドレス情報は消えません。
アドレスの変更予定が無ければアドレスの信号線ははずしてしまってもかまいません。

次にスケッチを変更してLEDを光らせてみます。

//*****************************************************************
// WS2822S
// 2015/01/29
//
// 色情報の設定 setColor(LEDの番号、赤、緑、青)
// 色情報の送信  send()
//
//******************************************************************
#include <MsTimer2.h>
#include "Ws2822s.h"
#define PIXEL_NUM 10    //使用するWS2822Sの数
#define LED_PIN 13      //WS2822SのDAIピンにつなげるArduinoのピン番号

Ws2822s LED(LED_PIN , PIXEL_NUM);

void write_color()
{
    LED.send();
}

void setup()
{
    //色配列の初期化
    for(int i=0; i<PIXEL_NUM; i++){
        LED.setColor(i,0,0,0);
    }
    //色情報送信用タイマ設定
    MsTimer2::set(100,write_color);
    MsTimer2::start();
}
void loop()
{     
  for(int i=0;i<PIXEL_NUM;i++){
      LED.setColor(i              ,0xFF,0x00,0x00);
      LED.setColor((i+1)%PIXEL_NUM,0xFF,0xFF,0x00);
      LED.setColor((i+2)%PIXEL_NUM,0x00,0xFF,0x00);
      LED.setColor((i+3)%PIXEL_NUM,0x00,0xFF,0xFF);
      LED.setColor((i+4)%PIXEL_NUM,0x00,0x00,0xFF);
      LED.setColor((i+5)%PIXEL_NUM,0xFF,0x00,0xFF);
      LED.setColor((i+6)%PIXEL_NUM,0x00,0x00,0x00);
      LED.setColor((i+7)%PIXEL_NUM,0x00,0x00,0x00);
      LED.setColor((i+8)%PIXEL_NUM,0x00,0x00,0x00);
      LED.setColor((i+9)%PIXEL_NUM,0x00,0x00,0x00);
  }
}

#define PIXEL_NUM 10 で使用するWS2822Sの数を指定します。

Ws2822s LED(LED_PIN,PIXEL_NUM); で色情報の送信に使うピンが決まり、色情報を保存する配列が作られます。

LED.setColor(アドレ,赤,緑,青);で作られた配列に色情報を書き込みます。アドレスに指定できる値は0 ~ PIXEL_NUM-1 の範囲です。

色情報の送信は LED.send()で行います。用意した配列に書き込まれた色の情報を送信します。

WS2822Sは最長でも1秒以内に色情報を書き直す必要があるので、MsTimer2ライブラリを使用して100ms毎に色情報を書き込んでいます。
LEDに送信された色情報が反映されてLEDがその色に光るのは、その次の色信号のBreakが送られたタイミングのようです。
ですので、一度色信号を送っただけでは光りません。

注意点

規格上は1本の信号線で1024個のLEDをコントロールできますが、このライブラリはArduinoのSRAMに色情報保存用の配列を展開しているので、
メモリ不足で1024個まではコントロールできません。 Arduino Unoで多くても200個ほどが限界の目安です。

Last modified 2 years ago Last modified on Aug 19, 2015 6:05:14 PM

Attachments (10)

Download all attachments as: .zip