混合媒體

混合媒體查看器是媒體查看器。 它支援包含影像、色板集、旋轉集、視頻和自適應視頻集的媒體集。

查看器底部的縮略圖表示每個媒體集元素及其資產類型指示器。 選擇色板集元素後,將出現第二行色板,以允許在色板集內選擇顏色變化。 影像和色板集元素支援連續或串聯模式的縮放;旋轉集支援縮放和旋轉。 視頻和自適應視頻集支援所有基本的播放控制,只要視頻內容頂部顯示任何可選的隱藏字幕。 用戶可以隨時按一下全屏按鈕切換到全屏。 查看器具有可選的關閉按鈕。 它設計用於台式機和移動設備。

當基礎系統支援時,Mixed Media Viewer將HLS格式的HTML5流視頻回放使用其預設配置。 在不支援HTML5流式傳輸的系統上,查看器將返回HTML5逐步視頻傳輸。

注意

此查看器不支援使用IR(影像呈現)或UGC(用戶生成的內容)的影像。

查看器類型505。

請參閱 系統要求和先決條件

演示URL

https://s7d9.scene7.com/s7viewers/html5/MixedMediaViewer.html?asset=Scene7SharedAssets/Mixed_Media_Set_Sample

使用混合媒體查看器

混合媒體查看器表示主JavaScript檔案和一組幫助檔案(單個JavaScript包含該查看器在運行時下載的所有查看器SDK元件,該查看器由該特定查看器、資產和CSS使用)。

您可以使用隨IS-Viewers提供的生產就緒HTML頁,在彈出模式下使用混合媒體查看器。 或者,您可以在嵌入式模式下使用查看器,在該模式下,使用文檔化的API將查看器整合到目標網頁中。

配置和設定查看器外觀的任務與其他查看器類似。 所有蒙皮都是通過自定義CSS實現的。

請參閱 所有查看器通用的命令引用 — 配置屬性所有查看器通用的命令引用 — URL

與混合媒體查看器交互

混合媒體查看器支援其他移動應用程式中常見的單點觸控和多點觸控手勢。 當查看器無法處理用戶的刷卡手勢時,它會將事件轉發到Web瀏覽器以執行本機頁面滾動。 此功能允許用戶在頁面中導航,即使查看器佔據了大部分設備螢幕區域。

手勢

說明

按一下

激活彈出視圖或主縮放級別和次縮放級別之間的更改。

按兩下

連續 縮放模式,縮放一個級別,直到達到最大放大率,下一個按兩下手勢將重置為初始狀態。

觸摸並停留

縮放模式,激活縮放影像。

在連續縮放模式下,放大或縮小影像。

水準輕掃或輕拂

當當前資產是旋轉集,並且影像處於重置狀態時,它會水準旋轉旋轉該旋轉集。

當當前資產是旋轉集或影像,並且影像被放大時,它將水準移動影像。 如果影像被移動到視圖邊緣並且沿該方向繼續刷掃,則手勢執行本機頁面滾動。

在色板欄中滾動色板清單。

垂直輕掃或輕拂

如果影像處於重置狀態,則當使用多維自旋集時,它改變垂直視角。 在一維旋轉集中,或當多維旋轉集位於最後一個或第一個軸上時,使得垂直滑動不會導致垂直視角變化,該手勢執行本機頁面滾動。

當當前資產是旋轉集或影像並且影像被放大時,垂直移動影像。 如果將影像移動到視圖邊緣,並且仍沿該方向進行刷掃,則手勢將執行本機頁面滾動。

如果手勢是在色板區域內完成的,則它將執行本機頁面滾動。

該查看器還支援Windows設備上的觸摸輸入和滑鼠輸入,包括觸摸屏和滑鼠。 但是,此支援僅限於Chrome、Internet Explorer 11和Edge Web瀏覽器。

此查看器可完全以鍵盤方式訪問。

請參閱 鍵盤輔助功能和導航

嵌入混合媒體查看器

不同的網頁對查看者行為有不同的需求。 有時,網頁提供的連結在選中時會在單獨的瀏覽器窗口中開啟查看器。 在其他情況下,必須將查看器右嵌入到托管頁中。 在後一種情況下,該網頁可以具有靜態頁面佈局,或者使用響應設計,該響應設計在不同的設備上顯示不同的或針對不同的瀏覽器窗口大小。 為滿足這些需要,查看器支援三種主要操作模式:彈出式、固定大小嵌入和響應性設計嵌入。

關於彈出模式

在彈出模式下,在單獨的Web瀏覽器窗口或頁籤中開啟查看器。 它會佔用整個瀏覽器窗口區域,並在瀏覽器調整大小或移動設備的方向發生變化時進行調整。

彈出模式是移動設備中最常見的模式。 網頁使用 window.open() JavaScript調用,正確配置 A HTML元件或任何其它合適的方法。

