Faviconを作成する

2016.3.22 (火)

http://ao-system.net/favicon/
http://ao-system.net/favicongenerator/
こういったサイトさんがありまして、かなり便利になってます。

最も大きなサイズが192×192となっているので、これ以上の大きさのPNGでFaviconのデザインをすればよいかと思います。凝ってしまうときりがないんですが、小さくなっても潰れないシンプルなデザインがいいかと思います。物好きな方は、自作でつくるのもよいでしょう。結構たくさんあります。

<link rel="shortcut icon" href="/favicon.ico" type="image/vnd.microsoft.icon">
<link rel="icon" href="/favicon.ico" type="image/vnd.microsoft.icon">
<link rel="apple-touch-icon" sizes="57x57" href="/apple-touch-icon-57x57.png">
<link rel="apple-touch-icon" sizes="60x60" href="/apple-touch-icon-60x60.png">
<link rel="apple-touch-icon" sizes="72x72" href="/apple-touch-icon-72x72.png">
<link rel="apple-touch-icon" sizes="76x76" href="/apple-touch-icon-76x76.png">
<link rel="apple-touch-icon" sizes="114x114" href="/apple-touch-icon-114x114.png">
<link rel="apple-touch-icon" sizes="120x120" href="/apple-touch-icon-120x120.png">
<link rel="apple-touch-icon" sizes="144x144" href="/apple-touch-icon-144x144.png">
<link rel="apple-touch-icon" sizes="152x152" href="/apple-touch-icon-152x152.png">
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon-180x180.png">
<link rel="icon" type="image/png" href="/android-chrome-192x192.png" sizes="192x192">
<link rel="icon" type="image/png" href="/favicon-48x48.png" sizes="48x48">
<link rel="icon" type="image/png" href="/favicon-96x96.png" sizes="96x96">
<link rel="icon" type="image/png" href="/favicon-16x16.png" sizes="16x16">
<link rel="icon" type="image/png" href="/favicon-32x32.png" sizes="32x32">
<link rel="manifest" href="/manifest.json">
<meta name="msapplication-TileColor" content="#2d88ef">
<meta name="msapplication-TileImage" content="/mstile-144x144.png">

ちょっとした問題点は今はやりのPHPのルーティングとかAngularJSでのルーティング際に/favicon.pngがうまく読み込めない時があります。これは/以下のアクセスがすべてルーティングで制御されているときに/favicon.pngも明示的に指示してあげるか、あるいはrewriteの操作で例外処理をしてあげないとダメなときがあります。いちばん安全な方法はそもそも画像やCSSなどを格納しているディレクトリなんかはフレームワーク側で例外処理をしているので、その中に入れてあげるのがいちばんいいです。

/assets/img/icon/favicon.png

こういう感じとかに。
個人的にはこういうアイコンがなんであるかはどうでもいいのですが、仕事になると面倒なので一応おさえておくとよいかと思います。