画像の表示
画像を表示することは非常に一般的なユース・ケースであり、Retoolで画像を表示する方法もたくさんあります。ここでは、次の事項を説明します。
- Imageコンポーネント
- Textコンポーネント
- Tableコンポーネント
- 画像サイズの変更
URLやBase64文字列を介して画像を表示する方法についても説明します。
Imageコンポーネント
URLを介した表示
Retoolで画像を表示する方法として最も簡単なものはURLを介して表示することです。最初に、画像コンポーネントをキャンバス(またはコンテナ、タブ付きコンテナなど)にドラッグします。コンポーネントをクリックすると、サイドバーに「Image URL」フィールドが表示されます。
URLを直接ハードコードしたり、波括弧({{ }}
)で囲んだJavaScriptを使用して画像を参照することができます。例えば、テーブルを使用しており、選択した行の「image」列を参照したい場合には、画像コンポーネントで{{ table1.selectedRow.data.image }}
と記述します。
Base64文字列を介した表示
Retoolの画像コンポーネントは表示するURLを取り込みますが、Base64文字列を使用することもできます。画像コンポーネントをキャンバスにドラッグします。
追加した画像コンポーネントをクリックして、画面右側にあるサイドバーの「Image URL」フィールドに移動します。URLの代わりに、先頭に正しい記述子が追加されたBase64の文字列を追加します。例ではJPEG形式の鏡の写真を用意しました。Base64の文字列の先頭にdata:image/jpeg;base64,
を追加します。
Base64の文字列全体は非常に長いため、ここで貼り付けることはできませんが、冒頭の部分は/9j/4AAQSkZJRgABAQAAAQABAAD/2
のようになります。この文字列の先頭に、先ほどの記述子を追加すると、...
のようになります。そして、画像コンポーネントの「Image URL」フィールドに文字列を記述します。
すべての手順が問題なく完了すると、画像コンポーネントが更新され、鏡が表示されます。
Base64の画像文字列をクエリーで取得する場合は、先頭に追加する記述子を{{}}
で囲みます。このとき、文字列を正しく連結してください。データベースに画像のBase64文字列をimageString
として保存している場合、「Image URL」フィールドに{{ "data:image/jpeg;base64," + imageString }}
と記述します。imageString
をテーブルからまたはクエリーで取得する場合には、{{ "data:image/jpeg;base64," + table.data.imageString }}
または{{ "data:image/jpeg;base64," + query.data.imageString }}
に変更します。
Textコンポーネント
「Render as HTML」トグルを使用して、Textコンポーネント内に画像を表示することもできます。最初に、テキスト・コンポーネントをキャンバスにドラッグします。
画像(または画面右側のサイドバーの「Inspector」タブ)をクリックして、「Render as HTML」パラメーターをオンにします。
「Value」フィールドに画像タグ(<img>
)を追加すると、そのsrc=
フィールドにURLやBase64の文字列などを記述することができます。Base64の文字列を記述したい場合、上記と同じBase64文字列への参照をsrc=
に記述します。鏡の写真の場合は、<img src="...">
と記述します。テーブルからまたはクエリーで取得した画像を参照する場合には、<img src={{ "data:image/jpeg;base64," + query.data.imageString }}>
のように記述します。
Tableコンポーネント
Tableコンポーネントで画像を表示する場合にも、「Render as HTML」形式を使用することができます。クエリーを使用して(ここでは{{ query1.data }}
とします)、テーブルにデータを取り込んだ後に、各列のトグルをオンにしてクエリー結果をHTMLとして表示することができます。テーブル・コンポーネントをクリックします。そして画面右側のサイドバーに移動し、画像が含まれている列をクリックします。
上述のTextコンポーネントの場合と同様に、表示したい画像のURLがある場合には<img src={{ imageURL }}">
と記述し、Base64で画像を参照する場合には<img src={{ "data:image/jpeg;base64," + imageString }}>
と記述します。ただし、テーブル・コンポーネントでは、現在の列を参照するときにself.
プロパティを使用します。そのため、「Mapper」フィールドに入力する値を<img src={{ "data:image/jpeg;base64," + self.imageString }}>
としてください。これにより、全体ではなく、現在選択しているセルのプロパティを参照するようになります。
画像サイズの変更
Imageコンポーネントの場合
画像コンポーネントを使用している場合、画像サイズはコンポーネントのサイズに応じて変わります。そのため、画像を大きくしたい場合は、画像の角を外向きにドラッグし、画像を小さくしたい場合は、画像の角を内向きにドラッグします。現在Retoolでは、表示される画像の幅と高さをImageコンポーネントでユーザーが設定することはできません。
TextコンポーネントおよびTableコンポーネントの場合
TextコンポーネントまたはTableコンポーネントで、HTMLを介して画像を表示している場合は、そのHTMLで画像の幅と高さを設定することができます。TextコンポーネントのValueフィールドへの記述例を、以下に示します。
<img src="your-url.com/image" width="200px" height="200px">
また、パーセントで記述することもできます。
<img src="your-url.com/image" width="80%" height="80%">
パーセント値は、画像のコンテナ(使用中のTextコンポーネントまたはTableコンポーネント)に対する割合として評価されます。
Updated over 3 years ago