Top
ch552 - 2023年8月16日更新

Arduino(ch55xduino)を使って開発しています。
ここでは作成したコードを公開しています。
※最新情報や一部のソースはX(twitter) @inunyannで公開しています。ソースは画像になっていますが…
Amazonのほしいものリスト🎁お願いします!!

製作例:振動で光る肉球キーホルダー
NeoPixelライブラリ


●製作例:振動で光る肉球キーホルダー

// clock: 12MHz for 3v3
#include "WS2812.h"
#include "neopixel.h"
#include "sleep.h"
#include "flash.h"

#define PIN_LED      34 // 30 for WeAct
#define PIN_NEOPIXEL 35
#define PIN_NP_GND   33
#define PIN_VIB_SENS 14

// neopixel
#define NUM_LEDS  3
#define NP_SPEED 12
__xdata uint8_t  ledData[3 * NUM_LEDS];
__xdata uint16_t hue = 1 << NP_SPEED - 1;
#define enableNp()  do { digitalWrite(PIN_NP_GND, LOW);    digitalWrite(PIN_NEOPIXEL, LOW); } while (0)
#define disableNp() do { digitalWrite(PIN_NEOPIXEL, HIGH); digitalWrite(PIN_NP_GND, HIGH);  } while (0)
#define neopixel_show_B(led_data, num_led) do { uint16_t nowDiv = getDivNow(); clockDefault(); neopixel_show_P3_5((led_data), (num_led)); clockByDiv(nowDiv); } while (0)

// sleep
#define SLEEP_SEC 3
__xdata uint16_t lastSec = 0;

void setup() {
  clock187K();
  digitalWrite(PIN_LED, HIGH);
  pinMode(PIN_LED, OUTPUT);
  disableNp();
  pinMode(PIN_NP_GND, OUTPUT);
  pinMode(PIN_NEOPIXEL, OUTPUT);
  neopixel_begin(NUM_LEDS, ledData);
  neopixel_setBrightness(0x1f); // 3.3ma/pixel

  digitalWrite(PIN_VIB_SENS, HIGH);
  pinMode(PIN_VIB_SENS, INPUT_PULLUP);
  if (initEEPROM()) hue = (uint16_t)EEPROMbyteRead(0) << 8 | EEPROMbyteRead(1);
  else { digitalWrite(PIN_LED, HIGH); delayB(3000); EEPROMbyteWrite(0, hue >> 8); EEPROMbyteWriteC(1, hue); }
}

inline void delayBwRead(uint16_t ms) {
  do {
    if (!digitalRead(PIN_VIB_SENS)) lastSec = secs();
    if (!(ms & 0xfff0)) break; else ms -= 16;
    delayB(2);
  } while (true);
  delayB((uint8_t)ms & 0x0f);
}

void loop() {
  neopixel_fill(neoPixel_gamma32(neopixel_ColorHSV_fast(hue += (uint16_t)1 << NP_SPEED, 0x9f)));
  enableNp();
  neopixel_show_B(ledData, 3 * NUM_LEDS);
  delayBwRead(10);
  disableNp();
  delayBwRead(10);
  enableNp();
  neopixel_show_B(ledData, 3 * NUM_LEDS);
  delayBwRead(10);
  disableNp();
  digitalWrite(PIN_LED, LOW);
  delayBwRead(10);
  digitalWrite(PIN_LED, HIGH);
  delayBwRead(10);
  digitalWrite(PIN_LED, LOW);
  delayBwRead(10);
  digitalWrite(PIN_LED, HIGH);
  delayBwRead(360);
  if (secs() - lastSec >= SLEEP_SEC) {
    disableNp();
    pinMode(PIN_NEOPIXEL, INPUT_PULLUP);
    pinMode(PIN_NP_GND, INPUT_PULLUP);
    digitalWrite(PIN_LED, HIGH);
    pinMode(PIN_LED, INPUT_PULLUP);
    EEPROMbyteWrite(0, hue >> 8);
    EEPROMbyteWriteC(1, hue);
    enterSleep(bWAK_P1_4_LO | bWAK_RST_HI);
    reset();
  }
}

●NeoPixelライブラリ(Adafruit_NeoPixelの一部のみporting+アレンジしたものです)

#include "WS2812.h"

#define ENABLE_Original_ColorHSV_Func 0

