Ktai Style マニュアル

サイト設定とテンプレートの改造

ここでは、携帯サイトの見た目を変更する方法を説明します。管理画面での設定による方法と、携帯表示用テンプレートの改造による方法があります。

管理画面の「携帯表示」設定

テーマ

使用するテーマを選択します。初期状態では以下の4つのテーマがあります。

携帯電話キャリアごとにテーマを変更できますが、通常は「共通テーマと同じ」のままで構いません。

動作

携帯サイトの見栄えを変更できます。

3G 端末, WILLCOM, スマートフォン等での画像表示
3G 端末、WILLCOM, スマートフォン等 (今ドキの端末) の場合、デフォルトではサーバー上の画像をインライン表示します。これを、PDC 端末同様、画像へのリンクに変換する処理に設定できます。デフォルト値が変化するだけで、ページ下部には「画像を表示する/リンクにする」のメニューが出るため、閲覧者が好みによって画像をインライン表示させることが可能です。最近ではパケット定額制を利用している閲覧者が多いため、このオプションを変更する必要はないでしょう。
コメントフォームや投稿内容での絵文字入力
コメントフォームや、携帯管理画面での投稿内容において、携帯電話絵文字を使えるようにします。「許す」を選択すると、絵文字を検出して <img localsrc="XXXX" /> のフォーマットに変換します。「認めない」を選択すると何も処理しませんので、データベースへの保存時に絵文字が失なわれます (SoftBank 絵文字はウェブコードのまま残ってしまいます)。
コメントとトラックバック
デフォルトでは、各記事および最新コメント一覧において、コメントとトラックバック・ピンバックを混在して表示しますが、二者を分離できます (トラックバックとピンバックは分離しません)。
なお、各記事についている「コメントn件」の件数については、コメントとトラックバックを合わせた数です (分離はできません)。
直接リンクを張るサイト
このフィールドに記入された URL へのリンクは、中継ページ経由のリンクにせず普通にリンク (直接リンク) します。携帯電話対応サイトの URL を記入すると便利です。この設定を使わずに、それぞれの a 要素に class="ktai" と記載しても、直接リンクするようになります。
コメント投稿者の端末識別情報
「送信が必須」を選ぶと、ドコモ、au、ソフトバンク、イー・モバイル音声端末からのコメント投稿時に、端末識別情報 (iモードID、EZ番号、ユーザーID 等) を送信しないと受け付けられなくなります。送信された端末 ID は、ユーザーエージェントの後に付与してデータベースに保存されます。WordPress の管理画面では通常見られませんが、phpMyAdmin 等で wp_comments テーブルの comment_agent カラムを見れば確認できます。 なお、ウィルコム端末、その他端末 (スマートフォン、PSP 等) では、「送信が必須」にしても端末 ID なしでコメント可能です。
*** 注意 ***「送信を必須」にしても、フルブラウザ・PC サイトビューアー等に切り換えれば回避できます。通常は「必須ではない」を選択することをおすすめします。

※バージョン 0.97 以降、外部サイトへのリンクは原則として残すことにしました。もし、外部サイトへのリンクを一律に削除したい場合は、使用している携帯テーマの functions.php に以下のコードを入れてください。

function ks_delete_external_links($link_html, $href, $label) {
	return $label;
}
add_filter('external_link/ktai_style.php', 'ks_delete_external_links', 90, 3);

文字色

要所要所の文字色を変更できます。設定値は #rrggbb の16進表記で記述します。HTML では一般的な書式です。値を入力すると、リアルタイムに色見本が変更され、色の確認がしやすくなっています。なお、Ktai Style の標準テーマ以外では設定が反映されない場合があります。

※背景色・通常の文字色・リンク色・訪問済みリンク色は、設定画面ではなく、テンプレートの改造 (templates/header.php の <body> 要素の属性を修正) で対応してください。

投稿・コメントの日付書式

投稿やコメントの日付書式を変更できます。WordPress 一般設定の日付書式は、原則として使っていません (記事タイトルの上に表示する日付は一般設定を適用)。

これは、「今年の日付は年を省略して表示する」「今日の日付は時刻のみ表示する」という短縮処理を行うためです。したがって、それぞれの状況に応じて書式を設定する必要があります。

フォーマットに使う文字列は WordPress の設定画面と同じ (PHP の date() 関数と同じ) です。

年月日を表示する場合 (去年以前の日付)
デフォルトでは Y-m-d という ISO フォーマットです。スラッシュ区切りや日本語表記に変更して構いません。なお、年・月・日を示す文字それぞれが含まれる必要があります。
OK な例: Y/m/d , Y年n月j日, M jS, Y
ダメな例: n/j, Y年n月
月日のみ表示の場合 (今年の日付)
デフォルトではスラッシュ区切リの n/j という書式です。年省略では ISO フォーマットは不自然なためです。月・日を示す文字列それぞれが含まれる必要があります。
時刻
時刻フォーマットはすべての場合で使われます。デフォルトは秒を省略した H:i です。

テンプレートの改造

本プラグインのテンプレートは、WordPress のテーマとほぼ同じ構造です。このため、WordPress のテーマを制作・改造したことがあれば、同じ要領で改造することができます。

独自のテーマを作るときは、既存テーマのフォルダーを複製して好きな名前を付け、その複製に対して作業することをおすすめします。default テーマを直接改造することは避けてください。独自テーマは、ktai_style/themes/ ディレクトリーに入れてもいいですが、wp-content/ktai-themes/ ディレクトリーを作成して、そこに格納することをおすすめします。

なお、プラグインのソースコードおよびテンプレートは原則として英数字のみで記述されています。改造時に日本語文字列を入れる場合は、「ウェブログの文字コードと同じコード」(たいてい UTF-8) で保存してください (Windows のテキストエディターの場合、英数字のみのファイルに日本語を追加すると Shift_JIS で保存することが多いため要注意!!)。

なお、WordPress の管理画面で編集しても構いません。ただし、emobile.php, ezweb.php, i-mode.php, softbank.php, willcom.php は Shift_JIS で書かれています。WordPress の管理画面で編集すると壊れますので、ご注意ください。

併用する他のプラグインは、携帯電話表示のとき動作しないものがあります。この場合、header.php で ks_wp_head() を有効にしたり、footer.php で ks_wp_footer() を有効にすると動作するようになる場合があります (デフォルトではこれらのテンプレートタグはコメントアウト)。

附属テンプレートファイル一覧

WordPress 標準テンプレート

