WINGSプロジェクト 土井 毅 [著] 山田 祥寛 [監修] 2009/10/21 14:00

 mixiアプリで始めるOpenSocial入門も第3回目となりました。ここまでOpenSocialの概要と、mixiアプリの作成方法について解説してきましたが、今回はOpenSocialアプリケーションの基本となるガジェットXMLの仕様と、ビューとユーザーの役割という概念について解説します。

1 2 3 →

はじめに

 mixiアプリで始めるOpenSocial入門も第3回目となりました。ここまでOpenSocialの概要と、mixiアプリの作成方法について解説してきましたが、今回はOpenSocialアプリケーションの基本となるガジェットXMLの仕様と、ビューとユーザーの役割という概念について解説します。次回から詳しく解説するOpenSocial APIを使う上で重要なポイントが含まれていますので、しっかり押さえておきましょう。

ガジェットXMLの仕様

 シリーズの過去2回でも少し解説しましたが、OpenSocialアプリケーションの実体はガジェットXMLと呼ばれるXMLファイルです。ガジェットXMLの基本的な構造は次のとおりです。

ガジェットXMLの構造
ガジェットXMLの構造

 ガジェットXMLは、ルートのModule要素以下に、OpenSocialアプリケーションの設定情報のためのModulePrefs要素と、表示するコンテンツのためのContent要素を置くことになっています。

 ModulePrefs要素以下には、使用するモジュールを定義するためのRequire要素と、コンテナに対するオプション指定を行うためのOptional要素を置きます。

モジュールについて(Require要素)

 第1回でOpenSocialのJavaScript APIが「Gadgets API」と「OpenSocial API」で構成されていることを説明しましたが、それぞれのAPIはさらに細かくモジュールという単位に分割されています。以下に、mixiアプリで指定可能なモジュールのいくつかを示します。

mixiアプリで指定可能な主なモジュール
モジュール名対応するAPI説明
opensocial-0.8OpenSocial APIOpenSocial API全体を含むモジュール。コンテナからの情報取得などを行う場合には必須
tabsGagdets APIタブ機能のためのモジュール
dynamic-heightGagdets APIアプリケーションの表示領域を調整するためのモジュール
flashGagdets APIFlashコンテンツを埋め込むためのモジュール
minimessageGagdets APIアプリケーションからユーザーに対するメッセージを表示するためのモジュール
viewsGagdets APIビュー(後述)の情報の取得や切替のためのモジュール

 表にも記したように、OpenSocial APIを使ったmixiアプリを作成する場合は、opensocial-0.8モジュールの指定は必須となります(逆に、前回のサンプルのようにOpenSocial APIを呼び出さないのであれば、opensocial-0.8モジュールは不要です)。

 Gadgets APIは機能ごとにモジュールに分割されており、必要とする機能に応じてモジュールを指定して使用します。Gadgets APIに含まれるモジュールのいくつかは、この連載でも解説する予定です。

コンテナへのオプション指定(Optional要素)

 Optional要素は、コンテナに対して特定のオプションを指定するための要素です。コンテナごとに機能が異なるため、OpenSocialでは具体的な機能は定義されていません。

 mixiアプリについて現時点で公開されている情報の範囲では、先回説明した、Optional要素の指定によるContent Rewriteの制御機能だけが定義されています。

表示するコンテンツ(Content要素)

 Content要素には、実際にWebブラウザに表示するコンテンツを記述します。

 type属性に"html"を指定した場合には、CDATAセクションとしてHTML形式でコンテンツを記述します。type属性に"url"を指定した場合には、href属性にコンテンツのURLを指定します。

 type属性に"html"を指定した場合、ガジェットXMLがコンテナで解析され、Webブラウザに送信される際には、HTMLのbody要素以下にContent要素のCDATAセクションの内容が展開されます。従って、html要素やhead要素などをCDATAセクション内に記述することはできません。CDATAセクションにはHTMLだけでなく、JavaScriptやCSSなども記述することができます。CDATAセクション内の要素がどのように変換されるかについては、第1回の説明を参照してください。

 type属性に"url"を指定した場合には、アプリケーションの内容として指定したURLの内容が表示されます。単純にWebブラウザが指定したURLに移動するのではなく、OpenSocialアプリケーションの表示領域内に、指定したURLの内容が表示されます。

 アプリケーションのビューごとに異なった内容を表示させるため、Content要素は複数記述することができます。この機能についてはビューの詳細と併せて次項で説明します。


1 2 3
→
INDEX
mixiアプリで始めるOpenSocial入門(3) ――OpenSocialアプリケーションの基本:ガジェットXMLとビュー
Page1
はじめに
ガジェットXMLの仕様
ビューの種類について
OWNER, VIEWER, FRIENDSについて
各種ビューとユーザーの役割を確認するサンプル
まとめ
参考資料
プロフィール
WINGSプロジェクト 土井 毅 ドイ ツヨシ

WINGSプロジェクトについて>
有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2011年7月時点での登録メンバは36名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。


プロフィール
山田 祥寛 ヤマダ ヨシヒロ

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for ASP/ASP.NET。執筆コミュニティ「WINGSプロジェクト」代表。
主な著書に「入門シリーズ(サーバサイドAjax/XMLDB/PEAR/Smarty)」「独習シリーズ(ASP.NET/PHP)」「10日でおぼえる入門教室シリーズ(ASP.NET/PHP/Jakarta/JSP&サーブレット/XML)」「Pocket詳解辞典シリーズ(ASP.NET/PHP/Perl&CGI)」「今日からつかえるシリーズ(PHP/JSP&サーブレット/XML/ASP)」「書き込み式 SQLのドリル」他、著書多数


記事へのコメント・トラックバック機能は2011年6月に廃止させていただきました。記事に対する反響はTwitterやFacebook、ソーシャルブックマークサービスのコメントなどでぜひお寄せください。

スポンサーサイト