混合媒体 mixed-media
混合媒体查看器是媒体查看器。 它支持包含图像、样本集、旋转集、视频和自适应视频集的媒体集。
查看器底部的缩略图表示每个媒体集元素及其资源类型指示器。 当选择样本集元素时,会出现第二行样本以允许选择样本集中的颜色变化。 图像和样本集元素支持在连续或内联模式下缩放;旋转集支持缩放和旋转。 视频和自适应视频集支持所有基本播放控件,前提是任何可选的隐藏式字幕都显示在视频内容上方。 用户可通过单击全屏按钮随时切换到全屏。 查看器具有可选的关闭按钮。 它设计为可在台式机和移动设备上工作。
只要基础系统支持,混合媒体查看器就会在其默认配置中使用HLS格式的HTML5流视频播放。 在不支持HTML5流式传输的系统上,查看器回退到HTML5渐进式视频交付。
查看器类型505。
请参阅系统要求和先决条件。
演示URL section-e1c3106f5b3e445d9b95be337c2f94e2
使用混合媒体查看器 section-f21ac23d3f6449ad9765588d69584772
混合媒体查看器表示一个主JavaScript文件和一组帮助程序文件(单个JavaScript包含此特定查看器使用的所有Viewer SDK组件、资源、CSS),这些文件由查看器在运行时下载。
您可以使用随IS-Viewers提供的生产就绪型HTML页,在弹出模式下使用混合媒体查看器。 或者,您可以在嵌入模式下使用查看器,在该模式下,使用文档记录的API将其集成到目标网页中。
配置查看器和为其设置外观的任务与其他查看器的任务类似。 所有外观设计都是通过自定义CSS实现的。
查看所有查看者通用的命令引用 — 配置属性和所有查看者通用的命令引用 — URL
与混合媒体查看器交互 section-ab66eb6955aa4a8aa6d14a3b3acfed3f
混合媒体查看器支持在其他移动设备应用程序中常见的单点触控和多点触控手势。 当查看器无法处理用户的轻扫手势时,它将事件转发给Web浏览器以执行本机页面滚动。 此功能允许用户在页面中导航,即使查看者占据设备屏幕区域的大部分。
当当前资源为旋转集并且图像处于重置状态时,它将水平旋转旋转旋转集。
当当前资源是旋转集或图像并且图像被放大时,它水平移动图像。 如果图像被移动到视图边缘并且仍沿该方向滑动,则手势执行本机页面滚动。
在样本栏中滚动样本列表。
如果图像处于复位状态,则当使用多维旋转集时,它改变垂直视角。 在一维旋转集中,或者当多维旋转集位于最后一个或第一个轴上以便垂直滑动不会导致垂直视角改变时,该手势执行本机页面滚动。
如果当前资源是旋转集或图像,并且放大了图像,则会垂直移动图像。 如果将图像移动到视图边缘并且仍沿该方向轻扫,则手势将执行本机页面滚动。
如果该手势在样本区域内完成,则会执行本机页面滚动。
该查看器还支持在带有触摸屏和鼠标的Windows设备上输入触摸和鼠标。 但是,此支持仅适用于Chrome、Internet Explorer 11和Edge Web浏览器。
此查看器可使用键盘完全访问。
请参阅键盘辅助功能和导航。
嵌入混合媒体查看器 section-6bb5d3c502544ad18a58eafe12a13435
不同的网页对查看者的行为具有不同的需求。 有时,网页会提供一个链接,选中该链接后,会在单独的浏览器窗口中打开查看器。 在其他情况下,需要直接将查看器嵌入到托管页面中。 在后一种情况下,网页可能具有静态页面布局,或者使用响应式设计,该设计在不同的设备上或对于不同的浏览器窗口大小显示不同。 为了满足这些需求,查看器支持三种主要操作模式:弹出窗口、固定大小嵌入和响应式设计嵌入。
关于弹出模式 section-77d5aa03b8b94566958a179b1a2cd474
在弹出模式下,查看器将在单独的Web浏览器窗口或选项卡中打开。 它采用整个浏览器窗口区域,并在浏览器调整大小或移动设备的方向更改时进行调整。
弹出模式是移动设备中最常见的一种模式。 该网页使用window.open()
JavaScript调用、正确配置的A
HTML元素或任何其他合适的方法加载查看器。
建议您为弹出操作模式使用现成的HTML页面。 在这种情况下,该文件夹名为MixedMediaViewer.html,位于标准IS-Viewers部署的html5/子文件夹中:
<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>
关于固定大小和响应式设计嵌入 section-ec86b100ba5943d0b16694268520bbde
在嵌入模式下,查看器将添加到现有网页,这些网页可能已有一些与查看器无关的客户内容。 查看者通常只占用网页不动产的一部分。
主要用例是面向台式机或平板电脑设备的网页,以及根据设备类型自动调整布局的响应式设计页面。
当查看器在初始加载后未更改其大小时,使用固定大小嵌入。 此操作是拥有静态布局的网页的最佳选择。
响应式设计嵌入假定查看器必须在运行时调整大小以响应其容器DIV
的大小更改。 最常见的用例是将查看器添加到使用灵活页面布局的网页。
在响应式设计嵌入模式下,查看器的行为方式有所不同,具体取决于网页调整其容器DIV
大小的方式。 如果网页仅设置容器DIV
的宽度,而不限制其高度,则查看器会根据所用资源的长宽比自动选择其高度。 此功能可确保资产完全适合视图,不会出现任何边距。 此用例最常见于使用响应式设计布局框架(如Bootstrap或基础)的网页。
否则,如果网页同时设置了查看器容器DIV
的宽度和高度,则查看器仅填充该区域,并遵循网页布局提供的大小。 一个很好的示例是将查看器嵌入到模式叠加中,其中叠加根据Web浏览器窗口大小调整大小。
固定大小嵌入 section-17d162f76ffa4804b27928f51e7bea1d
通过执行以下操作将查看器添加到网页:
-
正在将查看器JavaScript文件添加到您的网页。
-
正在定义容器
DIV
。 -
设置查看器大小。
-
创建和初始化查看器。
-
正在将查看器JavaScript文件添加到您的网页。
创建查看器需要您在HTML头中添加脚本标记。 在使用查看器API之前,请确保包括MixedMediaViewer.js。 MixedMediaViewer.js文件位于标准IS-Viewers部署的html5/js/子文件夹下:
<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>
include
文件。 请勿在网页代码中引用任何其他JavaScript文件,这些文件可能由查看器的逻辑在运行时下载。 特别是,请勿直接引用查看器从/s7viewers
上下文HTML加载的库SDK Utils.js
库(所谓的统一SDK include
)。 原因是Utils.js
或类似的运行时查看器库的位置完全由查看器的逻辑管理,并且查看器版本之间的位置会发生变化。 Adobe不会在服务器上保留旧版本的辅助查看器includes
。include
会破坏查看器功能。-
定义容器DIV。
向要显示查看器的页面添加一个空DIV元素。 DIV元素必须定义其ID,因为此ID稍后将传递到查看器API。 DIV的大小通过CSS指定。
占位符DIV是定位元素,这意味着
position
CSS属性设置为relative
或absolute
。确保全屏功能在Internet Explorer中正常工作。 检查以确保DOM中没有其他元素的栈叠顺序高于占位符DIV。
以下是定义的占位符DIV元素的示例:
code language-html <div id="s7viewer" style="position:relative"></div>
-
设置查看器大小
此查看器在处理多项目集时显示缩略图。 在桌面系统上,缩览图位于主视图的下方。 同时,查看器允许在运行时使用
setAsset()
API交换主资源。 作为开发人员,当新资产只有一个项目时,您可以控制查看器管理底部缩略图区域的方式。 可以保持外部查看器大小不变,并允许主视图增加其高度并占据缩略图区域。 或者,您可以保持主视图大小为静态并折叠外部查看器区域,使网页内容向上移动。 然后,使用缩略图上留下的自由页房地产。要保持外部查看器边界不变,请定义
.s7mixedmediaviewer
顶级CSS类的大小(以绝对单位表示)。 CSS的大小调整可直接放置在HTML页面或自定义查看器CSS文件中,并稍后分配给Dynamic Media Classic中的查看器预设记录,或使用style命令显式传递。有关使用CSS设置查看器样式的详细信息,请参阅自定义混合媒体查看器。
以下是在HTML页中定义静态外部查看器大小的示例:
code language-html #s7viewer.s7mixedmediaviewer { width: 640px; height: 480px; }
您可以在下面的示例页面上看到带有固定外部查看器区域的行为。 请注意,在组之间切换时,外部查看器大小不会更改:
要使主视图维度为静态维度,请使用
.s7mixedmediaviewer .s7container
CSS选择器或使用stagesize
修饰符以绝对单位定义内部Container
SDK组件的查看器大小。下面是定义内部
Container
SDK组件的查看器大小的示例,以便主视图区域在切换资产时不会更改其大小:code language-html #s7viewer.s7mixedmediaviewer .s7container { width: 640px; height: 480px; }
以下示例页面显示了固定主视图大小的查看器行为。 请注意,在页面集之间切换时,主视图将保持静态状态,网页内容将垂直移动:
您可以在Dynamic Media Classic中的查看器预设记录中设置
stagesize
修饰符,或通过params
集合显式传递查看器初始化代码。 或者,作为一个API调用,如本帮助的命令参考部分中所述,如下所示:code language-html mixedMediaViewer.setParam("stagesize", "640,480");
此示例中建议并使用基于CSS的方法。
-
创建和初始化查看器。
完成上述步骤后,创建
s7viewers.MixedMediaViewer
类的实例,将所有配置信息传递到其构造函数,并在查看器实例上调用init()
方法。 配置信息作为JSON对象传递给构造函数。 此对象至少应具有containerId
字段,该字段包含查看器容器ID的名称,并嵌套params
JSON对象以及查看器支持的配置参数。 在这种情况下,params
对象必须至少将图像服务URL作为serverUrl
属性传递,将视频服务器URL作为videoserverurl
属性传递,并将初始资产作为asset
参数传递。 基于JSON的初始化API允许您通过一行代码创建和启动查看器。必须将查看器容器添加到DOM,以便查看器代码可以按其ID查找容器元素。 某些浏览器会延迟构建DOM,直到网页结尾。 要获得最大兼容性,请在结束
BODY
标记之前或主体onload()
事件上调用init()
方法。同时,容器元素还不一定是网页布局的一部分。 例如,可以使用分配给它的
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>
高度不受限制的响应式嵌入 section-056cb574713c4d07be6d07cf3c598839
通过响应式设计嵌入,网页通常具有某种灵活的布局,可指定查看器容器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>
将查看器添加到此类页面与嵌入固定大小的步骤类似。 唯一的区别是,您不需要显式定义查看器大小。
- 正在将查看器JavaScript文件添加到您的网页。
- 定义容器DIV。
- 创建和初始化查看器。
上述所有步骤与嵌入固定大小相同。 将容器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>
以下示例页面说明了高度不受限制的响应式设计嵌入的更多实际用途:
定义宽度和高度的灵活大小嵌入 section-0a329016f9414d199039776645c693de
如果定义了宽度和高度的灵活大小嵌入,则网页样式会不同。 它为"holder"
DIV提供两种大小,并将其放在浏览器窗口中居中。 此外,网页将HTML
和BODY
元素的大小设置为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进行嵌入 section-af26f0cc2e5140e8a9bfd0c6a841a6d1
可以使用基于setter的API和no-args构造函数,而不是使用基于JSON的初始化。 使用此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>