スキップしてメイン コンテンツに移動

BLE Nanoを使ったマインクラフトの松明リモート制御

ニャンパスでは普段、ウェブサービスやスマートフォンアプリ開発をやりつつ、コワーキングスペースHaLakeを越谷市レイクタウンにて運営していることから、IoT勉強会開催や、小学生へプログラミングを教えたりしてます。
プログラミング教室では、最近マインクラフトをつかってComputerCraftというModを導入し、遊んでもらってるんですが、何かマインクラフトでもIoT的なことをやりたいというところから、Amazonで売っていたマイクラの松明を改造してみましたのでその共有です。
改造に利用したのはこちらの松明。


この松明を改造している様子は、下記の様な感じで、写真に写っているニャンパス社員の河野くんがこの辺ガッツリ対応いただきました。






意外と一番苦労したのは松明を空けるところで、松明の中身がどのように組んであるかが分からず当たりをつけてカッターで切ってみるという方法を取りました。
開けてみての構造は、写真を見ていただくと分かりますが、LEDのある頭部は金属のフレームで囲まれていますので、側面の接着剤のある部分を繰り返して切れ目を入れていけくことで空けることが出来ました。側面同士をつないでいるツメも切ることになり、この辺はどれくらい真似される方がいるか分かりませんが自己責任でお願いします。

BLE Nano自体のプログラムはmbedを使うと、そのサンプルとして
SampleControls works with the BLEController iOS/Android Appというプロジェクトの雛形から始めると参考になります。
このプロジェクトではすでに、BLEの読み書きそれぞれのプロファイルが用意されていますので、この挙動を今回の場合は、以下のように変更しました。

  • 電源が入ったかどうか分かるよう、起動時に0.5秒、松明を点滅させる

    起動時以下のコードで点灯させています。
    PWM = 1.0;
    wait_ms(500);
    PWM = 0.0;

  • BLEとしてPWMの値を受け取り、以下のコードで松明のLEDを制御

    サンプルコード自体がPWMのデータ受信を行っていますので、GPIOのピンを調整するくらいですみます。ここを松明のLEDと繋ぎ明るさを調整できるようになります。
あとは如何ようにでも松明を制御できますので、サンプルとして作ったNode.jsのコードでは、1秒おきに明るさを変更しています。

var noble = require('noble')

var serviceUuid = '713d0000503e4c75ba943148f18d941e';
var txCharacteristicUuid = '713d0003503e4c75ba943148f18d941e';

noble.on('stateChange', function(state) {
  if (state === 'poweredOn') {
    console.log('scanning...');
    noble.startScanning([serviceUuid], false);
  }
  else {
    noble.stopScanning();
  }
})

var service = null;
var txCharacteristic = null;

noble.on('discover', function(peripheral) {
  noble.stopScanning();

  console.log('found peripheral:', peripheral.advertisement);
  peripheral.connect(function(err) {
    peripheral.discoverServices([serviceUuid], function(err, services) {
      services.forEach(function(service) {
        console.log('found service:', service.uuid);

        service.discoverCharacteristics([], function(err, characteristics) {
          characteristics.forEach(function(characteristic) {
            console.log('found characteristic:', characteristic.uuid);

            if (txCharacteristicUuid == characteristic.uuid) {
              txCharacteristic = characteristic;
            }
          })

          if (txCharacteristic) {
     setInterval(sendMessage, 1000);
          }
          else {
            console.log('missing characteristics');
          }
        })
      })
    })
  })
})

function sendMessage() {
    var data = new Buffer(2);
    data.writeUInt8(0x2, 0);
    data.writeUInt8(Math.ceil((new Date().getSeconds() % 2) * 255), 1);
    txCharacteristic.write(data, true, function(err) {
console.log("err: " + err);
    })
}

Modを作ると、実際のマインクラフトと連動するということもできますので、その方法はまた別の機会に掲載できればと思います。

今回作成した松明はHaLakeにおいていますのでご興味ある方は見にいらしてください。

コワーキングスペースHaLake










コメント

このブログの人気の投稿

ESP8266で書き込めない時に対処したこと

