レスポンシブ画像ライブラリを Web ページに追加し、ライブラリを使用して既存の画像を管理するには、次の手順を実行します。
レスポンシブ画像ライブラリを使用するには
Dynamic Media Classicでは、 画像プリセットの作成 レスポンシブ画像ライブラリをプリセットで使用する予定の場合。
レスポンシブ画像ライブラリで使用する画像プリセットを定義する際に、画像サイズに影響を与える設定(例: )を使用しないでください。 wid=
, hei=
または scl=
. 画像プリセットでサイズフィールドを指定しないでください。 代わりに、空白の値のままにします。
ライブラリの JavaScript ファイルを Web ページに追加します。
ライブラリ API を使用する前に、次を必ず含めてください: responsive_image.js
. この JavaScript ファイルは、 libs/
標準の IS-Viewers デプロイメントのサブフォルダー
<s7viewers_root>/libs/responsive_image.js
既存の画像を設定します。
ライブラリは、作業中の画像インスタンスから特定の設定属性を読み取ります。 属性を s7responsiveImage
このような画像に対して API 関数が呼び出されます。
また、既存の画像 URL を data-src
属性。 次に、 src
の属性には、1 x 1GIFの画像をデータ URI としてエンコードする必要があります。 これにより、読み込み時に Web ページから送信される HTTP リクエストの数が減ります。 ただし、SEO(検索エンジン最適化)が必要な場合は、 title
属性を画像インスタンスに設定します。
次に、 data-breakpoints
属性を指定し、データ URI としてエンコードされた 1 x 1GIFを使用します。
<img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" data-src="https://s7d9.scene7.com/is/image/Scene7SharedAssets/Backpack_B" data-breakpoints="360,720,940">
を s7responsiveImage
ライブラリが管理するすべての画像インスタンスの API 関数。
を s7responsiveImage
ライブラリが管理するすべての画像インスタンスの API 関数。 この呼び出しの後、ライブラリでは、元の画像が、 IMG
要素を選択し、デバイスの画面の密度を指定します。
次のコードは、 s7responsiveImage
画像の API 関数 ( responsiveImage
はその画像の ID です。
<script type="text/javascript">
s7responsiveImage(document.getElementById("responsiveImage"));
</script>
このライブラリは、Web ページ上の多くの画像インスタンスの同時操作をサポートします。 したがって、ライブラリで管理する画像ごとに、上記の手順 1 と 2 を繰り返します。
画像要素のサイズを柔軟に設定できるようにするには、Web ページでのスタイル設定をおこなう必要があります。 レスポンシブ画像ライブラリ自体は、固定サイズの画像と「流動的」な画像を区別しません。 固定サイズの画像に適用した場合、新しい画像は 1 回だけ読み込まれます。
次のコードは、レスポンシブ画像ライブラリで管理される単一の流体画像を持つ簡単な Web ページの例です。 この例には、Web ブラウザーのウィンドウサイズに対して画像を「レスポンシブ」にする追加の CSS スタイルが含まれています。
<!DOCTYPE html>
<html>
<head>
<style type="text/css">
.container {
width: 50%;
}
.fluidimage {
max-width: 100%;
}
</style>
</head>
<body>
<div class="container">
<img id="responsiveImage" src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" data-src="https://s7d9.scene7.com/is/image/Scene7SharedAssets/Backpack_B" data-breakpoints="200,400,600,800" class="fluidimage">
</div>
<script type="text/javascript" src="https://s7d9.scene7.com/s7viewers/libs/responsive_image.js"></script>
<script type="text/javascript">
s7responsiveImage(document.getElementById("responsiveImage"));
</script>
</body>
</html>
スマート切り抜きの使用
AEM 6.4 およびDynamic Mediaビューア 5.9 では、2 つのスマート切り抜きモードを使用できます。
スマート切り抜きモードを使用するには、 data-mode
属性 smart crop
. 例:
<img
src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7"
data-src="https://imageserver.com/is/image/ExampleCo/SmartCropAsset"
data-mode="smartcrop">
関連する画像要素は、 s7responsiveViewer
イベントを設定します。
responsiveImage.addEventListener("s7responsiveViewer", function (event) {
var s7event = event.s7responsiveViewerEvent;
if(s7event.type == "breakpointchanged") {
console.log("New width: " + s7event.width);
console.log("Old width: " + s7event.oldWidth);
}
});