画像ファイルをdisplayする方法を教えて下さい



  • obniz.display.xxで画像を表示する方法を教えて下さい。


  • administrators

    @Google-Homer ここのサンプルが似たようなことを行っております。

    https://obniz.io/explore/24

    具体的にはobnizのディスプレイサイズと同じく128*64のcanvasというのをHTMLの中に用意していただき、

    <canvas id="canvas" width=128 height=64 style="-webkit-font-smoothing:none"></canvas>
    

    そこに画像を描画します。
    canvasへの画像の描画方法はこちらが参考になります。
    http://www.html5.jp/canvas/ref/method/drawImage.html

    またはこちら

    https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/drawImage

    そして、そのcanvasのデータをobniz.display.drawに入れることで描画が可能です。

    let ctx = $("#canvas")[0].getContext('2d');
    obniz.display.draw(ctx)
    

    canvasは画像だけじゃなく、直線や円なども描画できますし。3Dなども出せます。

    https://obniz.io/explore/18

    こちらは3Dの例です。



  • 上記参考に下記のように書いたのですが、obnizの画面で「OK」が表示された後に真っ黒になります。HTML画面にはcanvasOutputにイメージ画像が表示されています。どこがまずいでしょうか?

    <html>
    <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <script src="https://obniz.io/js/jquery-3.2.1.min.js"></script>
    <script src="https://unpkg.com/obniz@1.15.2/obniz.js" crossorigin="anonymous"></script>
    </head>

    <body>
    <div id="obniz-debug"></div>
    <div>
    <td>
    <canvas id="canvasOutput" width=128 height=64 style="-webkit-font-smoothing:none"></canvas>
    </td>
    </div>
    <script>
    var obniz = new Obniz("XXX-XXXX");

    obniz.onconnect = async function () {
    obniz.resetOnDisconnect(false);
    var canvasOutput = document.getElementById('canvasOutput');
    var canvasContext = canvasOutput.getContext('2d');

    var img = new Image();
    img.src = "https://docs.google.com/uc?id=1-9PdB7e285Uk3ek4DQ4P1mk5U5urcoJF";
    img.onload = function() {
    canvasContext.drawImage(img, 0, 0);
    }

    var ctx = $("#canvasOutput")[0].getContext('2d');
    obniz.display.clear();obniz.display.print('OK');
    obniz.display.draw(ctx)
    }

    </script>
    </body>
    </html>


  • administrators

    @Google-Homer そのコードですと、画像のロードが終わる前に画像が書かれていないcanvasをobnizに送ろうとしています。画像のロードが終わってcanvasContext.drawImage()を行ったあとにobnizに対して送る必要があります。

    img.onload = function() {
    canvasContext.drawImage(img, 0, 0);
    var ctx = $("#canvasOutput")[0].getContext('2d');
    obniz.display.clear();obniz.display.print('OK');
    obniz.display.draw(ctx)
    }
    }
    

    また、いざ描画しようとしたところでエラーになるかと思いますが、
    これはブラウザのセキュリティ的な理由で、「違うドメインの画像は描画はできても値の取得ができない」からです。
    回避するにはobnizのリポジトリ内に画像を保存するか(そうすれば同じドメインになります)または、画像をbase64という生データにしてプログラムの中に入れてしまう方法です。

    後者の場合は
    https://www.base64-image.de
    などのサイトで画像をbase64に変換して、urlの代わりに利用します

    img.src = "";
    

    これでディスプレイ上に画像が出るかと思います。

    ただ、obnizのディスプレイは濃淡のないモノクロディスプレイなので、しきい値(どの明るさで白にするか)を設定しないとうまく画像が表示されません。

    https://tech-blog.s-yoshiki.com/2018/09/448/
    を参考にcanvasの段階で2値化するとうまく描画できると思います。



  • 無事表示できました。imgはzリポジトリにアップロードしました。
    ありがとうございました。

    0_1548398987705_WIN_20190125_15_48_09_Pro.jpg


  • administrators

    @Google-Homer よかったです!


 

Recent Projects

  • @nak435 かしこまりました。よろしくお願いします。

    read more
  • @Yuki-Sato さん、

    外部の3.3vを使うとはいえ普通にvccやgndを供給して問題なくうごくのであれば、弊社での動作確認後Flick Hatのライブラリとして公開できればと思っているのですがいかがでしょう。

    今週末に確認しますので、お待ちください。

    read more
  • @nak435 時間がかかってすいません、

    なんとか3.3vをgndにつないでFlick Largeを動かしたかったのですが、うまく動かすことができなかったです。
    3.3vをgndを繋がずに接続するというのはライブラリで推奨して伝えることは難しいと思ってます。

    Flick LargeでなくFlick Hatの方で、外部の3.3vを使うとはいえ普通にvccやgndを供給して問題なくうごくのであれば、弊社での動作確認後Flick Hatのライブラリとして公開できればと思っているのですがいかがでしょう。

    よろしくお願い致します。

    read more
  • @nak435 ありがとうございます。
    接続は3.3vのgnd以外同じでした。
    エラーはそのせいかもしれませんが、しかし電気的にはgndを繋がない場合3.3vとしてうまく供給できないはずなのでそこが不思議です。

    教えていただいたプログラムの部分を修正して試してみたいと思います。
    また少し時間がかかりそうなのですが、早めに試したいと思います。

    引き続きよろしくお願い致します。

    read more