WordPressでGoogle Maps i アプリを使う

Pocket

WordPressでGoogle Mapsを使いたいときありますよね

Google Mapsのマイマップを使えば地図に線が引けます
その機能を使って道路計画や廃線跡などの線を引いてます
線を引いた成果をブログに載せたいのです
ただし、携帯では見えませんよね
なるべく携帯でも成果が見れるように頑張りたいと思います
ドコモのiアプリではkmlの指定をすれば線が引けます!

Google Mapsのiアプリではkmlを指定できるみたい

記述はコレ

<br />
&amp;lt;object declare id=&quot;GMM-Doja&quot; data=&quot;http://www.google.co.jp/gmm?noss=1&quot;&amp;gt;<br />
&amp;lt;param name=&quot;mime-type&quot; value=&quot;vnd.google.gmm&quot; /&amp;gt;<br />
&amp;lt;param name=&quot;url0&quot;  value=&quot;http://www.google.co.jp/gmm/x?action=BUSI&amp;amp;q=[kmlファイル]&quot; /&amp;gt;<br />
&amp;lt;/object&amp;gt;<br />
&amp;lt;a ista=&quot;#GMM-Doja&quot; href=&quot;http://m.google.co.jp/maps&quot;&amp;gt;アプリ起動&amp;lt;/a&amp;gt;<br />

PCにGoogle Mapsを表示するためのプラグインとしてGoogle Maps Anywhereを使ってます
このプラグインは携帯で地図の記述がある投稿を見るとstaticmapsへのリンクが出る

最終目標として、携帯で見た時にアプリ起動タグも表示されるようにしたいわけです

アプリ起動タグを表示させるために
二つのプラグインを修正しました
一つ目はGoogle Maps Anywhereプラグインです
google-maps-anywhere.phpの携帯判定のコードにドコモの場合さらにアプリ起動タグも表示するようにします
PDC端末でもアプリ起動タグが表示されてしまいます
しかし、携帯でブログ見ようとする人がPDCということは少ないですよね

<br />
	$ret_val .= '&amp;lt;div align=&quot;center&quot;&amp;gt;';<br />
	if ( function_exists('ks_is_image_inline') &amp;amp;&amp;amp; ks_is_image_inline() ) {<br />
		$ret_val .= &quot;&amp;lt;img src=&quot;{$img_src}&quot; alt=&quot;{$content}&quot; title=&quot;{$content}&quot; /&amp;gt;&quot;;<br />
	} else {<br />
		$ret_val .= &quot;[&amp;lt;a href=&quot;$img_src&quot; title=&quot;{$content}&quot;&amp;gt;&quot;;<br />
		$ret_val .= __('Map of this location', $this-&amp;gt;textdomain_name).' : '.$content;<br />
		$ret_val .= &quot;&amp;lt;/a&amp;gt;]&quot;;<br />
	}<br />
	// 追加開始<br />
	if ( $this-&amp;gt;isKtai() == &quot;DoCoMo&quot;) {<br />
		$ret_val .= '&amp;lt;object declare id=&quot;GMM-Doja&quot; data=&quot;http://www.google.co.jp/gmm?noss=1&quot; Type=&quot;application/x-jam&quot;&amp;gt;';<br />
		$ret_val .= '&amp;lt;param name=&quot;mime-type&quot; value=&quot;application/vnd.google.gmm&quot; /&amp;gt;';<br />
		$ret_val .= '&amp;lt;param name=&quot;url0&quot; value=&quot;http://www.google.co.jp/gmm/x?action=BUSI&amp;amp;q=' . $kml . '&quot; /&amp;gt;';<br />
		$ret_val .= '&amp;lt;/object&amp;gt;';<br />
		$ret_val .= '[&amp;lt;a ista=&quot;#GMM-Doja&quot; href=&quot;http://m.google.co.jp/maps&quot;&amp;gt;アプリで見る&amp;lt;/a&amp;gt;]';<br />
	}<br />
	// 追加終了<br />
	$ret_val .= &quot;&amp;lt;/div&amp;gt;n&quot;;<br />

続いてKtai Styleです
ktai style2.1 betaを使ってます
アプリ起動タグが吐き出されるようになりました

Ktai Styleのパケ代圧縮のため、余計なタグを削除する機能があります

通常はアプリ起動タグを記述する必要がないためistaが削除され、href部分しか残りません

<br />
&amp;lt;A href=&quot;http://m.google.co.jp/maps&quot;&amp;gt;アプリで見る&amp;lt;/a&amp;gt;<br />

ista が削除されないように、ktai_style.phpに以下の記述を追加します

<br />
private function set_allowedtags() {<br />
	global $allowedposttags, $allowedtags;<br />
	if ($allowedposttags) {<br />
		$allowedposttags['a']['accesskey'] = array();<br />
		$allowedposttags['a']['ktai'] = array();<br />
		$allowedposttags['a']['ifb'] = array();<br />
		$allowedposttags['a']['lcs'] = array();<br />
		$allowedposttags['a']['utn'] = array();<br />
		$allowedposttags['a']['z'] = array();<br />
		$allowedposttags['a']['ista'] = array();  // 追加<br />
		$allowedposttags['bgsound']['loop'] = array();<br />

ktai style2.0 なら以下のようにkses.phpに追加すれば良いのかな?

<br />
class Ktai_HTML_Filter {<br />
	static public $allowedtags = array(<br />
	'address' =&amp;gt; array(),<br />
	'a' =&amp;gt; array(<br />
		'class' =&amp;gt; array(), 'href' =&amp;gt; array('type' =&amp;gt; 'uri'),<br />
		'id' =&amp;gt; array(), 'ifb' =&amp;gt; array(), 'lcs' =&amp;gt; array(),<br />
		'name' =&amp;gt; array(), 'utn' =&amp;gt; array(), 'z' =&amp;gt; array(), 'ista' =&amp;gt; array(),<br />
	),<br />

コメントを残す