« [Places] ビューと nsIPlacesView インタフェース | [Places] フォルダ内のブックマークを列挙する » |
[Places] nsINavHistoryResultNode からブックマークの各種情報を取得する
[Places] ビューと nsIPlacesView インタフェースから引き続き、 Places データベースからの検索結果 (nsINavHistoryResult オブジェクト) から得たブックマークのノード (nsINavHistoryResultNode オブジェクト) について、各種情報を取得する。
ブックマークの種類
あるノードの種類を調べる、例えばフォルダかどうかを調べるには、 type プロパティを調べる。
if (node.type == Ci.nsINavHistoryResultNode.RESULT_TYPE_FOLDER) alert("The node is a folder.");
PlacesUtils には nodeIs* メソッドがたくさん用意されているので、こちらを使った方が便利。
if (PlacesUtils.nodeIsFolder(node)) alert("The node is a folder."); else if (PlacesUtils.nodeIsLivemarkContainer(node)) alert("The node is a Live Bookmark.");
ブックマークのタグ
nsINavHistoryResultNode の tags プロパティではすべてのタグが「, 」で連結された文字列として取得できる。
var tags = node.tags;
一方、 nsITaggingService#getTagsForURI ですべてのタグを配列として取得することも可能。なお、 PlacesUtils.tagging は nsITaggingService へのショートカット、 PlacesUtils._uri は URI 文字列から nsIURI オブジェクトを生成する便利メソッドである。
var tags = PlacesUtils.tagging.getTagsForURI(PlacesUtils._uri(node.uri), {});
ブックマークのアノテーション
Places では、ブックマークの「説明」プロパティなどは、ブックマークアイテムに対するアノテーションのひとつとして管理されている。アノテーションを取得するには nsIAnnotationService#getItemAnnotation を使う。 PlacesUtils.annotations は nsIAnnotationService へのショートカット、 DESCRIPTION_ANNO はアノテーション名 “bookmarkProperties/description” である。
var desc = PlacesUtils.annotations.getItemAnnotation(node.itemId, DESCRIPTION_ANNO);
以下のように PlacesUIUtils の便利メソッドを使ってブックマークの itemId に対応する「説明」プロパティを取得することも可能。
var desc = PlacesUIUtils.getItemDescription(node.itemId);
ブックマークのアイコン
nsINavHistoryResultNode の icon プロパティから nsIURI オブジェクトとして取得可能。
var iconLink = node.icon ? node.icon.spec : null;
取得した URI は「moz-anno:favicon:http://en-us.www.mozilla.com/favicon.ico」のような特殊なプロトコルで示される。この URI をブラウザに直接貼り付けてみればわかるように、「moz-anno:」プロトコルはプロトコルハンドラによって自動的にアイコンの画像データへ変換される。
一方、あるブックマークの URL を引数としてアイコンの URL を取得するには、 nsIFaviconService#getFaviconForPage を使用する。 PlacesUtils.favicons は nsIFaviconService へのショートカットである。
var icon = PlacesUtils.favicons.getFaviconForPage(PlacesUtils._uri(node.uri));
アイコンの MIME 型と画像データを取得するには、 nsIFaviconService#getFaviconData を使用する。
var mimeType = {}; var iconData = PlacesUtils.favicons.getFaviconData(icon, mimeType, {}); mimeType = mimeType.value;
BASE64 形式の data: URI に変換するには以下のようにする。
var dataURI = "data:" + mimeType + ";" + "base64," + btoa(String.fromCharCode.apply(null, iconData));
im totally new to fire gestures. how do you change the settings on it??
see FIREGESTURES :: Options