サンプル・プログラムの実行例

目次
サンプル・プログラムのダウンロード
myWeather.php | サンプル・プログラム本体 |
pahooGeoCode.php | 住所・緯度・経度に関わるクラス pahooGeoCode。 使い方は「PHPで住所・ランドマークから最寄り駅を求める」「PHPで住所・ランドマークから緯度・経度を求める」などを参照。include_path が通ったディレクトリに配置すること。 |
pahooWeather.php | 気象情報に関わるクラス pahooWeather。 気象情報に関わるクラスの使い方は「PHPで天気予報を求める」を参照。include_path が通ったディレクトリに配置すること。 |
pahooCache.php | キャッシュ処理に関わるクラス pahooCache。 キャッシュ処理に関わるクラスの使い方は「PHPで天気予報を求める」を参照。include_path が通ったディレクトリに配置すること。 |
jmaweatherspots.xml | 予報地点情報ファイル。「PHPで天気予報を求める」参照。 |
jmaWeatherInit.php | 予報地点情報ファイル作成プログラム。「PHPで天気予報を求める」参照。 |
バージョン | 更新日 | 内容 |
---|---|---|
3.3 | 2021/04/10 | キャッシュ・システム導入:pahooCacheクラス |
3.2 | 2021/03/07 | 天気予報情報を気象庁防災情報XMLから取得に変更 |
3.1 | 2020/12/13 | PHP8対応 |
3.0 | 2020/07/25 | 気象庁週間天気予報に変更 |
3.01 | 2020/07/15 | リファラ・チェックなどを改良 |
バージョン | 更新日 | 内容 |
---|---|---|
6.1.0 | 2022/12/30 | ip2address()追加 |
6.0.4 | 2022/12/13 | PHP8.2対応 |
6.03 | 2022/05/29 | マップにプロットできる場所を999箇所に拡大 |
6.02 | 2022/03/19 | drawLeaflet()で移動時の緯度・経度を拾わないbug-fix |
6.01 | 2021/12/06 | bug-fix |
バージョン | 更新日 | 内容 |
---|---|---|
5.4 | 2023/02/11 | FILE_VERSION = 2.2 に更新 |
5.3 | 2022/03/10 | 気象庁防災情報XMLのhttps化に対応 |
5.2 | 2021/04/08 | pahoo_simplexml_loadをpahooCache::simplexml_loadへ |
5.1 | 2021/04/02 | キャッシュ・システム導入:pahooCacheクラス |
5.03 | 2021/03/24 | 当日~2日後の天気予報が違う都市になる不具合を修正 |
バージョン | 更新日 | 内容 |
---|---|---|
1.1.1 | 2023/02/11 | コメント追記 |
1.1 | 2021/04/08 | simplexml_load()メソッド追加 |
1.0 | 2021/04/02 | 初版 |
サンプル・プログラムの流れ

