週刊ヒロテックはWEB・IT関連、ブックレビュー、グルメ、映画などの話題満載のブログマガジンです

週刊ヒロテックにiphone版をリリースしました

[UP:2010.05.24]  

お客様から「サイトをiphone対応にしたい」とのご要望をいただき、制作に先立って、まずは自分のブログをiphone対応版にしようと、先週、仕事の合間をぬってトライしてみました。

約2日間の悪戦苦闘の結果、こーんな感じに。(一見シンプルで簡単にできそうですが、ハマッた点は後述しますのでご参考に・・・)

週刊ヒロテック iphone版

▲左がトップページ、右がブログ記事ページ

週刊ヒロテック iphone版

▲ブログ記事内の写真。幅が広いものは右側に横スクロールすると表示される。
iphoneの特長を活かし、記事や写真を拡大して読めるようにした(右側の写真)


このサイトはiphoneで見た人だけに表示されるので、iphoneでない人のため、動画版も作ってみました。表示速度、画面遷移など、iphoneでの雰囲気を見ていただければと思います。

 


自分のメモも含めて、使ったツールやハマッたポイントなどを記しておきます。(技術者向き)

===========
★基本
===========
iphoneライクなライブラリ「iui」を使用。ボタンなどが用意されているのがありがたい。サンプルのHTMLがあるが、解説はないので、自分で必要な箇所のソースを見て使えそうなものを取る。

週刊ヒロテックはMTブログなので、使えそうなプラグインなどを調べてみたが、カスタマイズなどを考えると自分で作ったほうがいいということに落ち着き、iphone用に

トップページ、ブログ記事リスト、ブログ記事

の3つのテンプレートを追加。
iphone用のページはPC版のサブフォルダとした。つまり、blog/index.htmlはPC用のトップページ、blog/iphone/index.htmlはiphone用のトップページになる。

==========
★ハマッた点その1
==========
まずは画面遷移をどうするかということ。iphoneのページは1つのファイルに複数ページをid付きで指定できるようになっており、この機能のメリット(手軽)、デメリット(ファイルサイズが大きくなる)を考えながら、

どのページをどのファイルに入れていくか
グローバルナビゲーションをどのようにするか

についてけっこう悩んだし、使いやすさの試行錯誤で時間がかかった。
だいたいのコツはつかんだので、これからは着手前にきちんと設計しておこう。

===========
★ハマッた点その2
===========
一番ハマッのが、iphoneユーザーだけに表示するための.htaccessのRewrite記述。
iphoneの人が、http://www.hirotec-k.jp/blog/にアクセスしたときに自動的にhttp://www.hirotec-k.jp/blog/iphone/に変更するのはいたって簡単。

RewriteEngine on
RewriteCond %{HTTP_USER_AGENT} iPod [OR]
RewriteCond %{HTTP_USER_AGENT} iPhone [OR]
RewriteCond %{HTTP_USER_AGENT} UP.Browser
RewriteRule ^$ /blog/iphone/ [R]

これを記述した.htaccessをblogフォルダに入れればいいのだが、これだとトップページしか変換されない。
検索エンジンには、ブログ記事やカテゴリーページも登録されており、そのページをダイレクトに指定したときだって、自動的に変換したい!

ということで、単純に考えたのが次の記述。

RewriteEngine on
RewriteCond %{HTTP_USER_AGENT} iPod [OR]
RewriteCond %{HTTP_USER_AGENT} iPhone [OR]
RewriteCond %{HTTP_USER_AGENT} UP.Browser
RewriteRule ^(.*)$ /blog/iphone/$1 [R]

これをやりはじめて、うまくいかずに、はまりまくった。
「多くのリダイレクションが発生」とエラーになってページが一切切り替えられなくなり・・・

ググってもググっても、どうしてこの記述が違っているのか、わからない・・・
正規表現をいろいろ変えてみてもうまくいかず・・・

あるQ&Aでようやくヒントが・・・この指定をblogフォルダに入れると、そのサブフォルダすべてに影響が及ぶので(すっかり忘れてた!)、blog/iphoneフォルダにも影響し、ループのリダイレクションが発生するのです。
そこで、blog/iphoneフォルダ以外のときだけこのルールを適用するようにすればいいわけ。

RewriteEngine on
RewriteCond %{REQUEST_URI} !^/blog/iphone
RewriteCond %{HTTP_USER_AGENT} iPod [OR]
RewriteCond %{HTTP_USER_AGENT} iPhone [OR]
RewriteCond %{HTTP_USER_AGENT} UP.Browser
RewriteRule  ^(.*)$ /blog/iphone/$1  [R]

要するに、上から2行目の記述が必須。これで、どのページも変換できた!やったー!!

思ったら、さっきまで表示されていた画像がすべて表示しなくなってる!
画像もこのルールにしたがって、URLが変換されちゃったんですね・・・

で、最終的な記述がコレ。

RewriteEngine on
RewriteCond %{REQUEST_URI} !^/blog/iphone
RewriteCond %{HTTP_USER_AGENT} iPod [OR]
RewriteCond %{HTTP_USER_AGENT} iPhone [OR]
RewriteCond %{HTTP_USER_AGENT} UP.Browser
RewriteRule  ^(.*)\.html$ /blog/iphone/$1\.html  [R]

HTMLだけを変換しておけばいいんですね。画像はblogフォルダのものをそのまま使っているんだし。

ってことでメデタシ、メデタシ。

その他、細かい画面表示などでハマッた点、工夫した点も多々あり、iuiライブラリで提供されているjavascriptのロジックを追って修正するハメにもなったが、細かいことはここでは省略。

あー、苦労した。
ま、ものごとにはじめてチャレンジするときはこんなものかな・・・
でも、できて良かった。


 

トラックバック(0)

このブログ記事を参照しているブログ一覧: 週刊ヒロテックにiphone版をリリースしました

このブログ記事に対するトラックバックURL: http://www.hirotec-k.jp/mt/mt-tb.cgi/980

コメントする


画像の中に見える文字を入力してください。

管理人@ブログ

prof.gif明治大学卒業後、27歳でヒロテックを起業。パソコン畑一筋。
自称活字中毒。映画と旅行、美味しい食べ物も大好き。
石川県輪島市生。現在、金沢市在住。両親、ダンナ、息子と5人家族
  ヒロテックHP

2010年9月

      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30    

過去の月別アーカイブ