
特集:Webアプリケーション+αの使い勝手を実現するカスタムブラウザの作り方
調べもの専用Googleブラウザを作ってみよう
アリエル・ネットワーク中山淳
2006/12/7
| Webアプリケーションの機能や操作性を向上させるアプローチの1つとして、特定のWebアプリケーション専用ブラウザの作成を提案し、その具体的な方法を解説します。ここでは、Googleで検索を行ったときにその検索語を記録していく機能を持った「調べもの専用ブラウザ」 の作り方を説明します(*注意:グーグルが提供を開始したWebブラウザ「Google Chrome」については下記記事をご参照ください)。 |
| Google Chrome曰く「Webブラウザは主役じゃない」 ベータ版が提供開始されたグーグルの新しいブラウザをWebアプリ開発者の視点で検証。IEやFirefoxと比べると? Gearsとの関係は? 検証で見えたChromeの思想とは? 「リッチクライアント & 帳票」フォーラム 2008/9/5 |
||
| 調べもの専用ブラウザを作ってみよう |
- - PR -
Webアプリケーションを構築していると、Webブラウザだけではどうしても実現が難しい問題にぶつかることがあります。
例えばグループウェアで新着情報があったら画面上に通知してほしい(Webブラウザが起動していない状態でも!)とか、Webブラウザを閉じる前の書きかけのフォームの内容を覚えていてほしいとかといった要求がそれです。
いずれも、ユーザーの立場から見ればあって当然の機能ですが、Web技術だけではなかなか解決できないというのが現状ではないでしょうか。
本稿では、特定のWebアプリケーションに特化したWebブラウザ(カスタムブラウザ)を作成することで、このような問題を解決する手法を説明します。
・メリットとデメリット
カスタムブラウザをユーザーに提供する場合、通常のブラウザで使用しても十分な機能性、操作性をユーザーに与えられることが重要です。
というのも、カスタムブラウザには「インストールする手間を掛けなければ使えない」というデメリットがあるからです。
ユーザーはカスタムブラウザをインストールすることで得られる価値が、インストールする手間を上回ると感じなければ、そもそも試すこともしません。つまり、すべてのユーザーがカスタムブラウザを使ってくれることを期待するのは不可能です。
ここから、カスタムブラウザなしでも通常使用には十分な使い勝手を提供できること、カスタムブラウザはプラスαの価値を提供することに特化すべきであるということが導かれます。
本稿では、Googleで検索を行ったときにその検索語を記録していく機能を持った「調べもの専用ブラウザ」を作成します。
| カスタムブラウザの開発を始める前に |
ここでは、カスタムブラウザの開発環境として無料の「Visual C++ 2005 Express Edition」と「Microsoft Platform SDK」を使用します。
下記のURLからダウンロードし、インストールを行ってください。
|
両方ともインストールした後に、下記の手順を行ってVisual C++ 2005 Express EditionからMicrosoft Platform SDKとATLを使えるようにする必要があります(カスタムブラウザの核としてIEコンポーネントを使用するためです)。
1. Microsoft Platform SDKにパスを通す
インストールしただけではVisual C++ 2005 Express EditionからMicrosoft Platform SDKを使える状態になっていないため、ヘッダファイルやライブラリファイルのあるディレクトリにパスを通す必要があります。
(1) Visual C++ 2005 Express Editionを起動し、メニューの[ツール]―[オプション]からオプションダイアログを開きます。
![]() |
(2) オプションダイアログの[プロジェクトおよびソリューション]―[VC++ディレクトリ]を開きます。
(3) [ディレクトリを表示するプロジェクト]の[実行可能ファイル]を選択し、「C:\Program Files\Microsoft Platform SDK\Bin」を入力します。
同様に、[インクルードファイル]に「C:\Program Files\Microsoft Platform SDK\include」と「C:\Program Files\Microsoft Platform SDK\Include\atl」を、[ライブラリファイル]に「C:\Program Files\Microsoft Platform SDK\lib」を追加します(Microsoft Platform SDKをC:\Program Files\Microsoft Platform SDK以外のディレクトリにインストールした場合は、適宜読み替えてください)。
![]() |
(4) [OK]ボタンを押してオプションダイアログを閉じます。
2. Win32プロジェクトのテンプレートを修正する
Microsoft Platform SDKで追加されたライブラリファイルがデフォルトでリンク対象になるようにします。
(1) 「C:\Program Files\Microsoft Visual Studio 8\VC\VCProjectDefaults」にある「corewin_express.vsprops」をテキストエディタ(メモ帳など)で開きます。
![]() |
(2) 「AdditionalDependencies="kernel32.lib"」となっている部分を「AdditionalDependencies="kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib"」に置き換えます。
![]() |
(3) 変更したファイルを上書き保存します。
3. Win32アプリケーションウィザードのWindows アプリケーションを有効にする
インストール直後のVisual C++ 2005 Express Edition では、ウィザードからWindows アプリケーションが作成できないため、修正が必要になります。
(1) 「C:\Program Files\Microsoft Visual Studio 8\VC\VCWizards\AppWiz\Generic\Application\html\1041」にあるAppSettings.htmテキストエディタ(メモ帳など)で開きます。
![]() |
(2) 441行目から444行目までの各行の先頭に「//」を挿入して、コメントアウトします。
![]() |
4. ATLのコンパイルエラー・リンクエラーを除去する
Microsoft Platform SDKに含まれるATLのバージョンが古いため、そのままではコンパイルエラーやリンクエラーが発生します。
(1) 「C:\Program Files\Microsoft Platform SDK\Include\atl」にあるatlwin.hを開きます。
![]() |
(2) 1753行目の「for(i = 0; i < m_aChainEntry.GetSize(); i++)」となっている個所を「for(int i = 0; i < m_aChainEntry.GetSize(); i++)」に変更します(「i = 0」を「int i = 0」に変更)。
![]() |
(3) 変更したファイルを上書き保存します。
(4) 「C:\Program Files\Microsoft Platform SDK\Include\atl」にあるatlbase.hを開きます。
![]() |
(5) 287行目から293行目までの各行の先頭に「//」を挿入してコメントアウトし、下記の2行を追加します。
![]() |
![]() |
| コード1 ここをクリックすると、縮小なしのテキスト画面が表示されます |
6) 変更したファイルを上書き保存します。
以上で、開発環境の準備が整いました。
| 1/4 |
|
INDEX |
||
| 調べもの専用Googleブラウザを作ってみよう | ||
| Page1<調べもの専用ブラウザを作ってみよう> メリットとデメリット/カスタムブラウザの開発を始める前に |
||
| Page2<カスタムブラウザの基礎作り> Hello Worldアプリケーションで動作確認 |
||
| Page3<カスタムブラウザの作成> カスタムブラウザらしいコードを追加する |
||
| Page4<調べもの専用Googleブラウザ> プラスαの価値をカスタムブラウザ |
||
ホワイトペーパー(TechTargetジャパン)
- いまさら聞けないTwitter超入門−@IT記事も対応なう (2010/2/4)
Twitterは最近話題のつぶやきツール。基本的な使い方から、iPhoneアプリの使い方、RTの解説、4人のご意見番の活用例や感想まで - HTML5は開発者側の都合。ユーザーには関係ない (2010/2/2)
3つのレンダリングエンジンを載せている“国産”ブラウザベンダは、HTML5やWeb/ブラウザの進化について何を語るのか - テキスト・フォント周りをキレイに見せるCSS、13選! (2010/1/29)
無数にあるCSSのプロパティを大まかに分類し、1つずつ紹介していく本連載。初回は、テキスト・フォント周りについて - OpenGL ESが大変な3Dアプリ開発を楽にするUnity (2010/1/27)
iPhoneゲーム開発に必須のOpenGL ES。そのコーディングに手こずっている方に有用なツールを紹介し簡単なサンプルを作成します
|
|
スキルアップ/キャリアアップ(JOB@IT)
スポンサーからのお知らせ
お勧め求人情報