建議您使用現成HTML頁面進行彈出操作模式。 在這種情況下,它叫 MixedMediaViewer.html 位於 html5/ 標準IS查看器部署的子資料夾:

<s7viewers_root>/html5/MixedMediaViewer.html

通過應用自定義CSS,可以實現可視化定製。

以下是在新窗口中開啟查看器的HTML代碼示例:

<a href="http://s7d1.scene7.com/s7viewers/html5/MixedMediaViewer.html?asset=Scene7SharedAssets/Mixed_Media_Set_Sample" target="_blank">Open popup viewer</a>

關於固定大小和響應性設計嵌入

在嵌入模式中,查看器被添加到現有網頁中,該網頁可能已經具有與查看器無關的一些客戶內容。 瀏覽者通常只佔用網頁的一部分房地產。

主要使用案例是面向台式機或平板電腦設備的網頁,還有響應性設計頁面,根據設備類型自動調整佈局。

當查看器在初始載入後不更改其大小時,使用固定大小嵌入。 此操作是具有靜態佈局的網頁的最佳選擇。

響應性設計嵌入假定查看器必須在運行時根據其容器的大小變化調整大小 DIV。 最常見的用例是向使用靈活頁面佈局的網頁添加查看器。

在響應性設計嵌入模式中,查看器根據網頁大小其容器的方式而具有不同的行為 DIV。 如果網頁僅設定容器的寬度 DIV在保持高度不受限制的情況下,觀看者根據所使用資產的縱橫比自動選擇其高度。 此功能可確保資產完美地貼入視圖中,而不會在側面出現任何填充。 此使用案例是使用響應性設計佈局框架(如Bootstrap或Foundation)的網頁中最常見的使用案例。

否則,如果網頁為查看者的容器設定寬度和高度 DIV,查看器僅填充該區域並遵循網頁佈局提供的大小。 一個很好的例子是將查看器嵌入到模式覆蓋中,其中覆蓋根據Web瀏覽器窗口大小進行大小調整。

固定大小嵌入

通過執行以下操作,可將查看器添加到網頁:

  1. 將查看器JavaScript檔案添加到網頁。

  2. 定義容器 DIV

  3. 設定查看器大小。

  4. 建立和初始化查看器。

  5. 將查看器JavaScript檔案添加到網頁。

    建立查看器要求在HTML頭中添加指令碼標籤。 在使用查看器API之前,請確保包括 MixedMediaViewer.js。 的 MixedMediaViewer.js 檔案位於 html5/js/ 標準IS查看器部署的子資料夾:

<s7viewers_root>/html5/js/MixedMediaViewer.js

如果查看器部署在其中一個Adobe Dynamic Media Classic伺服器上,並且從同一域提供服務,則可以使用相對路徑。 否則,您將指定到安裝了IS-Viewers的Adobe Dynamic Media Classic伺服器之一的完整路徑。

相對路徑如下所示:

<script language="javascript" type="text/javascript" src="/s7viewers/html5/js/MixedMediaViewer.js"></script>
注意

僅引用主查看器JavaScript include 檔案。 不要引用網頁代碼中任何可能在運行時由查看器邏輯下載的附加JavaScript檔案。 特別是,不直接引用HTML5 SDK Utils.js 由查看器從 /s7viewers 上下文路徑(所謂統一SDK) include)。 原因是 Utils.js 或類似的運行時查看器庫由查看器的邏輯和查看器版本之間的位置更改進行完全管理。 Adobe不保留舊版次查看器 includes 在伺服器上。

