このブログで表示している画像は全てflickrにアップしたものを使用しているんですが、記事内に挿入するのはwp-flickr-pressという自分で作っているプラグインを使うことで簡単に利用できるんですが、Twenty Fourteenを少し使ってみてアイキャッチ画像を使ったデザインも良いなと思いました。そこで、今までアイキャッチ画像というものを使ったことがなかったのでWordPress内でどういう風に管理されているのかもよく分かっていませんでした。
そんな中、先走り気味にwordpress + flickr + アイキャッチ画像みたいなキーワードでプラグインを検索していると通常のアイキャッチ画像設定画面にflickrの画像選択画面が出てきて選択するとWPをインストールしたサーバにダウンロード、サムネイル生成し、その後は通常のアイキャッチ画像と同じように扱えるというものが幾つかありました。
ただ、個人的にはせっかく画像配信にflickrを使っているのでアイキャッチ画像もflickrを経由して行いたいものです。そこからWordPressのソースを読みました。するとアイキャッチ画像の情報はpostmetaテーブルに管理されており、記事に紐付いている画像のIDや画像サイズ?alt情報も同様に管理されているようでした。
で、postmetaテーブルを使わずにとりあえず記事内に最初に出現するflickr画像をそのままアイキャッチ画像として使用するようなものを書いてみました。ただ、postmetaテーブルなどを介さずに毎回、記事内容からアイキャッチ画像を作り出しているのでアイキャッチ画像を設定しない場合やサイズはもちろんのこと、他アイキャッチ画像を設定することも出来ません。
と、ここまで書いてて気づいたんですが、基本的には記事内の最初に出現するflickr画像をアイキャッチ画像に設定することで問題ないんですが、投稿や更新時に今まで毎回行っていたアイキャッチ画像の抜き出しをして、さらにそれをpostmetaテーブルに格納してやれば問題なさそうですね。
ちょっと実装できるか検討してみよう。wp-flickr-pressユーザでアイキャッチ画像を使っている人いたら、今までどういう風に運用していたか教えてもらえると助かります。
追記: 2013.12.15 00:32
wp_postmetaにMedia Library情報を管理しているが既にMedia Libraryを使っていた場合、既存の画面で表示がおかしくなったりする可能性は多いにあるかもしれない。また、それらを回避して、アイキャッチ画像に独自のCDNを考慮するようなコードは今のところ見られないので検証も大変そうな気がする。
追記: 2013.12.15 00:59
なんで気づかなかったのか分からないが、post_thumbnail_htmlフィルターでサムネイル用HTMLタグの整形を行うが、ココで記事内から画像を取ってきて、、、全部やらせるという手もある。なんか行けそうな気がしてきた。独自のサムネイルに関してはプラグイン個別で管理機能を実装する必要があるけどココは仕方ない気がする。ただ、カスタムフィールドを使えばさほど難しくないんじゃないかと思っている。