**先週の人気講座ランキング**
〜CCNA編〜
| ◆ | 企業の仮想化に足りない“発想”とは? 仮想化運用管理のキモは意外なところに! New! |
| ◆ | 操作もマニュアルも分かりやすい! ユーザー視点で開発されたPC管理ツール New! |
| ◆ | 仮想化すればコストは削減できるか? 仮想化に必要な「3つの視点」を解説する |

| ◆ | セキュリティを知り尽くす上野氏が登壇! @ITメールソリューションLive! in Tokyo |
| ◆ | 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |
| ◆ | 世界に通用するストレージの作り方とは? 製品に込めた思いを富士通の開発者に聞く |

| ◆ | OSSで手間も時間も、障害も減った―― 「マピオンの事例」オープンソース活用法 |
| ◆ | 「ノートPCの持ち出し禁止」で大丈夫? 情報漏えいを防ぐ管理手法とインフラは? |
| ◆ | 1日の処理を1秒に――MySQLの達人が語る 「コスト削減」できるチューニング |

| ◆ | ドキュメント作成を自動化して、SEの作業 効率を大幅アップ! Visio 2007の魅力 |
| ◆ | 急速に広がるHyper-Vでのサーバ仮想化 そのベストプラクティスをデルが解説 |
| ◆ | @IT主催セミナーで語られた、「担当者に 求められるセキュリティ対策」をレポート |

| ◆ | @IT「Windows 7」 特設サイトオープン! 最新情報・移行ノウハウを公開しています |

