ESP8266のチップで書き込めなかった問題が起こり、それについての対処を参考になる可方がいるかもということでブログにもメモとして残しておきます。 書き込みで失敗したケースとしては、 スイッチサイエンスさんのESP-WROOM-02ピッチ変換済みモジュール《シンプル版》 へのシリアル通信での書き込みができなかった問題 Over The Air(OTA)の機能を使うコードを、同じくESP-WROOM-02に対して転送するも、更新の途中でクラッシュし、書き込みが失敗するという問題 の二つです。 OTAまで使って書き込もうとしている背景は、ニャンパスとして Robip というプログラミング学習環境を作っていて、そのツールの中でWi-Fi経由での書き込み機能を対応することでスマートフォン、タブレットなどでのビジュアルプログラミングしたものが、OTA経由で電子工作のプログラミングができるようという機能があり、いくつかのESP8266を積んだモジュールへのサポートを増やそうとしたところ(ようはRobipとしての対応デバイスを広げたかった)上記の書き込みできない問題にぶつかりました。 Facebookのこちらに書いたことの詳細版です。 ESP-WROOM-02への書き込み出来ない問題 もともと、HaLake KitというコワーキングスペースHaLakeオリジナル基板は、ESP8266を積んでいますので、この書き込みツールとしてClojureで書いた robip-tool というのを用意していました。 このツールであればHaLake Kitには書き込めていたのですが、ESP-WROOM-02ピッチ変換済みモジュール《シンプル版》ですと最初の書き込みの段階で失敗することが分かりました。 そこで世界中で人気のESP8266ですので、色んなバージョンの書き込みツールがありまして、書き込みに成功するツールを探す旅が始まりました。 その際には、シンプル版だけでなく、HaLake Kit、ESPr Developer(ESP-WROOM-02開発ボード)、ESP-WROOM-02ピッチ変換済みモジュール《フル版》でも試して、全てで動くツールを検証しました。 途中、Go言語で書きなおしてみたりいろいろテストもしたのですが、結果的に全て

ClojureScriptとBLE

2017年Clojure Advent Calendar 15日目の記事として書きました。 今年、ニャンパスとして、またプライベートでいろいろとBLEを扱うコードをClojureScriptで書きましたので、まとめてみます。 使用したデバイスは、micro:bitです。秋葉原や通販等で手に入り、BLE、25個のLED、加速度センサーがついている学習用のボードです。ブラウザ上でビジュアルプログラミングでの開発ができたりと面白いので、年末年始に遊んでみてください。 ClojureScriptでの環境の作り方から始まって、micro:bitとPCとの接続、リモートでのLチカを試すというIoTなClojureScriptの内容となってます。 1. ClojureScriptで、BLEな環境を作る Node.js、npm、Leiningenを入れておいてください。プロジェクトを作ります。   $ lein new figwheel-node ble figwheel-nodeテンプレートを使い、できたファイルはこんな感じです。 ./project.clj ./README.md ./package.json ./.gitignore ./src ./src/ble ./src/ble/core.cljs ./dev ./dev/user.clj 今回、PC側をBLEのセントラルとして振る舞わせ、micro:bitをペリフェラルとして操作しますので、そのためセントラル側のプログラムとしてnobleというライブラリを使います。 OS毎に依存するものが違いますので、サイトで事前に確認しておいたほうが良いです。    https://github.com/sandeepmistry/noble ※nobleはMac、Linux、Windows、FreeBSDをサポートしており、 僕自身今年nobleを使ったコードをClojureScriptを使って、Windos、Mac、Linuxそれぞれで動かしていて動作は安定していました。 では、nobleを以下のコマンドを実行しておきます。   $ npm install noble ※普段はlein-npm等を使

ClojureでCompojureを使わずにサーブレットを書く方法

Clojureでgen-class、proxyを使ってみようと思い、試しにサーブレットを書くとどうなるかを試してみました。 コンパイルにLeiningenを使うためプロジェクトを作ります。 lein new sample-servlet まずはsrc/sample_servlet/servlet.cljを書いてみます。 (ns sample_servlet.servlet (:gen-class :extends javax.servlet.http.HttpServlet)) (defn -servlet [this request response] (.setContentType response "text/html; charset=UTF-8") (let [out (.getWriter response)] (.. out (println "<html><body>hello world</body></html>")))) (defn -doGet [this request response] (-servlet this request response)) 依存関係とクラスファイル生成のオプションを与えたproject.cljファイルを作りました。 (defproject sample-servlet "1.0.0-SNAPSHOT" :description "FIXME: write" :dependencies [[org.clojure/clojure "1.1.0"] [org.clojure/clojure-contrib "1.1.0"] [javax.servlet/servlet-api "2.5"] ] :namespaces [sample_servlet.servlet]) 必要なライブラリを取得しコンパイル。 lein deps lein compile 無事生成されたことが分かります。 % ls -lr