因此,直接引用任何輔助JavaScript include 該頁面上的查看器使用的瀏覽器功能將在部署新產品版本時中斷查看器功能。

  1. 定義容器DIV。

    將空的DIV元素添加到希望查看器顯示的頁面。 DIV元素必須定義其ID,因為此ID稍後會傳遞給查看器API。 DIV的大小通過CSS指定。

    佔位符DIV是定位元素,表示 position CSS屬性設定為 relativeabsolute

    確保全屏功能在Internet Explorer中正常工作。 檢查以確保DOM中沒有堆疊順序高於佔位符DIV的其他元素。

    以下是定義的佔位符DIV元素的示例:

    <div id="s7viewer" style="position:relative"></div>
    
  2. 設定查看器大小

    此查看器在處理多項集時顯示縮略圖。 在案頭系統上,縮略圖放在主視圖下方。 同時,觀看者允許在運行時使用主資產的交換 setAsset() API。 作為開發人員,您可以控制當新資產只有一個項目時查看者如何管理底部的縮略圖區域。 可以保持外部查看器大小不變,並讓主視圖增加其高度並佔用縮略圖區域。 或者,您可以保持主視圖大小為靜態,並折疊外部查看器區域,使網頁內容向上移動。 然後,使用縮略圖中剩餘的免費頁面不動產。

    要保持外部查看器邊界不變,請定義 .s7mixedmediaviewer 以絕對單位表示的頂級CSS類。 CSS中的大小調整可以放在HTML頁或自定義查看器CSS檔案中,稍後分配給Dynamic Media Classic的查看器預設記錄,或使用style命令顯式傳遞。

    請參閱 自定義混合媒體查看器 的子菜單。

    以下是在HTML頁中定義靜態外部查看器大小的示例:

    #s7viewer.s7mixedmediaviewer {
     width: 640px;
     height: 480px;
    }
    

    您可以在以下示例頁面上看到具有固定外部查看器區域的行為。 請注意,在集之間切換時,外部查看器大小不會改變:

    https://experienceleague.adobe.com/tools/dynamic-media-demo/viewers-ref/mixedmedia/MixedMediaViewer-fixed-outer-area.html?lang=zh-Hant?lang=zh-Hant

    要使主視圖尺寸保持靜態,請為內部定義以絕對單位表示的查看器尺寸 Container SDK元件使用 .s7mixedmediaviewer .s7container CSS選擇器,或使用 stagesize 修改量。

    以下是定義內部查看器大小的示例 Container SDK元件,以便在切換資產時主視圖區域不更改其大小:

    #s7viewer.s7mixedmediaviewer .s7container {
     width: 640px;
     height: 480px;
    }
    

    以下示例頁顯示具有固定主視圖大小的查看器行為。 請注意,在集之間切換時,主視圖保持靜態,網頁內容垂直移動:

    https://experienceleague.adobe.com/tools/dynamic-media-demo/viewers-ref/mixedmedia/MixedMediaViewer-fixed-main-view.html?lang=zh-Hant?lang=zh-Hant

    可以設定 stagesize 修飾符,在Dynamic Media Classic的查看器預設記錄中,或用查看器初始化代碼將其顯式傳遞 params 的下界。 或者,如本幫助的「命令參考」部分所述,作為API調用,如下所述:

    mixedMediaViewer.setParam("stagesize", "640,480");
    

    建議使用基於CSS的方法,並在本示例中使用。

  3. 建立和初始化查看器。

    完成上述步驟後,將建立 s7viewers.MixedMediaViewer 類,將所有配置資訊傳遞給其建構子和調用 init() 的子常式。 配置資訊作為JSON對象傳遞給建構子。 至少,此對象應具有 containerId 包含查看器容器ID和嵌套名稱的欄位 params JSON對象及其查看器支援的配置參數。 在這個例子中, params 對象必須至少將Image Serving URL傳遞為 serverUrl 屬性,視頻伺服器URL傳遞為 videoserverurl 及初始資產(作為 asset 的下界。 基於JSON的初始化API允許您使用單行代碼建立和啟動查看器。

    必須將查看器容器添加到DOM中,以便查看器代碼可以通過其ID查找容器元素。 某些瀏覽器將生成DOM延遲到網頁結束。 要獲得最大相容性,請調用 init() 方法 BODY 標籤,或者身上 onload() 的子菜單。

    同時,容器元素還不一定是網頁佈局的一部分。 例如,它可能隱藏在 display:none 指定的樣式。 在這種情況下,查看器將其初始化過程延遲到網頁將容器元素帶回佈局的那一刻。 當此操作發生時,查看器載入將自動恢復。

    以下是建立查看器實例、將最小必要配置選項傳遞給建構子並調用 init() 的雙曲餘切值。 該示例假定 mixedMediaViewer 是查看器實例; s7viewer 是佔位符的名稱 DIV; http://s7d1.scene7.com/is/image/ 是影像服務URL; http://s7d1.scene7.com/is/content/ 是視頻伺服器URL;和 Scene7SharedAssets/Mixed_Media_Set_Sample 是資產:

<script type="text/javascript">
var mixedMediaViewer = new s7viewers.MixedMediaViewer({
 "containerId":"s7viewer",
"params":{
 "asset":"Scene7SharedAssets/Mixed_Media_Set_Sample",
 "serverurl":"http://s7d1.scene7.com/is/image/",
 "videoserverurl":"http://s7d1.scene7.com/is/content/"
}
}).init();
</script>
<script type="text/javascript">
mixedMediaViewer.init();
</script>

以下代碼是嵌入固定大小的混合媒體查看器的普通網頁的完整示例:

<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="http://s7d1.scene7.com/s7viewers/html5/js/MixedMediaViewer.js"></script>
<style type="text/css">
#s7viewer.s7mixedmediaviewer {
 width: 640px;
 height: 480px;
}
</style>
</head>
<body>
<div id="s7viewer" style="position:relative"></div>
<script type="text/javascript">
var mixedMediaViewer = new s7viewers.MixedMediaViewer({
 "containerId":"s7viewer",
"params":{
 "asset":"Scene7SharedAssets/Mixed_Media_Set_Sample",
 "serverurl":"http://s7d1.scene7.com/is/image/",
 "videoserverurl":"http://s7d1.scene7.com/is/content/"
}
}).init();
</script>
</body>
</html>