style.css
テーマの名称、配布元、説明、バージョン、作者を記述するために使用しています。バージョン 1.00 から必須のテンプレートとなりました (存在しない場合携帯テーマとして認識されません)。今のところスタイルシートとしては使用していません。
header.php
ページヘッダの表示用。add_action('wp_head'); を利用しているプラグインの場合、このテンプレートの wp_head() 前後のコメントマークを削除すると動作するようになります。
footer.php
ページフッタの表示用。add_action('wp_footer'); を利用しているプラグインの場合、このテンプレートの wp_footer() 前後のコメントマークを削除すると動作するようになります。
index.php
フロントページ・検索ページなど表示用で、必須のテンプレートです (存在しない場合携帯テーマとして認識されません)。default テーマでは、1番目の記事だけ本文を表示し、2番目以後はタイトル表示というスタイル、compact, classic, redportal テーマではすべてタイトル表示です。
archive.php
アーカイブページ (年日付別/カテゴリー別/投稿者別など) 表示用。記事タイトルだけ表示します。このテンプレートがないときは index.php で代用します。
page.php
固定ページ表示用。このテンプレートがないときは index.php で代用します。
single.php
投稿の単独表示用。このテンプレートがないときは index.php で代用しますが、デフォルトの index.php ではコメント一覧やコメント投稿フォームが出ないため、実質的に必須のテンプレートです。
comments.php
コメント一覧/コメント投稿フォーム表示用。コメント閲覧・投稿を行うためには必須のテンプレートです。single.php から comments_template() タグで呼び出されます。
functions.php
テーマ用の独自関数定義ファイル。附属テーマでは classic テーマのみ存在しており、全角カタカナ→半角カナ変換を行うフィルターを定義しています。

以上は WordPress の仕様に従って呼び出されます。もし、category-10.php というテンプレートを追加すれば、カテゴリー ID = 10 のアーカイブにはこのテンプレートが利用されます。

本プラグイン独自テンプレート

以後は本プラグイン独自のテンプレートです。 ウェブログ直下の URL に「?menu=XXXX」というクエリー文字列を付けると呼び出されます。
例: http://blog.example.jp/?menu=months

menu_months.php
年月アーカイブの一覧表示用。?menu=months で呼び出し。
menu_cats.php
カテゴリー一覧表示用。?menu=cats で呼び出し。
menu_tags.php
タグ一覧表示用。?menu=tags で呼び出し。
menu_pages.php
ページ一覧表示用?menu=pages で呼び出し。defalt, compact テーマでは使用していません。
menu_links.php
ブックマーク (ブログロール) 一覧表示用。?menu=links で呼び出し。デフォルトではこのテンプレートは使用していません。footer.php などに、
<a href="<?php ks_blogurl(); ?>?menu=links">リンク</a>
のように記載すれば使用できます。
menu_comments.php
最近のコメント表示用。?menu=comments で呼び出し。デフォルトでは、コメントとトラックバック・ピンバックを混在して表示しますが、設定で分離表示が可能です。

上記の他、テーマディレクトリーの配下に、独自の menu_XXX.php ファイル (XXX は英小文字、数字とアンダースコア(_) のみ) を作れば、?menu=XXX というクエリーが有効になります。例えば、menu_popular.php というファイルを作って、人気記事をリストするようなテンプレートとしておけば、http://blog.example.jp/?menu=popular などの URL で人気記事を出すページが作れます。PC 向けテーマではサイドバーに入れているものを、携帯版では独立したページに切り出して提供するなどの構成が可能です。

絵文字の使い方

テンプレートや投稿本文で以下の XHTML タグを使えば絵文字を挿入できます。EZweb の絵文字と同じ仕様です。
<img localsrc="999" alt="代替文字" />
localsrc 属性に絵文字番号 (上記の場合 999)、alt 属性は絵文字の代替文字です (PC やスマートフォンなど絵文字非搭載の端末向け)。絵文字番号は以下のものが使えますが、EZweb 絵文字番号を使うことを推奨します。単なるアイコンなど代替文字が必要ない場合は、alt 属性を省略せずに、中身なしの alt 属性 (alt="") を入れてください (省略した場合は既定の代替文字が入ってしまいます)。

サービス説明
EZweb1〜82210進数で EZweb 絵文字番号にそのまま対応
SoftBankse001〜se53es を除いた部分は16進数4ケタで、SoftBank 絵文字の UNICODE 値に対応。
i-moded001〜d276d を除いた部分は10進数。1〜176 は基本絵文字、201〜276 は拡張絵文字 1〜76 に対応。
WILLCOMd001〜d276i-mode と同じ
wf040〜wf15fw を除いた部分は16進数4ケタで、ウィルコム絵文字の Shift_JIS コードに対応
EMnet001〜d276i-mode と同じ
e253〜e278e を除いた部分は10進数で、イー・モバイル絵文字 253〜278 に対応。

ドコモ端末、ソフトバンク端末に対しては、似たような絵文字に自動的に変換されます。ウィルコム端末については、ウィルコム独自絵文字で似た絵文字があればそれを使い、なければ i モード互換絵文字に変換します。変換テーブルは独自のもので、キャリア公式のものとは微妙に異なっています。具体的な変換内容についてはソースコード (emobile.php, ezweb.php, i-mode.php, softbank.php, willcom.php) を参照してください。

PC やスマートフォンで閲覧した場合、絵文字は alt 文字列の内容に置換されます。alt 属性が存在しない場合、既定の代替文字を使います (services.php で定義)。

投稿やページの画像をそのまま表示させる

投稿やページでの画像 (img 要素) は、より小さいサムネールにするか (3G, WILLCOM, スマートフォン等)、リンクに変換します (PDC 端末) が、携帯電話でも画像をそのまま表示させたい場合は、その img 要素に
    class="ktai"
という属性を追加してください。すでに class 属性があるなら、既存の class の後ろに空白を入れて ktai と書けばよいです。
    例: <img src="/qr.png" class="noframe ktai" />

なお、画像のサイズが大きくてページの全体サイズが携帯端末の表示容量を越える場合は、画像を alt テキストの内容に置換して容量制限に収まるようにしています。複数の画像がある場合は、後ろの画像から順にテキスト化されます (前の画像を極力残します)。

ただし、画像サイズのチェックはウェブログ内の画像 (uploads フォルダー配下、プラグイン用画像、テーマ用画像など) に限られ、外部サイトの画像は対象外です。外部サイトの画像に class="ktai" を付けて表示させた場合、携帯端末の容量制限を越えてしまう可能性があります。

