3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

特定されちゃう!?M5Stackで家の温度データをWEB公開する

Last updated at Posted at 2019-03-24

目的

記事(M5Stackに温度センサーDS18B20を繋げて気温(℃ および F)を取得する)の続きで取得した温度データを Ambient というIoTデータ可視化サービスに投げて、WEB公開してみました。その備忘録としてこちらに投稿しておきます。

準備

下記の道具を準備します。

手順

1. M5Stack へのプログラムの書き込み

M5Stack を USB-C ケーブルで PC と接続し、PC側でArduino IDE を起動し、下記コードをコピペして M5Stack にプログラムの書き込みをします。

#include <WiFi.h>
#include <M5Stack.h>
#include <OneWire.h>
#include <DallasTemperature.h>
#include "Ambient.h" 

#define ONE_WIRE_BUS 2 // DS18B20 on arduino pin2 corresponds to D4 on physical board
#define PERIOD 60

OneWire oneWire(ONE_WIRE_BUS);
DallasTemperature DS18B20(&oneWire);

Ambient ambient; // Define Ambient Object
unsigned int channelId = 10536; // Channel ID of Ambient
const char* writeKey = "0badcad8f0f1af5c"; // Write Key of Ambient

WiFiClient client;
const char* ssid = "********";
const char* password = "********";

void setup() {
  M5.begin();
  M5.Lcd.setTextColor(TFT_WHITE, TFT_BLACK);
  M5.Lcd.setTextSize(2);

  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) {
    delay(100);
    M5.Lcd.print(".");
  }
  M5.Lcd.print("\n");
  M5.Lcd.print(WiFi.localIP());
  
  ambient.begin(channelId, writeKey, &client);
}

void loop() {
  int t = millis();
  float celsius;
  float fahrenheit;

  DS18B20.begin();
  int count = DS18B20.getDS18Count();

  //M5.Lcd.clear();
  M5.Lcd.setCursor(0, 0);
  M5.Lcd.print("Devices found: ");
  M5.Lcd.println(count);

  if (count > 0) {

    DS18B20.requestTemperatures();

    celsius = DS18B20.getTempCByIndex(0);
    fahrenheit = celsius * 1.8 + 32.0;

    ambient.set(1, String(celsius).c_str());
    ambient.send();
      
    celsius = round(celsius);
    fahrenheit = round(fahrenheit);
      
    M5.Lcd.print("Device ");
    M5.Lcd.print(0);
    M5.Lcd.print(": ");
    M5.Lcd.print(celsius, 0);
    M5.Lcd.print( "C / ");
    M5.Lcd.print(fahrenheit, 0);
    M5.Lcd.println("F");
  }
  
  t = millis() - t;
  t = (t < PERIOD * 1000) ? (PERIOD * 1000 - t) : 1;
  delay(t);
}

2. Ambient でマイページの確認

Ambient にログインして、作成したチャネルにチャートを追加(下記画面の[+]ボタンを押します)します。

キャプチャb.PNG

下記のようにチャート設定をします。今回 data1 に温度データを投げているのでそちらを表示するグラフの設定です。

キャプチャ.PNG

正しくデータが投げられていれば、Myチャネルから下記のように時系列グラフが確認できます。

キャプチャc.PNG

チャネル設定画面にて 公開チャネル? というチェックボックスを☑します。

キャプチャa.PNG

公開された WEB ページは下記です(下記イメージ)
https://ambidata.io/ch/channel.html?id=10536

キャプチャe.PNG

参考

3
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?