void     neopixel_begin(uint8_t numLed, __xdata uint8_t *ledData);
void     neopixel_begin_wpin(uint8_t numLed, __xdata uint8_t *ledData, uint8_t pin);
//void   neopixel_clear();
void     neopixel_setBrightness(uint8_t brightness);
//uint8_t neopixel_gamma8(uint8_t x);
__data uint32_t neoPixel_gamma32(__data uint32_t c);
//uint32_t neopixel_color(uint8_t r, uint8_t g, uint8_t b);
//void   neoPixel_setPixelColor(uint8_t n, uint8_t r, uint8_t g, uint8_t b);
void     neoPixel_setPixelColor32(__data uint8_t n, __data uint32_t c);
//uint32_t neoPixel_getPixelColor(uint8_t n);
void     neopixel_fill(__data uint32_t c);
#if ENABLE_Original_ColorHSV_Func == 1
uint32_t neopixel_ColorHSV(uint16_t hue, uint8_t sat, uint8_t val);
#endif
__data uint32_t neopixel_ColorHSV_fast(__data uint16_t hue, __data uint8_t sat);
//void   neopixel_rainbow(uint16_t first_hue);
void     neopixel_rainbow_wsat(uint16_t first_hue, __data uint8_t saturation);

__xdata uint8_t np_numLed = 0;
__xdata uint8_t *np_ledData;
__data  uint8_t np_brightness = 0x3f;

__code const uint8_t _NeoPixelGammaTable[256] = {
  0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   1,   1,   1,   1,   1,   1,   1,   1,   1,   1,
  1,   1,   2,   2,   2,   2,   2,   2,   2,   2,   3,   3,   3,   3,   3,   3,   4,   4,   4,   4,   5,   5,   5,   5,   5,   6,   6,   6,   6,   7,   7,   7,   8,   8,
  8,   9,   9,   9,   10,  10,  10,  11,  11,  11,  12,  12,  13,  13,  13,  14,  14,  15,  15,  16,  16,  17,  17,  18,  18,  19,  19,  20,  20,  21,  21,  22,  22,  23,
  24,  24,  25,  25,  26,  27,  27,  28,  29,  29,  30,  31,  31,  32,  33,  34,  34,  35,  36,  37,  38,  38,  39,  40,  41,  42,  42,  43,  44,  45,  46,  47,  48,  49,
  50,  51,  52,  53,  54,  55,  56,  57,  58,  59,  60,  61,  62,  63,  64,  65,  66,  68,  69,  70,  71,  72,  73,  75,  76,  77,  78,  80,  81,  82,  84,  85,  86,  88,
  89,  90,  92,  93,  94,  96,  97,  99,  100, 102, 103, 105, 106, 108, 109, 111, 112, 114, 115, 117, 119, 120, 122, 124, 125, 127, 129, 130, 132, 134, 136, 137, 139, 141,
  143, 145, 146, 148, 150, 152, 154, 156, 158, 160, 162, 164, 166, 168, 170, 172, 174, 176, 178, 180, 182, 184, 186, 188, 191, 193, 195, 197, 199, 202, 204, 206, 209, 211,
  213, 215, 218, 220, 223, 225, 227, 230, 232, 235, 237, 240, 242, 245, 247, 250, 252, 255 };

#define neopixel_clear() memset(np_ledData, 0, 3 * np_numLed)
void neopixel_begin(uint8_t numLed, __xdata uint8_t *ledData) {
  np_numLed = numLed;
  np_ledData = ledData;
  neopixel_clear();
}
void neopixel_begin_wpin(uint8_t numLed, __xdata uint8_t *ledData, uint8_t pin) {
  digitalWrite(pin, LOW);
  pinMode(pin, OUTPUT);
  neopixel_begin(numLed, ledData);
}

void neopixel_setBrightness(uint8_t brightness) {
  if (np_brightness != brightness) {
    uint16_t scale = ((uint16_t)brightness << 8) / np_brightness;
    for (uint8_t i = 0; i < 3 * np_numLed; i++) np_ledData[i] = scale * np_ledData[i] >> 8;
  }
  np_brightness = brightness;
}
#define neopixel_gamma8(x) _NeoPixelGammaTable[(__data uint8_t)(x)]
inline __data uint32_t neoPixel_gamma32(__data uint32_t c) {
  __data uint8_t *y = (__data uint8_t *)&c;
  for (__data uint8_t i = 0; i < 3; i++) y[i] = neopixel_gamma8(y[i]);
  return c;
}
#define neopixel_color(r, g, b) (((__data uint32_t)((__data uint8_t)(r)) << 16) | ((__data uint16_t)((__data uint8_t)(g)) << 8) | (__data uint8_t)(b))
#define neoPixel_setPixelColor(n, r, g, b) set_pixel_for_GRB_LED(np_ledData, n, (__data uint16_t)((__data uint8_t)(r)) * np_brightness >> 8, \
                                                                                (__data uint16_t)((__data uint8_t)(g)) * np_brightness >> 8, \
                                                                                (__data uint16_t)((__data uint8_t)(b)) * np_brightness >> 8)