PNG, GIF 自動切り替え機能

JPEG 画像は、ほぼすべての端末で表示できますが、PNG 画像は i-mode (ドコモ) で表示できず、GIF 画像は Softbank の PDC 端末で表示できません。Ktai Style では、端末に応じてどちらか適切なフォーマットの画像を表示させることができます。

PNG や GIF 画像を使いたい場合は、同じファイル名で PNG フォーマット、GIF フォーマットの画像をそれぞれ用意してください。そして、img 要素の src 属性では、PNG 画像か GIF 画像どちらかを呼び出してください。PNG 画像の呼び出しは i-mode において GIF 画像に、GIF 画像の呼び出しは SoftBank PDC において PNG 画像に変更されます。

例: <img src="<?php ks_theme_url(); ?>title.png" class="ktai" />
      → i-mode では title.gif を読み込む
例: <img src="<?php ks_theme_url(); ?>map.gif" class="ktai" />
      → SoftBank では map.png を読み込む

※Ktai Style 1.10 から、PNG, GIF どちらかの画像から片方の画像を作るようにしました。それでも、あらかじめ title.png, title.gif や map.gif, map.png それぞれを作っておくことをおすすめします (特に携帯テーマ用の画像の場合)。

コメント項目不足時エラーのインライン表示

default, compact, redportal テーマでは、WordPress の標準動作と異なり、コメント投稿時に必須事項 (コメント本文、名前、携帯電情報など) が記入されてないとき、コメントフォームを再び表示してその上部にエラーを出します (エラーのインライン表示)。classic テーマは、WordPress 標準の動作である、エラー画面に遷移となります。この場合、携帯電話の機種によっては、前の画面に戻ったとき、入力内容が消えてしまうことがあります。

エラーをインライン表示にするには、submit ボタンを ks_inline_error_submit() テンプレートタグを使って出力します。

default テーマの場合
<?php ks_inline_error_submit(_e('Say It!')); ?>
classic テーマの場合
<input type="submit" name="submit" value="<?php _e('Say It!'); ?>" />

スタイルシートの利用

DoCoMo FOMA, EZweb の WAP2.0 対応機、ソフトバンク 3G など、最近の端末ではスタイルシートにも対応しています。EZweb は、media="handheld" 指定によって独立したスタイルシートを作成できます。i-mode 用 CSS (i-CSS) は各要素に style 属性を付与したインライン形式しか対応しておらず、HTTP ヘッダで application/xhtml+xml を名乗る必要があります (text/html ではスタイルシートが無効になります)。

Ktai Style は、デフォルトではスタイルシートを使わず、HTTP ヘッダでは text/html を出力しています。しかし、ks_use_appl_xhtml() テンプレートタグを使うことにより、DoCoMo FOMA, EZweb の WAP2.0 対応機、ソフトバンク 3G において、HTTP ヘッダで application/xhtml+xml を出力し、body, h1 hr, font 要素などの特定の属性を style 属性に変換します。

Ktai Style のテンプレートタグは、従来式の HTML 記述 (font color="blue" など) となっていますが、この変換機構によりスタイルシート記述に対応するようになります。

フィルタ対象タグ一覧

WordPress が提供するテンプレートタグのうち、以下のものは本プラグインが出力をフィルタして表示を簡略化しています。

the_title()
パスワード保護された投稿の場合、「保護された投稿: 」または「保護中:」の文字列を「マル秘」絵文字に差し替えます。また、携帯管理画面では、「非公開:」の文字列を「鍵」の絵文字に差し替えます。
the_content()
投稿本文を携帯電話向けに変換して出力します。ただし、携帯電話用テンプレートでは、後述の ks_content() を使ってください (the_content() はパスワード保護された投稿に非対応のため)。
the_excerpt(), get_the_excerpt
投稿の抜粋を画面に出力もしくは取得します。抜粋を設定していない場合、投稿本文から、del, style 要素の中身および JavaScript を削除し、マルチバイト文字を考慮して300バイトの抜粋を作成します。
get_stylesheet()
get_stylesheet_directory()
get_stylesheet_directory_uri()
get_stylesheet_uri()
get_locale_stylesheet_uri()
get_template()
get_template_directory()
get_template_directory_uri()
get_theme_root()
get_theme_root_uri()
comments_template()
PC 向けサイトのスタイルシート/テーマ/テンプレートの代わりに携帯サイト用のスタイルシート/テーマ/テンプレートを読み込みます。
comment_text()
コメント内容を携帯電話向けに簡略化して出力します。
get_permalink()
get_page_link()
get_attachment_link()
get_year_link()
get_month_link()
get_day_link()
get_category_link()
get_tag_link()
wp_list_cats()
wp_list_categories()
wp_list_pages()
すべて title 属性, rel 属性を除去し、href 属性のリンク先からホスト名を削除します。

独自アクションフック一覧

Ktai Style 独自のアクションフックを用意しています。以下のようなコードを、my-hacks.php もしくは携帯テーマの functions.php に記述すれば利用可能です。

add_action('init_pc/ktai_style.php', 'フック関数名');
init_mobile/ktai_style.php
携帯電話でアクセスしたときの初期化処理に、独自処理を追加するためのアクションです。
init_pc/ktai_style.php
PCでアクセスしたときの初期化処理に、独自処理を追加するためのアクションです。

独自フィルターフック一覧

Ktai Style 独自のフィルターフックを用意しています。以下のようなコードを、my-hacks.php もしくは携帯テーマの functions.php に記述すれば利用可能です。

add_filter('raw_content/ktai_style.php', 'フック関数名');

複数の引数がある場合は、優先順位 (デフォルトは10) および引数の数を指定する必要があります。

