
特集: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ジャパン)
- 画像を美しく魅せる効果を加えるjQueryプラグイン3選 (2010/3/17)
2つ重ねて比較するBefore/After、部分ごとに切り替えるpanelGallery、ズーム/カーテンなどができるcycle - 現場の無駄な流血を止めるための「プロトタイプ」とは (2010/3/12)
サイトやWebアプリ/RIAの設計やデザインを効率良く進めるには、プロジェクト関係者の想定を一致させていくことが大事だが… - Flashを閃光のごとく高速化するための基礎知識 (2010/3/9)
Flash高速化のための基礎知識や実践的テクニックを紹介する連載。初回は“処理負荷”を調べる具体的な方法を解説します - Windows 7でどんだけ“おばか”なアプリが作れるの? (2010/3/4)
おばかの発想の源やアプリの作り方などについて、おばかアプリ選手権の歴戦の受賞者や、マイクロソフトの代表者に話を伺った。アイデアのご参考に
|
|
スキルアップ/キャリアアップ(JOB@IT)
スポンサーからのお知らせ
| 「いつかは壊れるサーバ」そんな故障に 迅速で安価に手軽に対応する方法とは? New! |
| 「特権ユーザー」の事件を防げ! 万能権限を持つユーザーの管理方法とは? New! |
| 仮想環境の構築とデータ保護の特効薬?! 実績と信頼性の高いパッケージで安心運用 |
| 仮想環境のバックアップもこれまでどおり 「まるごと取ってまるごと戻す」簡単運用 |
| おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |
| その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |
| 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |
| 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |
お勧め求人情報

**先週の人気講座ランキング**
〜CCNA編〜
| ◆ | TomcatやJBossなどAPサーバ環境に関する 情報を集約! “業務”用APサーバ大百科 New! |
| ◆ | 一気に解説! 最新のクラスタストレージ 「RAIDを超えたストレージ基準」……など New! |
| ◆ | クラウド的ユーザー体験の変化は脅威か? 仮想化技術を使いこなす運用管理術を紹介 New! |

| ◆ | 上司や部下、部署内メンバーとの情報共有 を“ガラッ”と変えるコラボツールとは? New! |
| ◆ | おばかアプリ選手権、第4弾開催中!! ムダにカッコよくてくだらない作品求ム! |
| ◆ | 社内ファイルサーバを“クラウド”に統合 VPN直結「クラウド型ストレージ」を紹介 |

| ◆ | Twitterのアカウントはなぜ突破された? メールによる新手の攻撃手法とその対策 |
| ◆ | もう仮想化のお試しフェイズは終わりだ! Hyper-V 2.0が基幹システムも仮想化 |
| ◆ | 美人!? まあまあ? 気になる いやし系!! PV急増で「美人時計」がとった手段とは? |

| ◆ | クライアント企業から求められる人材 ⇒IT技術と経営戦略を併せ持つ「戦略家」 |
| ◆ | .NET編集長が実践する「技術情報検索術」 サンプル・コードを簡単に探す“技”は? |
| ◆ | 業務効率と情報セキュリティ対策を両立! 手間なく確実に機密情報を守る方法とは? |

| ◆ | 進化を続ける富士通ストレージETERNUS DX 製品開発者の自信を裏付けるものとは何か |
| ◆ | 運用管理の課題を“2つの観点”から分析 ユーザー満足度の高い「仮想環境」とは? |

| ◆ | 【CTC事例】約30の基幹システムを統合! 膨大なバッジジョブを制御した方法は? |
| ◆ | 仮想化すればコストは削減できるか? 仮想化に必要な「3つの視点」を解説する |
| ◆ | その数、なんと400台以上! グループ内 サーバの「統合管理」によるメリットは? |

