inline void neoPixel_setPixelColor32(__data uint8_t n, __data uint32_t c) {
  __data uint8_t *y = (__data uint8_t *)&c;
  neoPixel_setPixelColor(n, y[2], y[1], y[0]);
}
#define neoPixel_getPixelColor(n) ((__data uint32_t)((__data uint16_t)np_ledData[3 * (n) + 1] << 8) / np_brightness << 16 | \
                                                    ((__data uint16_t)np_ledData[3 * (n)    ] << 8) / np_brightness << 8  | \
                                                    ((__data uint16_t)np_ledData[3 * (n) + 2] << 8) / np_brightness)
inline void neopixel_fill(__data uint32_t c) { for (__data uint8_t i = 0; i < np_numLed; i++) neoPixel_setPixelColor32(i, c); }

#if ENABLE_Original_ColorHSV_Func == 1
uint32_t neopixel_ColorHSV(uint16_t hue, uint8_t sat, uint8_t val) {
  uint8_t r, g, b;
  hue = ((uint32_t)hue * 1530L + 32768) / 65536;
  if (hue < 510) {
    b = 0;
    if (hue < 255) { r = 255; g = hue; }
    else { r = 510 - hue; g = 255; }
  } else if (hue < 1020) {
    r = 0;
    if (hue < 765) { g = 255; b = hue - 510; }
    else { g = 1020 - hue; b = 255; }
  } else if (hue < 1530) {
    g = 0;
    if (hue < 1275) { r = hue - 1020; b = 255; }
    else { r = 255; b = 1530 - hue; }
  } else { r = 255; g = b = 0; }
  uint16_t v1 = (uint16_t)val + 1;
  uint16_t s1 = (uint16_t)sat + 1;
  uint8_t s2 = 255 - sat;
  return ((uint32_t)(((uint16_t)r * s1 >> 8) + s2) * v1 & 0xff00) << 8 |
          (uint32_t)(((uint16_t)g * s1 >> 8) + s2) * v1 & 0xff00 |
         ((uint32_t)(((uint16_t)b * s1 >> 8) + s2) * v1 & 0xff00) >> 8;
}
#endif
__data uint32_t neopixel_ColorHSV_fast(__data uint16_t hue, __data uint8_t sat) {
  __data uint8_t r, g, b, hue2 = hue + 128 >> 8;
  if (hue2 < 85) {
    b = 0;
    if (hue2 < 43) { r = 255; g = hue2 * 6; }
    else { r = 255 - (hue2 - 42) * 6; g = 255; }
  } else if (hue2 < 170) {
    r = 0;
    if (hue2 < 128) { g = 255; b = (hue2 - 85) * 6; }
    else { g = 255 - (hue2 - 127) * 6; b = 255; }
  } else if (hue2 < 255) {
    g = 0;
    if (hue2 < 213) { r = (hue2 - 170) * 6; b = 255; }
    else { r = 255; b = 255 - (hue2 - 212) * 6; }
  } else { r = 255; g = b = 0; }
  if (sat == 255) return (__data uint32_t)r << 16 | (__data uint16_t)g << 8 | b;
  __data uint16_t s1 = (__data uint16_t)sat + 1;
  __data uint8_t s2 = 255 - sat;
  return (__data uint32_t)(((__data uint16_t)r * s1 >> 8) + s2) << 16 |
                           ((__data uint16_t)g * s1 >> 8) + s2  << 8  |
                           ((__data uint16_t)b * s1 >> 8) + s2;
}
inline void neopixel_rainbow_wsat(uint16_t first_hue, __data uint8_t saturation) {
  for (__data uint8_t i = 0; i < np_numLed; i++) neoPixel_setPixelColor32(i, neoPixel_gamma32(neopixel_ColorHSV_fast(((__data uint32_t)i << 16) / np_numLed + first_hue, saturation)));
}
#define neopixel_rainbow(first_hue) neopixel_rainbow_wsat((first_hue), 255)


ibunyan.com