add_filter('convert_link/ktai_style.php', 'フック関数名', 10, 4);
detect_agent/ktai_style.php
引数: $ktai, $ua
携帯端末の判別結果をフィルターします。$ktai は端末ごとのオブジェクトです (PC と判別された場合は NULL)。$ua はユーザーエージェント文字列です。判別結果を変更する場合は、既存の $ktai オプジェクトを破棄してから、新たなオブジェクトを生成して返り値とします。例えば、Blazer を「その他端末」として判別させる場合は以下の通りとします。
function ks_detect_blazer($ktai, $ua) {
	if (preg_match('|\bBlazer/|', $ua)) {
		if ($ktai) {
			unset($ktai);
		}
		$ktai = new Ktai_Service_Other($ua);
	}
	return $ktai;
}
add_filter('detect_agent/ktai_style.php', 'ks_detect_blazer', 10, 2);
※重要このフィルターを使うフック関数および呼び出し用の add_filter() は、my-hacks.php に記述する必要があります。他のフィルターと異なり、携帯テーマの functions.php に入れても読まれません (携帯テーマの functions.php を読む前に携帯端末の判別を行うため)。
smiley_table/ktai_style.php
引数: $smiles
WordPress のスマイリーを携帯電話絵文字に変換するテーブルをフィルターします。このフィルターを使えば、スマイリーアイコンを追加した場合、それに対応する携帯絵文字を追加することが可能になります。$smiles は配列で、キーはスマイリーのファイル名 (icon_XXXX.gif) で、値は現在閲覧しているキャリアに対応した絵文字の文字コード (SoftBank の場合ウェブコード) です。たいていの場合、フィルター関数では、is_ktai() を使ってキャリア別に処理する必要があるでしょう。例えば以下のようにします。
function ks_correct_smiley($smiles) {
	global $Ktai_Style;
	switch (is_ktai()) {
	case 'DoCoMo' :
		$smiles['icon_question.gif'] = Ktai_Service_DoCoMo::$pics['d159']; // use "!?"
		break;
	}
	return $smiles;
}
add_filter('smiley_table/ktai_style.php', 'ks_correct_smiley');
pictogram_table/ktai_style.php
引数: $trans
絵文字用を示す <img localsrc="XXXX" /> フォーマットから実際の絵文字に変換するときのテーブルをフィルターします。$trans は配列で、キーは絵文字番号 (XXXX 部分)、値は現在閲覧しているキャリアに対応した絵文字の文字コード (SoftBank の場合ウェブコード) です。
convert_pict_other/ktai_style.php
引数: $converted, $number, $alt
PC および「その他」端末での閲覧時、携帯電話絵文字を文字列に変換した結果をフィルターします。$converted は Ktai Style 既定の代替文字列に置き換えた結果、$number は絵文字番号、$alt<img localsrc... に書かれた alt 文字列です。空の alt 文字列ならば空文字列が、alt が存在しなければ NULL が入ります。PC でもフィルターを使うためには、my-hacks.php にフィルタ関数および add_filter を書く必要があります。
raw_content/ktai_style.php
引数: $buffer
テンプレートによって作成された直後のページ内容をフィルターできます。文字コードはウェブログの文字コードのままです (たいていは UTF-8)。UTF-8 そのままで記述されているハートマーク等を数値実体参照に置換する処理は、このフックに処理用関数を割り当てて行なっています。
encoding_converted/ktai_style.php
引数: $buffer
文字コードを携帯電話用に変換後、ページ分割前の内容をフィルターできます。絵文字 (実体参照で記述されたハートマーク等も含む) や顔文字の変換、余分な XHTML タグや改行コードの削除はこのフックにそれぞれの処理関数を割り当てることで実施しています。優先順位 10 でフィルター追加した場合、これらの処理が終わった後の内容をフィルターすることになります。
split_page/ktai_style.php
引数: $buffer, $page_num
ページ分割を行うためのフィルターです。ページ分割処理は、このフックにページ分割関数を割り当てることで行なっています。$buffer は出力用 XHTML、$page_num は現在のページ番号 (最初のページは1) です。携帯電話各社に応じた HTML/XHTML タグ最適化は、このフックに10以上の優先順位を持つフィルターを追加することで行なってください。ページ分割前に li, dt, dd, option などの閉じタグ削除を行なっても、ページ分割処理で補完されてしまうためです。
allowedtags/ktai_style.php
引数: $allowedtags
ページ分割時に、使用を許可する XHTML タグの一覧をフィルターできます。デフォルトのタグ一覧は kses.php で定義していますので、追加したいタグを適宜修正してください。例えば、フィルター関数で
$allowedtags['style'] = array();
とすれば style 要素が使えるようになります。
split_page_navi/ktai_style.php
引数: $navi, $prev, $num, $next
携帯用ページ分割のナビゲーションメニューをフィルターします。すべての引数はウェブログの文字コードと同じ (たいてい UTF-8) で、$navi は、メニュー文字列で、%s, %d, %s という変数を含みます。$prev は1つ目の変数で「*. 前へ」を示す文字列、$num は2つ目の変数で現在のページ数、$next は3つ目の変数で「次へ.#」を示す文字列です。
引数: $html, $url, $ext
外部サイトへの中継ページ、コメント投稿時のエラー画面、管理画面での確認画面等で、画面上部に出る WordPress ロゴの出力をフィルターします。$html は出力用HTML, $url はロゴの URL、$ext は、閲覧している端末に応じた画像拡張子 (png または gif) です。WordPress ロゴをサイトのロゴに差し替えたいときに使えます。
redir/ktai_style.php
引数: $html, $url
i-mode, EZweb, Yahoo! ケータイ閲覧時に外部サイトに移動する際に出る中継ページの文言をフィルターします (使用例)。$html はXHTML で記述された内容で、$url はジャンプ先 URL です。
leave_scheme/ktai_style.php
引数: $schemes
中継ページ経由のリンクとせず、通常リンクのままとする URI スキーム一覧 (配列) をフィルターできます。フィルター関数で
unset($schemes['tel-av:']);
とすると tel-av スキームのリンクは中継ページ経由になります。
引数: $link_html, $href, $label
外部サイトへのリンク変換処理をフィルターします。$link_html は Ktai Style による処理後のリンクHTML, $href はリンク先 URL, $label はリンク文字列です。携帯電話キャリアや種別を知りたい場合は、is_ktai(), ks_service_type() を使ってください。
mobile_same_url/ktai_style.php
引数: $url_pat
同じ URL で PC /携帯両対応できるサイトの URL 正規表現リストをフィルターします。デフォルトの URL リストは、URL が共用になっているサイト、PC 向け URL に携帯電話でアクセスしたら別 URL にリダイレクトされるサイトのどちらも含まれます。デフォルトのサイト一覧に追加する場合は以下のようにします。追加する URL は正規表現であることに注意してください。
function ks_add_mobile_sites($url_pat) {
	$url_pat[] = 'http://blog\.example\.jp/';
	return $url_pat;
}
add_filter('mobile_same_url/ktai_style.php', 'ks_add_mobile_sites');
none_mobile_url/ktai_style.php
引数: $url_pat
上記 mobile_same_url のパターンにマッチするものの、中継ページを出させたい URL の正規表現リストをフィルターします。これは、"http://www.cocolog-nifty.com/" を除外するために用意しています ;-) mobile_same_url には http://[-\w]+.(cocolog|air|moe|tea|txt|way)-nifty\.com/ というパターンがあって、ココログのフロントページである http://www.cocolog-nifty.com/ もマッチしてしまいます。しかし、この URL 配下のページは完全に携帯対応しておらず、中継ページなしでリダイレクトするのはふさわしくありません。といって、正規表現で www.cocolog-nifty.com だけ外す記述は難しいため、除外サイトを設定する、という手段を用意しました。mobile_same_url フィルターで追加した URL パターンで似た状況があれば、none_mobile_url フィルターも使ってみてください。
引数: $link_html, $orig_html, $href, $label
a 要素によるハイパーリンクの変換処理をフィルターします。$link_html は Ktai Style による処理後のリンク HTML、$orig_html は処理前の a 要素そのもの、$href はリンク先 URL、$label はリンク文字列です。フィルター結果を NULL にすると、a 要素の変換処理が行なわれなくなります。
引数: $image_html, $orig_html, $src
img 要素による画像を、より小さいサムネールやリンクに変換する処理をフィルターします。$image_html は Ktai Style による変換後の HTML、$image は変換前の img 要素そのもの、$src は画像のソース URL です。フィルター結果を NULL にすると、画像からリンクへの変換処理が行なわれなくなります (画像がそのまま表示される)。
image_inline_setting/ktai_style.php
引数: $image_inline
3G 端末、WILLCOM、スマートフォン等で、画像をインライン表示させるかどうかデフォルト状態をフィルターします。3G 端末、WILLCOM、スマートフォン等でアクセスし、かつ、管理画面で「3G 端末, WILLCOM, スマートフォン等での画像表示」が「画像を表示」に設定されていれば、$image_inline が TRUE となっています。この値をそのまま返すと、画像をインライン表示します。常に FALSE を返せば、端末によらず、「画像をリンクにする」がデフォルトになります。逆に、常に TRUE を返すと、2G 端末でも画像をインライン表示してしまいます (おすすめしません)。フィルター関数の例は以下の通りです。
function ks_image_link_default($image_inline) {
	return FALSE;
}
add_filter('image_inline_setting/ktai_style.php', 'ks_image_link_default');
ks_switch_inline_images/ktai_style.php
引数: $menu, $before, $after
「画像を表示する/リンクに変換」の切り替えメニューをフィルターします。$menu は切り替えメニュー HTML、$before, $after は切り替えメニューの前後につく XHTML (ks_switch_inline_images() の引数)です。
switch_pc_view/ktai_style.php
引数: $menu, $uri, $before, $after
「PC 表示にする」の切り替えメニューをフィルターします。$menu は切り替えメニュー HTML、$uri は現在ページの URI、$before, $after は切り替えメニューの前後につく XHTML (switch_pc_view() の引数)です。