準備:pahooGeoCode クラス
  37: class pahooGeoCode {
  38: var $items; //検索結果格納用
  39: var $error; //エラー・フラグ
  40: var $errmsg; //エラー・メッセージ
  41: var $hits; //検索ヒット件数
  42: var $webapi; //直前に呼び出したWebAPI URL
  43:
  44: //Google Cloud Platform APIキー
  45: //https://cloud.google.com/maps-platform/
  46: //※Google Maps APIを利用しないのなら登録不要
  47: var $GOOGLE_API_KEY_1 = '**************************'; //HTTPリファラ用
  48: var $GOOGLE_API_KEY_2 = '**************************'; //IP制限用
  49:
  50: //Yahoo! JAPAN Webサービス アプリケーションID
  51: //https://e.developer.yahoo.co.jp/register
  52: //※Yahoo! JAPAN Webサービスを利用しないのなら登録不要
  53: var $YAHOO_APPLICATION_ID = '*****************************';
クラスについては「PHPでクラスを使ってテキストの読みやすさを調べる」を参照されたい。

地図や住所検索として Google を利用するのであれば、Google Cloud Platform APIキー が必要で、その入手方法は「Google Cloud Platform - WebAPIの登録方法」を、Yahoo!JAPAN を利用するのであれば、Yahoo! JAPAN Webサービス アプリケーションIDが必要で、その入手方法は「Yahoo!JAPAN デベロッパーネットワーク - WebAPIの登録方法」を、それぞれ参照されたい。
準備:地図サービスの選択
  52: //地図描画サービスの選択
  53: // 0:Google
  54: // 2:地理院地図・OSM
  55: define('MAPSERVICE', 2);
  56:
  57: //住所検索サービスの選択
  58: // 0:Google
  59: // 1:Yahoo!JAPAN
  60: // 11:HeartRails Geo API
  61: // 12:OSM Nominatim Search API
  62: define('GEOSERVICE', 1);
  63:
  64: //逆ジオコーディングサービスの選択
  65: // 0:Google
  66: // 1:Yahoo!JAPAN
  67: // 11:HeartRails Geo API
  68: // 21:簡易ジオコーディングサービス
  69: define('REVGEOSERVICE', 21);
住所検索サービスは、Google、Yahoo!JAPAN、HeartRails Geo API、OSM Nominatim Search API から選べる。あらかじめ、定数 GEOSERVICE に値を設定すること。
逆ジオコーディングサービスは、Google、Yahoo!JAPAN、HeartRails Geo API、簡易ジオコーディングサービスから選べる。あらかじめ、定数 REVGEOSERVICE に値を設定すること。


準備:キャッシュ・システム
  83: //キャッシュ保持時間(分) 0:キャッシュしない
  84: //気象庁へのアクセス負荷軽減のため,60分以上のキャッシュ保持をお勧めします.
  85: define('LIFE_CACHE', 120);
  86:
  87: //キャッシュ・ディレクトリ
  88: //書き込み可能で,外部からアクセスされないディレクトリを指定してください.
  89: //最大150Mバイトを消費します.天気予報系プログラムは同じディレクトリで構わない.
  90: define('DIR_CACHE', './pcache/');
キャッシュ保持時間、キャッシュ・ディレクトリともに、自サイトの環境に応じて変更してほしい。天気予報系プログラム(「PHPで天気予報を求める」「PHPで地図で指定した場所の天気予報を求める」「PHPで地図で指定した場所の週間カレンダーを表示」)は全て同じディレクトリを指定することで、気象庁サイトへのアクセス回数がさらに減少する。
解説:最も近い予報地点
 154: /**
 155: * 指定した緯度・経度に最も近い予報地点コードを求める.
 156: * 参考サイト https://www.pahoo.org/e-soul/webtech/php06/php06-52-01.shtm
 157: * @param object $pgc pahooGeoCodeオブジェクト
 158: * @param double $longitude 経度(世界測地系)
 159: * @param double $latitude 緯度(世界測地系)
 160: * @param int $forecast 0:天気予報,1:週間天気予報(省略時:1)
 161: * @return string 予報地点コード/NULL:合致する予報地点がない
 162: */
 163: function getJmaNearSpot($pgc, $longitude, $latitude, $forecast=1) {
 164: //電文コード
 165: $code = ($forecast == 0) ? 'VPFD51' : 'VPFW50';
 166:
 167: $res = NULL;
 168: $cnt = 0;
 169: $d0 = 999999999;
 170: //電文コードが一致する予報地点を選んで2地点間の距離を計算
 171: while (1) {
 172: if ($this->spots[$cnt]['code'] == $code
 173: && isset($this->spots[$cnt]['stationCode'])
 174: && isset($this->spots[$cnt]['longitude'])
 175: && isset($this->spots[$cnt]['latitude'])) {
 176: $d1 = $pgc->distance($this->spots[$cnt]['longitude'], $this->spots[$cnt]['latitude'], $longitude, $latitude);
 177: //距離がより小さければ採用
 178: if ($d1 < $d0) {
 179: $res = (string)$this->spots[$cnt]['stationCode'];
 180: $d0 = $d1;
 181: }
 182: $cnt++;
 183: } else {
 184: break;
 185: }
 186: }
 187: return $res;
 188: }
最も近い予報地点を取得するのがメソッド getJmaNearSpot である。
あらかじめ用意した予報地点情報 $spots とマップ・サービスから取得した緯度・経度の距離を計算し、それが最短になる予報地点を採用する。

なお、予報地点情報 $spots は、あらかじめXML形式ファイル "FILE_JMASPOTS" として用意しておく必要がある。
"FILE_JMASPOTS" は圧縮ファイルに同梱しているが、もし新規作成する場合は、「予報地点情報ファイル - PHPで天気予報を求める」をご覧いただきたい。
解説:表示とURLパラメータ
 412: //パラメータ
 413: $id = (int)getParam('id', FALSE, 0); //表示モード
 414: $query = (string)getParam('query', TRUE, ''); //地図検索キー
 415: $latitude = (float)getParam('latitude', FALSE, DEF_LATITUDE); //緯度
 416: $longitude = (float)getParam('longitude', FALSE, DEF_LONGITUDE); //経度
 417: $zoom = (int)getParam('zoom', FALSE, DEF_ZOOM); //ズーム
 418: $type = (string)getParam('type', FALSE, DEF_TYPE); //マップタイプ
 419: $category = (string)getParam('category', FALSE, DEF_CATEGORY); //カテゴリ
 420: $outenc = (string)getParam('charset', FALSE, INTERNAL_ENCODING);
myWeather.php?id=1&query=%E6%9C%AD%E5%B9%8C%E5%B8%82のようにすることで、query をキーワードにして検索した地点の天気予報のみを表示させることができる。つまり、このスクリプトをホームページやブログの一部として組み込むことで、週間天気予報を表示するパーツになる。
query はUTF-8をURLエンコードしたもの。Yahoo!JAPAN住所検索を使う場合は、category をあわせて指定すること。
また、出力はHTML文のみとなり、スタイルシートは本体ページの方で用意していただきたい。必要なclassは次の通り。
 120: <style>
 121: /* エラー表示 */
 122: p.werror {
 123: color: red;
 124: }
 125: /* 天気予報表 */
 126: table.weather {
 127: width: {$width}px;
 128: border:solid 1px #000000;
 129: border-collapse:collapse;
 130: margin-top:10px;
 131:
 132: }
 133: /* 天気予報表:月日表示部 */
 134: table.weather td.dt {
 135: width: {$width}px;
 136: border:solid 1px #000000;
 137: border-collapse: collapse;
 138: padding:4px;
 139: white-space:nowrap;
 140: text-align:center;
 141: }
 142: /* 天気予報表:予報表示部 */
 143: table.weather td.info {
 144: width: {$width}px;
 145: border:solid 1px #000000;
 146: border-collapse: collapse;
 147: padding:4px;
 148: white-space:nowrap;
 149: text-align:center;
 150: }
 151: /* 天気予報表:予報アイコン */
 152: img.wicon {
 153: width: 60px;
 154: }
 155: /* 天気予報表:小さい文字 */
 156: span.wsmall {
 157: font-size: small;
 158: }
 159: </style>
myWeather.php?id=1&query=%E6%9C%AD%E5%B9%8C%E5%B8%82&charset=SJISとすると、シフトJISで出力することができる。
myWeather.php?id=1&latitude=26.591&longitude=127.977のようにすることで、北緯26.591度、東経127.977度の天気予報のみを表示させることができる。
(2023年3月18日)予報地点情報ファイルを更新
(2023年2月11日)予報地点情報ファイルを更新。