説明
chrome.action
API を使用して、Google Chrome ツールバーの拡張機能のアイコンを制御します。
対象
マニフェスト
chrome.action
API を使用するには、"manifest_version"
を 3
に指定し、マニフェスト ファイルに "action"
キーを含めます。
{
"name": "Action Extension",
...
"action": {
"default_icon": { // optional
"16": "images/icon16.png", // optional
"24": "images/icon24.png", // optional
"32": "images/icon32.png" // optional
},
"default_title": "Click Me", // optional, shown in tooltip
"default_popup": "popup.html" // optional
},
...
}
"action"
キー(およびその子)は省略可能です。含まれていない場合でも、拡張機能のメニューにアクセスできるように、拡張機能はツールバーに表示されます。そのため、少なくとも "action"
キーと "default_icon"
キーを常に含めることをおすすめします。
コンセプトと使用方法
UI の各部分
アイコン
アイコンは、拡張機能のツールバーのメイン画像であり、マニフェストの "action"
キーの "default_icon"
キーで設定されます。アイコンの幅と高さは 16 デバイス独立ピクセル(DIP)にする必要があります。
"default_icon"
キーは、サイズと画像パスのディクショナリです。Chrome はこれらのアイコンを使用して、使用する画像スケールを選択します。完全一致が見つからない場合は、最も近いものが選択され、画像に合わせてスケーリングされます。このため、画質に影響する可能性があります。
1.5 倍や 1.2 倍など、あまり一般的でないスケール ファクタのデバイスが増えているため、アイコンの複数のサイズを提供することをおすすめします。これにより、アイコンの表示サイズが変更される可能性があっても、拡張機能は影響を受けなくなります。ただし、1 つのサイズのみを提供する場合は、"default_icon"
キーを辞書ではなく、単一のアイコンへのパスを含む文字列に設定することもできます。
action.setIcon()
を呼び出して、別の画像パスを指定するか、HTML キャンバス要素を使用して動的に生成されたアイコンを指定することで、拡張機能のアイコンをプログラムで設定することもできます。拡張機能のサービス ワーカーから設定する場合は、オフスクリーン キャンバス API を使用します。
const canvas = new OffscreenCanvas(16, 16);
const context = canvas.getContext('2d');
context.clearRect(0, 0, 16, 16);
context.fillStyle = '#00FF00'; // Green
context.fillRect(0, 0, 16, 16);
const imageData = context.getImageData(0, 0, 16, 16);
chrome.action.setIcon({imageData: imageData}, () => { /* ... */ });
パッケージ化された拡張機能(.crx ファイルからインストールされたもの)の場合、画像は Blink レンダリング エンジンで表示できるほとんどの形式(PNG、JPEG、BMP、ICO など)で指定できます。SVG はサポートされていません。パッケージ化されていない拡張機能では PNG 画像を使用する必要があります。
ツールチップ(タイトル)
ツールチップ(タイトル)は、ユーザーがツールバーで拡張機能のアイコンにマウスポインタを合わせたときに表示されます。また、ボタンにフォーカスが当たったときにスクリーン リーダーが読み上げるユーザー補助機能テキストにも含まれます。
デフォルトのツールチップは、manifest.json
の "action"
キーの "default_title"
フィールドを使用して設定されます。action.setTitle()
を呼び出してプログラムで設定することもできます。
バッジ
アクションでは、アイコンの上に重ねて表示されるテキスト「バッジ」を任意で表示できます。これにより、アクションを更新して、拡張機能の状態に関する少量の情報(カウンタなど)を表示できます。バッジにはテキスト コンポーネントと背景色があります。スペースが限られているため、バッジのテキストは 4 文字以下にすることをおすすめします。
バッジを作成するには、action.setBadgeBackgroundColor()
と action.setBadgeText()
を呼び出してプログラムで設定します。マニフェストにデフォルトのバッジ設定はありません。バッジの色の値は、バッジの RGBA 色を構成する 0 ~ 255 の 4 つの整数の配列、または CSS の色の値を含む文字列のいずれかです。
chrome.action.setBadgeBackgroundColor(
{color: [0, 255, 0, 0]}, // Green
() => { /* ... */ },
);
chrome.action.setBadgeBackgroundColor(
{color: '#00FF00'}, // Also green
() => { /* ... */ },
);
chrome.action.setBadgeBackgroundColor(
{color: 'green'}, // Also, also green
() => { /* ... */ },
);
ポップアップ
ユーザーがツールバーの拡張機能のアクション ボタンをクリックすると、アクションのポップアップが表示されます。ポップアップには任意の HTML コンテンツを含めることができ、コンテンツに合わせて自動的にサイズが調整されます。ポップアップのサイズは 25×25 ~ 800×600 ピクセルの範囲で指定する必要があります。
ポップアップは、最初は manifest.json
ファイルの "action"
キーの "default_popup"
プロパティによって設定されます。存在する場合、このプロパティは拡張機能ディレクトリ内の相対パスを指す必要があります。また、action.setPopup()
メソッドを使用して、別の相対パスを指すように動的に更新することもできます。
ユースケース
タブごとの状態
拡張機能のアクションは、タブごとに異なる状態を持つことができます。個々のタブの値を設定するには、action
API の設定メソッドで tabId
プロパティを使用します。たとえば、特定のタブのバッジ テキストを設定するには、次のようにします。
function getTabId() { /* ... */}
function getTabBadge() { /* ... */}
chrome.action.setBadgeText(
{
text: getTabBadge(tabId),
tabId: getTabId(),
},
() => { ... }
);
tabId
プロパティが省略されている場合、設定はグローバル設定として扱われます。タブ固有の設定は、グローバル設定よりも優先されます。
有効状態
デフォルトでは、ツールバーのアクションはすべてのタブで有効(クリック可能)になっています。このデフォルトを変更するには、マニフェストの action
キーで default_state
プロパティを設定します。default_state
が "disabled"
に設定されている場合、アクションはデフォルトで無効になっており、クリック可能にするにはプログラムで有効にする必要があります。default_state
が "enabled"
(デフォルト)に設定されている場合、アクションはデフォルトで有効になり、クリック可能になります。
action.enable()
メソッドと action.disable()
メソッドを使用して、状態をプログラムで制御できます。これは、ポップアップ(存在する場合)または action.onClicked
イベントが拡張機能に送信されるかどうかにのみ影響します。ツールバーでのアクションの存在には影響しません。
例
次の例は、拡張機能でアクションが使用される一般的な方法を示しています。この API を試すには、chrome-extension-samples リポジトリから Action API のサンプルをインストールします。
ポップアップを表示する
拡張機能の動作をユーザーがクリックしたときに、ポップアップを表示する拡張機能は一般的です。独自の拡張機能でこれを実装するには、manifest.json
でポップアップを宣言し、Chrome がポップアップに表示するコンテンツを指定します。
// manifest.json
{
"name": "Action popup demo",
"version": "1.0",
"manifest_version": 3,
"action": {
"default_title": "Click to view a popup",
"default_popup": "popup.html"
}
}
<!-- popup.html -->
<!DOCTYPE html>
<html>
<head>
<style>
html {
min-height: 5em;
min-width: 10em;
background: salmon;
}
</style>
</head>
<body>
<p>Hello, world!</p>
</body>
</html>
クリック時にコンテンツ スクリプトを挿入する
拡張機能の一般的なパターンは、拡張機能のアクションを使用して、その主な機能を公開することです。次の例は、このパターンを示しています。ユーザーがアクションをクリックすると、拡張機能は現在のページにコンテンツ スクリプトを挿入します。コンテンツ スクリプトは、すべてが想定どおりに動作したことを確認するためのアラートを表示します。
// manifest.json
{
"name": "Action script injection demo",
"version": "1.0",
"manifest_version": 3,
"action": {
"default_title": "Click to show an alert"
},
"permissions": ["activeTab", "scripting"],
"background": {
"service_worker": "background.js"
}
}
// background.js
chrome.action.onClicked.addListener((tab) => {
chrome.scripting.executeScript({
target: {tabId: tab.id},
files: ['content.js']
});
});
// content.js
alert('Hello, world!');
declarativeContent でアクションをエミュレートする
この例は、拡張機能のバックグラウンド ロジックが、(a)デフォルトでアクションを無効にし、(b)declarativeContent を使用して特定サイトでアクションを有効にする方法を示しています。
// service-worker.js
// Wrap in an onInstalled callback to avoid unnecessary work
// every time the service worker is run
chrome.runtime.onInstalled.addListener(() => {
// Page actions are disabled by default and enabled on select tabs
chrome.action.disable();
// Clear all rules to ensure only our expected rules are set
chrome.declarativeContent.onPageChanged.removeRules(undefined, () => {
// Declare a rule to enable the action on example.com pages
let exampleRule = {
conditions: [
new chrome.declarativeContent.PageStateMatcher({
pageUrl: {hostSuffix: '.example.com'},
})
],
actions: [new chrome.declarativeContent.ShowAction()],
};
// Finally, apply our new array of rules
let rules = [exampleRule];
chrome.declarativeContent.onPageChanged.addRules(rules);
});
});
型
OpenPopupOptions
プロパティ
-
windowId
number 省略可
アクション ポップアップを開くウィンドウの ID。指定しない場合、デフォルトで現在アクティブなウィンドウになります。
TabDetails
プロパティ
-
tabId
number 省略可
状態をクエリするタブの ID。タブが指定されていない場合は、タブ固有ではない状態が返されます。
UserSettings
拡張機能のアクションに関連するユーザー指定の設定のコレクション。
プロパティ
-
isOnToolbar
ブール値
拡張機能のアクション アイコンがブラウザ ウィンドウの最上位ツールバーに表示されているかどうか(つまり、拡張機能がユーザーによって「ピン留め」されているかどうか)。
UserSettingsChange
プロパティ
-
isOnToolbar
ブール値(省略可)
拡張機能のアクション アイコンがブラウザ ウィンドウの最上位ツールバーに表示されているかどうか(つまり、拡張機能がユーザーによって「ピン留め」されているかどうか)。
メソッド
disable()
chrome.action.disable(
tabId?: number,
callback?: function,
): Promise<void>
タブのアクションを無効にします。
パラメータ
-
tabId
number 省略可
アクションを変更するタブの ID。
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
enable()
chrome.action.enable(
tabId?: number,
callback?: function,
): Promise<void>
タブのアクションを有効にします。デフォルトでは、アクションは有効になっています。
パラメータ
-
tabId
number 省略可
アクションを変更するタブの ID。
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
getBadgeBackgroundColor()
chrome.action.getBadgeBackgroundColor(
details: TabDetails,
callback?: function,
): Promise<extensionTypes.ColorArray>
アクションの背景色を取得します。
パラメータ
-
詳細
-
callback
関数 省略可
callback
パラメータは次のようになります。(result: ColorArray) => void
-
件の結果
-
戻り値
-
Promise<extensionTypes.ColorArray>
getBadgeText()
chrome.action.getBadgeText(
details: TabDetails,
callback?: function,
): Promise<string>
アクションのバッジ テキストを取得します。タブが指定されていない場合は、タブ固有ではないバッジのテキストが返されます。displayActionCountAsBadgeText が有効になっている場合、declarativeNetRequestFeedback 権限が存在するか、タブ固有のバッジテキストが指定されていない限り、プレースホルダ テキストが返されます。
パラメータ
-
詳細
-
callback
関数 省略可
callback
パラメータは次のようになります。(result: string) => void
-
件の結果
文字列
-
戻り値
-
Promise<string>
getBadgeTextColor()
chrome.action.getBadgeTextColor(
details: TabDetails,
callback?: function,
): Promise<extensionTypes.ColorArray>
アクションのテキストの色を取得します。
パラメータ
-
詳細
-
callback
関数 省略可
callback
パラメータは次のようになります。(result: ColorArray) => void
-
件の結果
-
戻り値
-
Promise<extensionTypes.ColorArray>
getPopup()
chrome.action.getPopup(
details: TabDetails,
callback?: function,
): Promise<string>
このアクションのポップアップとして設定された HTML ドキュメントを取得します。
パラメータ
-
詳細
-
callback
関数 省略可
callback
パラメータは次のようになります。(result: string) => void
-
件の結果
文字列
-
戻り値
-
Promise<string>
getTitle()
chrome.action.getTitle(
details: TabDetails,
callback?: function,
): Promise<string>
アクションのタイトルを取得します。
パラメータ
-
詳細
-
callback
関数 省略可
callback
パラメータは次のようになります。(result: string) => void
-
件の結果
文字列
-
戻り値
-
Promise<string>
getUserSettings()
chrome.action.getUserSettings(
callback?: function,
): Promise<UserSettings>
拡張機能のアクションに関連するユーザー指定の設定を返します。
パラメータ
-
callback
関数 省略可
callback
パラメータは次のようになります。(userSettings: UserSettings) => void
-
userSettings
-
戻り値
-
Promise<UserSettings>
isEnabled()
chrome.action.isEnabled(
tabId?: number,
callback?: function,
): Promise<boolean>
拡張機能のアクションがタブで有効になっているかどうかを示します(tabId
が指定されていない場合はグローバルで有効になっているかどうかを示します)。declarativeContent
のみを使用して有効にしたアクションは、常に false を返します。
パラメータ
-
tabId
number 省略可
有効ステータスを確認するタブの ID。
-
callback
関数 省略可
callback
パラメータは次のようになります。(isEnabled: boolean) => void
-
isEnabled
ブール値
拡張機能のアクションが有効になっている場合は true。
-
戻り値
-
Promise<boolean>
openPopup()
chrome.action.openPopup(
options?: OpenPopupOptions,
callback?: function,
): Promise<void>
拡張機能のポップアップを開きます。Chrome 118 から Chrome 126 までは、ポリシーでインストールされた拡張機能でのみ利用できます。
パラメータ
-
オプション
OpenPopupOptions 省略可
ポップアップを開くためのオプションを指定します。
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
setBadgeBackgroundColor()
chrome.action.setBadgeBackgroundColor(
details: object,
callback?: function,
): Promise<void>
バッジの背景色を設定します。
パラメータ
-
詳細
オブジェクト
-
色
文字列 | ColorArray
バッジの RGBA カラーを構成する、[0,255] の範囲の 4 つの整数の配列。たとえば、不透明な赤は
[255, 0, 0, 255]
です。CSS 値を含む文字列にすることもできます。不透明な赤は#FF0000
または#F00
です。 -
tabId
number 省略可
特定のタブが選択されている場合にのみ変更を制限します。タブを閉じると自動的にリセットされます。
-
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
setBadgeText()
chrome.action.setBadgeText(
details: object,
callback?: function,
): Promise<void>
アクションのバッジ テキストを設定します。バッジはアイコンの上に表示されます。
パラメータ
-
詳細
オブジェクト
-
tabId
number 省略可
特定のタブが選択されている場合にのみ変更を制限します。タブを閉じると自動的にリセットされます。
-
テキスト
文字列 省略可
任意の数の文字を渡すことができますが、スペースに収まるのは約 4 文字のみです。空の文字列(
''
)が渡されると、バッジのテキストがクリアされます。tabId
が指定され、text
が null の場合、指定されたタブのテキストがクリアされ、デフォルトでグローバル バッジのテキストになります。
-
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
setBadgeTextColor()
chrome.action.setBadgeTextColor(
details: object,
callback?: function,
): Promise<void>
バッジのテキストの色を設定します。
パラメータ
-
詳細
オブジェクト
-
色
文字列 | ColorArray
バッジの RGBA カラーを構成する、[0,255] の範囲の 4 つの整数の配列。たとえば、不透明な赤は
[255, 0, 0, 255]
です。CSS 値を含む文字列にすることもできます。不透明な赤は#FF0000
または#F00
です。この値を設定しないと、バッジの背景色とコントラストがつき、テキストが見えるように、色が自動的に選択されます。アルファ値が 0 に相当する色は設定されず、エラーが返されます。 -
tabId
number 省略可
特定のタブが選択されている場合にのみ変更を制限します。タブを閉じると自動的にリセットされます。
-
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
setIcon()
chrome.action.setIcon(
details: object,
callback?: function,
): Promise<void>
アクションのアイコンを設定します。アイコンは、画像ファイルへのパス、キャンバス要素のピクセルデータ、またはそれらのいずれかのディクショナリとして指定できます。path プロパティまたは imageData プロパティのいずれかを指定する必要があります。
パラメータ
-
詳細
オブジェクト
-
imageData
ImageData | object 省略可
設定するアイコンを表す ImageData オブジェクトまたは {size -> ImageData} ディクショナリのいずれか。アイコンが辞書として指定されている場合、使用される実際の画像は画面のピクセル密度に応じて選択されます。1 つの画面スペース単位に収まる画像ピクセルの数が
scale
の場合、サイズscale
* n の画像が選択されます。ここで、n は UI のアイコンのサイズです。画像を少なくとも 1 つ指定する必要があります。「details.imageData = foo」は「details.imageData = {'16': foo}」と同じです。 -
パス
string | object 省略可
設定するアイコンを指す相対画像パス、または {サイズ -> 相対画像パス} のディクショナリ。アイコンが辞書として指定されている場合、使用される実際の画像は画面のピクセル密度に応じて選択されます。1 つの画面スペース単位に収まる画像ピクセルの数が
scale
の場合、サイズscale
* n の画像が選択されます。ここで、n は UI のアイコンのサイズです。画像を少なくとも 1 つ指定する必要があります。'details.path = foo' は 'details.path = {'16': foo}' と同等です。 -
tabId
number 省略可
特定のタブが選択されている場合にのみ変更を制限します。タブを閉じると自動的にリセットされます。
-
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
Chrome 96 以降
setPopup()
chrome.action.setPopup(
details: object,
callback?: function,
): Promise<void>
ユーザーがアクションのアイコンをクリックしたときにポップアップとして開く HTML ドキュメントを設定します。
パラメータ
-
詳細
オブジェクト
-
ポップアップ
文字列
ポップアップに表示する HTML ファイルの相対パス。空の文字列(
''
)に設定すると、ポップアップは表示されません。 -
tabId
number 省略可
特定のタブが選択されている場合にのみ変更を制限します。タブを閉じると自動的にリセットされます。
-
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
setTitle()
chrome.action.setTitle(
details: object,
callback?: function,
): Promise<void>
アクションのタイトルを設定します。これはツールチップに表示されます。
パラメータ
-
詳細
オブジェクト
-
tabId
number 省略可
特定のタブが選択されている場合にのみ変更を制限します。タブを閉じると自動的にリセットされます。
-
title
文字列
マウスオーバー時にアクションで表示される文字列。
-
-
callback
関数 省略可
callback
パラメータは次のようになります。() => void
戻り値
-
Promise<void>
イベント
onClicked
chrome.action.onClicked.addListener(
callback: function,
)
アクション アイコンがクリックされると呼び出されます。アクションにポップアップがある場合、このイベントは発生しません。
onUserSettingsChanged
chrome.action.onUserSettingsChanged.addListener(
callback: function,
)
拡張機能のアクションに関連するユーザー指定の設定が変更されたときに発生します。
パラメータ
-
callback
関数
callback
パラメータは次のようになります。(change: UserSettingsChange) => void