上記フックでは既定のフィルターを定義していますが、以下の通りにして削除することも可能です。

remove_filter('raw_content/ktai_style.php', array($Ktai_Style->ktai, 'shrink_pre_encode'), 9);
remove_filter('encoding_converted/ktai_style.php', array($Ktai_Style->ktai, 'shrink_pre_split'), 5);
remove_filter('encoding_converted/ktai_style.php', array($Ktai_Style->ktai, 'replace_smiley'), 7);
remove_filter('encoding_converted/ktai_style.php', array($Ktai_Style->ktai, 'convert_pict'), 9);
remove_filter('split_page/ktai_style.php', array($KS_Shrinkage, 'add_image_inline'), 7);
remove_filter('split_page/ktai_style.php', array($Ktai_Style->ktai, 'split_page'), 9, 2);
remove_filter('split_page/ktai_style.php', array($Ktai_Style->ktai, 'shrink_post_split'), 15);
remove_filter('split_page/ktai_style.php', array($Ktai_Style->ktai, 'trim_images'), 20);

独自タグ一覧

出力される XHTML が簡略化されたテンプレートタグを用意しています。これらの関数はテンプレートが読み込まれる直前に有効となるため、他のプラグインでは、そのプラグインが add_action(), add_filter() で追加したコールバック関数の中でのみ使えます。