具有無限制高度的響應嵌入

通過響應性設計嵌入,網頁通常具有某種靈活的佈局,其指示查看者容器的運行時大小 DIV。 對於以下示例,假定該網頁允許查看者的容器 DIV 以取Web瀏覽器窗口大小的40%,使其高度不受限制。 網頁HTML代碼如下所示:

<!DOCTYPE html>
<html>
<head>
<style type="text/css">
.holder {
 width: 40%;
}
</style>
</head>
<body>
<div class="holder"></div>
</body>
</html>

將查看器添加到此頁麵類似於固定大小嵌入的步驟。 唯一的區別是您不需要顯式定義查看器大小。

  1. 將查看器JavaScript檔案添加到網頁。
  2. 定義容器DIV。
  3. 建立和初始化查看器。

上述步驟與固定尺寸嵌入步驟相同。 將容器DIV添加到現有 "holder" DIV 以下代碼是一個完整的示例。 注意當瀏覽器調整大小時查看器大小如何變化,以及查看器縱橫比如何匹配資產。

<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="http://s7d1.scene7.com/s7viewers/html5/js/MixedMediaViewer.js"></script>
<style type="text/css">
.holder {
 width: 40%;
}
</style>
</head>
<body>
<div class="holder">
<div id="s7viewer" style="position:relative"></div>
</div>
<script type="text/javascript">
var mixedMediaViewer = new s7viewers.MixedMediaViewer({
 "containerId":"s7viewer",
"params":{
 "asset":"Scene7SharedAssets/Mixed_Media_Set_Sample",
 "serverurl":"http://s7d1.scene7.com/is/image/",
 "videoserverurl":"http://s7d1.scene7.com/is/content/"
}
}).init();
</script>
</body>
</html>

以下示例頁說明了具有無限制高度的響應設計嵌入在現實生活中的更多用途:

即時演示

備用演示位置

定義寬度和高度的柔性尺寸嵌入

如果定義了寬度和高度的靈活大小嵌入,則網頁樣式會有所不同。 它為 "holder" DIV並將其居中到瀏覽器窗口中。 此外,網頁還設定 HTMLBODY 元素到100%。

<!DOCTYPE html>
<html>
<head>
<style type="text/css">
html, body {
 width: 100%;
 height: 100%;
}
.holder {
 position: absolute;
 left: 20%;
 top: 20%;
 width: 60%;
height: 60%;
}
</style>
</head>
<body>
<div class="holder"></div>
</body>
</html>

其餘嵌入步驟與用於具有無限制高度的響應設計嵌入的步驟相同。 結果示例如下:

<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="http://s7d1.scene7.com/s7viewers/html5/js/MixedMediaViewer.js"></script>
<style type="text/css">
html, body {
 width: 100%;
 height: 100%;
}
.holder {
 position: absolute;
 left: 20%;
 top: 20%;
 width: 60%;
height: 60%;
}
</style>
</head>
<body>
<div class="holder">
<div id="s7viewer" style="position:relative"></div>
</div>
<script type="text/javascript">
var mixedMediaViewer = new s7viewers.MixedMediaViewer({
 "containerId":"s7viewer",
"params":{
 "asset":"Scene7SharedAssets/Mixed_Media_Set_Sample",
 "serverurl":"http://s7d1.scene7.com/is/image/",
 "videoserverurl":"http://s7d1.scene7.com/is/content/"
}
}).init();
</script>
</body>
</html>

使用基於Setter的API嵌入

可以不使用基於JSON的初始化,而是使用基於setter的API和no-args建構子。 使用此API建構子不採用任何參數,配置參數是使用 setContainerId()setParam(), setAsset() API方法,具有單獨的JavaScript調用。

以下示例說明了將固定大小嵌入與基於setter的API一起使用:

<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="http://s7d1.scene7.com/s7viewers/html5/js/MixedMediaViewer.js"></script>
<style type="text/css">
#s7viewer.s7mixedmediaviewer {
 width: 640px;
 height: 480px;
}
</style>
</head>
<body>
<div id="s7viewer" style="position:relative"></div>
<script type="text/javascript">
var mixedMediaViewer = new s7viewers.MixedMediaViewer();
mixedMediaViewer.setContainerId("s7viewer");
mixedMediaViewer.setParam("serverurl", "http://s7d1.scene7.com/is/image/");
mixedMediaViewer.setAsset("Scene7SharedAssets/Mixed_Media_Set_Sample");
mixedMediaViewer.init();
</script>
</body>
</html>

本頁內容