気になる話題

leafletの地図を画像で保存する(その後Excelに張り付けて出力)

投稿日:

Webシステム上に地図を表示して、処理を行うためのJavasctriptライブラリとして「Leaflet」というものがあります。

今までこのライブラリを使用して色々な処理を実装してきましたが、今回言われたのが

「表示している地図をエクセルの様式に出力する」というものでした。

簡単に言うとエクセルのテンプレート上の決まった位置に表示されている地図の画像(マーカーなども含む)を

張り付けるということです。

目次

地図を画像にする

まず最初に地図を画像にします。

この処理には「Leaflet-image」というJavascriptライブラリを使用しました。

これを使用するには

<script src=’https://api.tiles.mapbox.com/mapbox.js/v2.4.0/mapbox.js’></script>
 <script src=’https://api.tiles.mapbox.com/mapbox.js/plugins/leaflet-image/v0.0.4/leaflet-image.js’></script>
 
を指定する必要があります。
 
上記の指定後に以下を
<script type=”text/javascript”>
//ボタンクリック等で処理実行
functhon 処理(){
        //地図に表示されている情報をイメージに変換
        leafletImage(map, doImage);
 
        var img = document.createElement(‘img’);
         function doImage(err, canvas) {
            var dimensions = map.getSize();
            img.width = dimensions.x;
            img.height = dimensions.y;
            img.src = canvas.toDataURL();
            imgtxt = img.src;
           
           //作成したbase64のイメージをサーバにPOST
           $.ajax({
                url : ‘http://imgsave.php’,
                type: ‘POST’,
                data: { “mapimg” : imgtxt }
            });      
         }
}
</script>
※Leaflet で地図を表示する部分は割愛しています。
 
 
 
 

受け取り側(PHP)でサーバに保存する

AjaxでPOSTされたデータを受け取る(ここではPHPを使用している)

        $mapimg = $_POST[“mapimg”];
        //画像はpng形式になるらしい
  //base64の頭にデコードに必要がない文字(というかこれがあったらデコードできない)を削除
        $str_rep = ‘data:image/png;base64,’;
        $filedata = base64_decode(str_replace($str_rep, ”, $mapimg));
 
        //サーバに保存
        $fileName = ‘tmp/mapimg.png’;
        file_put_contents($fileName, $filedata);
 
  これで指定したディレクトリにpng画像が保存されるので、あとは保存された画像を普通に使用することができる。
 

まとめ

Excelに出力する処理については「phpspreadsheet」などを使用します。

サーバに保存されている画像を出力する方法については、「phpspreadsheet」などを使用する場合は特に問題ないと思われるのでここでは記載しません。

今回は、「Leaflet.js」で表示した地図を画像でサーバに保存する方法でした。

leafletを使用すれWeb上に地図を簡単に表示できますが、表示した地図を画像として保存するのは意外と面倒でした。

 

 

-気になる話題

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

若八幡宮(やくはちまんぐう)で厄払いをしてきた!混雑状況も

1月3日に朝に福岡の厄払いで有名な若八幡宮(やくはちまんぐう)で厄払いをしてきました。 ここ2、3年は、混雑するであろう3が日は避けて平日やちょっと後に行っていたんですが、今回は、暇だったということも …

no image

ソフトバンク新プラン「LINEMO」au「povo」は2480円!申し込み方法は?「ahamo」はどうなる?

ソフトバンクの新プランについてですが、名称が「SoftBank on LINE」から「LINEMO」に変更になることが発表されました。 料金もau「povo」に対抗して2480円に変更になるそうです。 …

no image

Excelを使用して透過PNG画像を作る方法

通常、透過PNG画像を作成する場合には、有料無料を問わずペイントソフト等を使用すると思います。 ただし、1から複雑な画像を作るのではなく、単に透過させたいだけであればExcelで簡単にできます。 透過 …

no image

大坂なおみ全米オープン2020の決勝は何時から?放送予定は?

大坂なおみ選手が全米オープンテニス2020で2年ぶりに決勝進出ということで盛り上がっていますね! 全米オープンでは2年ぶり、グランドスラムとしては3度目の決勝進出で、勝てば3度目の四大大会制覇になりま …

no image

5Gギガホプレミア開始日に5Gギガライトから変更したら翌月からになった

3月までスマホで5GギガライトとD3WiFi(100G)というモバイルWiFiを使っていたんですが、最近は在宅ワークが多く外でPCを使う機会も減りました。 そんな中、ドコモから5Gギガホプレミアという …