ks_option($name)
本プラグインのオプション設定値を返します。
$name: オプション名
ks_service_type()
携帯キャリアごとのサービス名を返します。i-mode (DoCoMo) の場合 mova, FOMA のいずれか、EZweb (KDDI) の場合 HDML, WAP2.0 のいずれか、SoftBank の場合 PDC, 3G のいずれか、WILLCOM の場合 AIR-EDGE、イー・モバイルの場合 EMnet という値になります。ディズニー・モバイルは SoftBank 3G とみなします。
ks_is_flat_rate()
閲覧中の端末が定額パケット通信に対応しているなら TRUE を返します。具体的には、各社 3G 端末、WILLCOM、スマートフォン、「その他」端末 (mova, SoftBank PDC 以外) の場合 TRUE となります。
ks_in_network()
i-mode, EZweb, Yahoo! ケータイ, WILLCOM, EMnet 各社のネットワークからアクセスしている場合 TRUE になります。スマートフォン等でのアクセスや、携帯電話のユーザーエージェントを名乗ってインターネットからアクセスしている場合は FALSE になります。できるだけ最新情報に追随するよう配慮していますが、電話キャリアが突然新しい IP アドレスを追加することがある (携帯電話からアクセスしているのに、FALSE と判定される可能性がある) ため、ご注意ください 。
ks_is_menu()
menu_XXXX.php を使用した出力の場合 TRUE を返します。is_home() は、menu_XXXX.php を使った出力の場合でも TRUE になってしまうため、必要に応じて is_home() && ! ks_is_menu() といったコードを使ってください。
ks_is_front()
サイトの最初のページかどうかを判断します。is_home() かつ1ページ目であれば TRUE となります。独自テンプレートである menu_XXXX.php (年月アーカイブ/カテゴリー一覧/タグクラウド/ページ一覧/ブログロール/最近のコメント) を表示しているときは FALSE になります。
ks_is_comments_list()
コメント一覧ページであれば TRUE になります。
ks_is_comment_post()
コメント投稿ページであれば TRUE になります。
ks_is_comments()
コメント一覧ページまたはコメント投稿ページであれば TRUE になります。
ks_is_image_inline()
各社 3G 端末、WILLCOM、スマートフォン等で、画像をインライン表示させる状態のとき TRUE になります。関数名は ks_is_inline_image() ではないことに注意してください。
ks_added_image()
テーマや他のプラグインで、投稿本文やページ本文に画像を追加したとき、この関数を呼ぶ必要があります。さもないと、「画像を表示/リンクに変換」のメニューが出ません。
ks_has_inline_images()
ページ中のインライン画像の枚数を返します。この値が1以上かつ ks_is_image_inline() が TRUE のとき「画像を表示する/リンクに変換」のメニューが出ます。
ks_header()
ヘッダーを出力します (get_header() は使えません)。
フッターを出力します (get_footer() は使えません)。
ks_wp_head()
WordPress 標準テンプレートタグ wp_head() を実行しますが、スタイルシートや JavaScript の出力は抑制されます。wp_head() の実行を前提とするプラグインを併用するとき、かわりに ks_wp_header() を使ってください。附属テーマの header.php にはコメントアウトした形で記述ずみですので、コメントを外せば有効になります。
WordPress 標準テンプレートタグ wp_footer() を実行しますが、スタイルシートや JavaScript の出力は抑制されます。wp_footer() の実行を前提とするプラグインを併用するとき、かわりに ks_wp_footer() を使ってください。附属テーマの footer.php にはコメントアウトした形で記述ずみですので、コメントを外せば有効になります。
ks_blogurl($echo)
ウェブログの URL を出力します。ホスト名を省略した絶対パスに変換し、末尾にスラッシュが付きます。
$echo: TRUE の場合、画面に出力します (デフォルト)。FALSE の場合、関数の返り値とします。
ks_siteurl($echo)
WordPress がインストールされている URL を出力します。ホスト名を省略した絶対パスに変換し、末尾にスラッシュが付きます。
$echo: TRUE の場合、画面に出力します (デフォルト)。FALSE の場合、関数の返り値とします。
ks_plugin_url($echo)
プラグインのあるディレクトリにアクセスできる URL を出力します。末尾にスラッシュが付きます。
$echo: TRUE の場合、画面に出力します (デフォルト)。FALSE の場合、関数の返り値とします。
ks_theme_url($echo)
携帯電話用テーマのディレクトリーにアクセスできる URL を出力します。末尾にスラッシュが付きます。
$echo: TRUE の場合、画面に出力します (デフォルト)。FALSE の場合、関数の返り値とします。
ks_admin_url($echo)
管理画面にログインしたときの最上位 URL を出力します。末尾にスラッシュが付きます。
$echo: TRUE の場合、画面に出力します (デフォルト)。FALSE の場合、関数の返り値とします。
ktai_style/admin ディレクトリーがあれば、ログイン画面へのリンクを出力します。末尾にスラッシュが付きます
$before: リンクの前に出力する文字列
$after: リンクの後ろに出力する文字列
$echo: TRUE の場合、画面に出力します (デフォルト)。FALSE の場合、関数の返り値とします。
ks_get_logout_url($echo)
ログアウト用の URL を返します。
$echo: TRUE の場合、画面に出力します。FALSE の場合、関数の返り値とします (デフォルト)。
ks_is_loggedin()
携帯電話でログインしている場合、ユーザー ID を返します。ログインしていない場合 FALSE を返します。
ks_session_id_form()
コメントフォームなどで、ログイン中のセッション ID を引き継ぐための HTML を出力します。
ks_get_wp_version()
WordPress のバージョンを返します。WordPress ME の場合、「ME」という文字列を除いた数字部分となります。
ks_term_name()
携帯電話の機種名を表示します。不明時は N/A という文字列になります。au の場合、デバイス ID ではなく、一般的な機種名に変換します。
ks_use_appl_xhtml()
DoCoMo FOMA, EZweb (WAP2.0), SoftBank 3G およびディズニー・モバイルのとき、HTTP ヘッダーの MIME タイプを application/xhtml+xml に変更し、以下の html 要素を出力します。また、font 要素の color 属性を span 要素の style 属性に変換するなど、いくつかの XHTML 属性をスタイルシートに変換します (詳細は「↑スタイルシートの利用」を参照)。
<html xmlns="http://www.w3.org/1999/xhtml">
header.php の先頭で使い、かつ、<html> という記述は消しておく必要があります。でないと html 要素がダブって文法違反になります。
ks_applied_appl_xhtml()
ks_use_appl_xhtml() を使っているとき、MIME タイプが application/xhtml+xml に変更されている (== DoCoMo FOMA, EZweb (WAP2.0), SoftBank 3G, EMnet およびディズニー・モバイルで閲覧している) なら TRUE を返します。
ks_force_text_html()
MIME タイプを text/html に強制します。header.php の先頭で使う必要があります。
ks_mimetype()
携帯電話サイトの MIME タイプを出力します。
ks_charset()
携帯電話サイトの文字コードを出力します。
ks_fix_encoding_form()
入力フォームにおいて、文字化け防止のための文字コード判別用隠しフィールドを追加します。
ks_detect_encoding()
文字コード判別用隠しフィールドをもとに、文字コードを判別します。入力フォームの処理部分で使います。
ks_mb_get_form($key, $charset)
フォームの値をウェブログ文字コード (たいてい UTF-8) に変換して返します。携帯電話絵文字がある場合、<img localsrc="XXXX" /> の型式に変換されます。フォームには、ks_fix_encoding_form() で文字コード判別用隠しフィールドを埋め込んでおいてください。
ks_is_required_term_id()
端末 ID を要求している状態ならば TRUE になります。具体的には、管理画面で「コメント投稿者の端末 ID 送信を必須とする」を「はい」にしていて、かつ、閲覧者がドコモ/au/ソフトバンク/イー・モバイル音声端末の場合を示します。
ks_require_term_id_form($action, $method)
端末 ID を要求するフォームを作ります。
$action: フォームの送信先
$method: post, get のいずれか
ks_inline_error_submit($value)
必須項目不足などのエラーをインライン表示するコメントフォームを作るための送信ボタンを出力します。
$value: 送信ボタンの表示内容 (デフォルトは _e('Say It!') です)
ks_do_comment_form_action()
コメントフォームで do_action('comment_form', $post->ID);> を実行し、そのアクションで行なわれた画面出力を携帯電話向けに軽量化します。
ks_title()
ページのタイトルを出力します。ブラウザーウィンドウのタイトルに使われます。wp_title() よりも短い表示になります。
ks_content()
投稿本文を携帯電話向けに変換して出力します。del, style 要素の中身および JavaScript を削除/画像はより小さいサムネールもしくはリンクに変換/外部サイトへのリンクを中継ページ経由に変換/拙作の Ktai Location が挿入した位置情報 URL を削除など。
ks_get_content()
携帯電話向けに変換する前の投稿本文を返します。
ks_check_password($message)
パスワード保護された投稿かどうか確認します。保護されていないか、正しいパスワードが入力されれば、NULL を返します。保護されていて、かつ、パスワードが正しくなければパスワード入力フォームを返します。
$message: 入力フォームの上に出すメッセージ
ks_time($year, $month_date, $time)
現在日時に応じて適切に短縮した投稿日時を出力します。投稿日と現在が同じ年ならば年を省略、同じ年月日ならば年月日を省略します。日だけの表示はおかしいので、年月だけが同じのときは、年だけの省略となります。フォーマットに使う文字列は PHP の date() 関数と同じです。引数を省略すると、プラグイン設定画面に入力したフォーマットとなります。
$year: 年月日を表示する場合のフォーマット (去年以前の日付)
$month_date: 月日を表示する場合のフォーマット (今年の日付)
$time: 時刻のフォーマット
ks_mod_time($year, $month_date, $time)
現在日時に応じて適切に短縮した修正日時を出力します。投稿日と現在が同じ年ならば年を省略、同じ年月日ならば年月日を省略します。日だけの表示はおかしいので、年月だけが同じのときは、年だけの省略となります。フォーマットに使う文字列は PHP の date() 関数と同じです。引数を省略すると、プラグイン設定画面に入力したフォーマットとなります。
$year: 年月日を表示する場合のフォーマット (去年以前の日付)
$month_date: 月日を表示する場合のフォーマット (今年の日付)
$time: 時刻のフォーマット
ks_comment_datetime($year, $month_date, $time)
現在日時に応じて適切に短縮したコメント日時を出力します。コメント日と現在が同じ年ならば年を省略、同じ年月日ならば年月日を省略します。日だけの表示はおかしいので、年月だけが同じのときは、年だけの省略となります。フォーマットに使う文字列は PHP の date() 関数と同じです。引数を省略すると、プラグイン設定画面に入力したフォーマットとなります。
$year: 年月日を表示する場合のフォーマット (去年以前の日付)
$month_date: 月日を表示する場合のフォーマット (今年の日付)
$time: 時刻のフォーマット
ks_pict_number($num, $echo)
数字の絵文字を返します。
$num: 出力したい数字 (0〜9)。10 を与えると 0 を出力します。-1 以下の数値または11以上の数値を与えると□ (四角) を出力します。数字以外の値では何も返しません。
$echo: TRUE の場合、画面に出力します。FALSE の場合、関数の返り値とします (デフォルト)。
携帯電話の絵文字を使った数字付きリストの出力を行います。リンク先を指定すると、その数字がアクセスキーとして使えるリンクになります。使用例は index.php を参照してください。
$count: 出力したい数字。accesskey 用の番号にもなります。
$max: 絵文字を使う最大値。これより $count が大きければ、絵文字の代わりに □ (四角) になります。
$link: リンク先 URL
$label: リンク文字列。この引数を省略すると、閉じタグ (</a>) は出力しません。
wp_link_pages() の代わりとなる、分割ページ用ナビゲートタグです。パスワード保護された投稿で認証ずみの場合は、アンカーリンクではなく、隠しフィールドにパスワードを埋め込んだフォームボタンが表示されます。このため、パスワードの再入力なしにページ遷移が可能です。
$args: 各種パラメーター (wp_link_pages() と同じ仕様)
ks_pagenum($before, $after)
指定したコンテンツが複数ページに分かれている場合、現在のページ番号を出力します。1ページのみの場合は何も出力されません。例えば、2007年9月の記事が2ページに渡る場合、1/2, 2/2 などと表示されます。
ks_previous_post_link($format, $link, $in_same_cat, $excluded_categories, $accesskey)
前の投稿へのナビゲーションリンクを出力します。引数は previous_post_link() と同じものに、$accesskey が追加されています。
$accesskey: アクセスキー文字
ks_next_post_link($format, $link, $in_same_cat, $excluded_categories, $accesskey)
次の投稿へのナビゲーションリンクを出力します。引数は next_post_link() と同じものに、$accesskey が追加されています。
$accesskey: アクセスキー文字
前ページへのナビゲーションリンクを出力します。
$label: リンク文字列 (デフォルトは ≪*.前)
$accesskey: アクセスキー文字 (デフォルトは *)
次ページへのナビゲーションリンクを出力します。
$label: リンク文字列 (デフォルトは #.次≫)
$accesskey: アクセスキー文字 (デフォルトは #)
$max_page: 最大ページ数 (通常は指定不要)
前後のページへのナビゲーションリンクを出力します。前後のページがないときは何も出力しません。
$sep: 間に挟まれる分離文字列。
$before: ナビゲーションの前に付ける HTML タグ
$after: ナビゲーションの後ろに付ける HTML タグ
$prev_label: 前ページを示す文字列 (デフォルトは ≪*.前 )
$next_label: 次ページを示す文字列 (デフォルトは #.次≫ )
$prev_key: 前ページのアクセスキー文字 (デフォルトは *)
$next_key: 次ページアクセスキー文字 (デフォルトは #)
ks_posts_nav_multi($num, $first, $last, $prev_key, $next_key)
複数の前後ページおよび先頭・末尾ページへのナビゲーションリンクを出力します。accesskey は表示されませんが前後ページへ移動に対応しています。
$num: 前後何ページリンクするかの数
$first: 「先頭」を示す文字列
$last: 「末尾」を示す文字列
$prev_key: 前ページのアクセスキー文字 (デフォルトは *)
$next_key: 次ページアクセスキー文字 (デフォルトは #)
ks_posts_nav_dropdown()
ポップアップ (ドロップダウン) 式のページナビゲーションを出力します。ページ数が多くて吐き出す XHTML のサイズが携帯電話の制限を越える場合は、出力が抑制されます。index.php では抑制される可能性が高いため使用しないでください。附属テンプレートでは archive.php にのみ使用しています。
コメント一覧ページを示す URL を返します。
$id: 対象とする投稿 ID。投稿ループの中では空でよい。
コメント数を表示し、コメント一覧へのリンクとして出力します。
$icon: リンクの前に置く絵文字。NULL を渡すとデフォルトの「メモ用紙」絵文字になります。絵文字なしにするには空文字列を渡してください。
$zero: コメントなしを示す文字列
$one: コメント1件を示す文字列
$more: コメント2件以上を示す文字列。「%」があればコメント数に置換されます。
$none: コメント停止中を示す文字列。これを表示する場合、コメント一覧ページへのリンクはされません。
$sec: パスワード保護している投稿を示す文字列
$accesskey: アクセスキー文字列 (デフォルトはなし)
ks_comments_post_url($id)
コメント投稿フォームへのリンク URL を返します。
$id: 投稿 ID
ks_comments_post_link($label, $before, $after, $icon, $accesskey)
コメント投稿フォームへのリンクを出力します。
$label: リンク先の説明
$before: リンクの前に置く文字列 (絵文字等)
$after: リンクの後に置く文字列
$icon: リンク先説明の前に置く絵文字 (デフォルトは鉛筆の絵)
$accesskey: アクセスキー文字 (デフォルトはなし)
ks_back_to_post($icon, $label, $accesskey)
記事に戻るリンクを出力します。
$icon: リンクの前に置く絵文字
$label: リンク先の説明
$accesskey: アクセスキー文字 (デフォルトはなし)
ks_get_recent_comments($num, $type, $group_by_post)
最新コメント一覧を配列で返します。デフォルトでは2次元配列になります (後述)。
$num: コメント表示数
$type: コメントの種類を示す文字列
  (なし): コメント・トラックバック・ピンバックを混在
  comment: コメントのみ
  trackback: トラックバックのみ
  pingback: ピンバックのみ
  trackback+pingback: トラックバック・ピンバックを混在
$group_by_post: コメントを投稿ごとにまとめるかどうか (デフォルト TRUE)。TRUE の場合、同じコメントへの投稿をまとめて、2次元配列とします。1次元目は投稿 ID をキーとしたコメントオブジェクトの配列です。FALSE の場合、コメントオブジェクトの配列です。
ks_category($separator)
表示している投稿が属するカテゴリーの一覧を出力します。
$separator: カテゴリーごとの区切り文字列
ks_tags($before, $after, $separator)
表示している投稿に付与されているタグ一覧を出力します。タグが付いてないときは何も出力しません。
$before: 一覧の前に置く文字列 (絵文字等)
$after: 一覧の後に置く文字列
$separator: タグごとの区切り文字列
ks_tag_cloud($args)
タグクラウドを出力します。wp_tag_cloud() と同じ動作をしますが、余計な空白や title 属性、rel 属性などを除去しています。
ks_get_archives($args)
アーカイブ一覧を出力します。wp_get_archives() の結果から、余計な空白や title 属性を除去して出力します。
$arg: ks_get_archives() と同じ仕様のパラメーター
ks_list_bookmarks($args)
ブックマーク(ブログロール)一覧を出力します。wp_list_bookmarks() の結果から、余計な空白や title, rel 属性を除去して出力します。
$arg: wp_list_bookmarks() と同じ仕様のパラメーター
ks_pages_menu($sep, $before, $after, $args)
固定ページへのナビゲーションを出力します。デフォルトは親ページのみです。子ページが存在する場合、親ページ一覧のあとに、「ページ一覧ページ」(menu_pages.php) へのリンクが出ます。
$sep: 項目ごとの区切り
$before: 前に付ける HTML タグ
$after: 後ろに付ける HTML タグ
$args: 表示用パラメーター。get_pages() の引数が使えます。さらに、'parent_only=0' とすると、すべてのページをリストアップし、'echo=0' を入れると出力するかわりに HTML を返り値とします。
ks_switch_pc_view($before, $after)
スマートフォン等「その他」端末の場合、PC 表示に切り替えるかリンクを出力します。
$before: リンクの前に置く文字列
$after: リンクの後に置く文字列
ks_switch_inline_images($before, $after)
各社 3G, WILLCOM, スマートフォン等で、画像をインライン表示するかリンクに変換するかの切り替えメニューを出力します。
$before: メニューの前に置く文字列
$after: メニューの後に置く文字列

ページ分割機能用タグ

<!--start paging-->
<!--end paging-->
ページ分割機能において、分割対象領域を示します。この2つに挟まれた区間が分割され、前者より上/後者より下にある XHTML コードはすべてのページに出力されます (共通領域)。前者が存在しないときは <body> タグ、後者が存在しないときは「<hr /><a name="tail"」という文字列もしくは </body> タグを代わりに使います。
なお、共通領域が広くて分割に使えるバイト数があまりに少ないとき (256 バイト未満) は、強制的に <body>〜ページ終端を分割対象とします。

他のプラグインとの連携

他のプラグインにおいて、PC 向け出力か携帯電話出力かを区別できるよう、以下の関数を用意しています。

is_ktai()
携帯電話出力なら、事業者名を返します。DoCoMo, KDDI, SoftBank, WILLCOM, EMOBILE, Unknown のいずれかです。ディズニー・モバイルは SoftBank になります。

本プラグインが有効・無効にかかわらずエラーが出ないよう、次のようにして使ってください。

if (function_exists('is_ktai') && is_ktai()) { ?>
<img localsrc="334" alt="[new] " />
<?php }

次は、携帯電話でない場合にスタイルシートを追加する例です。この判別方法は、Mobile Eye+ を使っている場合や、WPhone Admin Plugin をインストールしている場合にも対応します。

if ((! function_exists('is_mobile') || ! is_mobile()) 
 && (! function_exists('is_ktai')   || ! is_ktai())) { ?>
<style type="text/css" media="all">
.locationurl { display:none; }
</style>
<?php }

以前は、原則として is_mobile() 関数を提供し、WPhone Admin Plugin が存在するときのみ、名前の衝突を避けるため is_ktai() に名前を変えていました。

しかし、WPhone プラグインの提供する is_mobile() 関数は SoftBank PDC 端末を検出しないことが判明したため、is_mobile() だけで携帯電話かどうかの判定を行うことができず、is_ktai() 関数も併用する必要が出てしまいました (具体的なコードは上記の通り)。

そうなると、Mobile Eye+ との互換性を取るために、Mobile Eye+ でも使っている関数名である is_mobile() という名前にする、という措置も無意味となってしまいました。このため、バージョン 0.98 より is_ktai() 関数に一本化することとしました。

# WPhone Admin Plugin の作りが悪い、とも言えますね ;-)