用JavaScript实现利用FLASH嵌入声音(一)

本JavaScipt教程将让你感受到FLASH给您带来有声世界的无穷魅力。在开始本教程之前,我先介绍一下本教程涉及到的内容:隐藏嵌入的SWF、 播放流同步的SWF、 从指定的帧上开始流、 停止和播放流、 检查是否磁道在播放、 检查是否播放器准备好、 检查SWF转载的百分比、验证SWF是否完全装载好、检查播放器的版本号、设置最小的播放器版本号、 清除错误信息等等。好吧,开始我们的教程吧。

隐藏嵌入的SWF

FlashSound的JavaScript API往网页插入一个FlashSound对象,随同插入还有embedSWF()方法。但是在网页中我们为什么不能看到这个对象呢?哦,原来是FlashSound隐藏了这个对象。在Internet浏览器中,FlashSound是这个对象变得透明,也就是说你看不到这个对象,但实际上它是存在的。而在Netscape浏览器中,这个对象的颜色被指定为跟网页相同的颜色,所以你也看不到它。你可以在Netscape浏览器中通过使用bgcolor属性来设置对象的颜色。以上两种方法正是隐藏对象的核心所在。试一试吧,下面我的代码是实现当鼠标移过对象时播放scale.swf文件,所以我们这样来创建FlashSound对象:

1<script>   
2  
3mySoundObj.bgcolor = "#0000ff";   
4  
5mySoundObj.embedSWF("scale.swf");   
6  
7</script>

下面的代码可以让你在Netscape浏览器中看到在“Play a Scale”下面有一个小点,它正是我们创建的FlashSound,因为此时它的颜色不是与网页的背景色相同,看看代码吧:

 1<html>
 2<head>
 3<script src="flashsound.js"></script>
 4<script>   
 5  
 6var mySoundObj = new FlashSound();   
 7  
 8</script>
 9</head>
10<body>
11<p><a href="javascript://" onmouseover="mySoundObj.TGotoAndPlay('/scale-event', 'start')">   
12  
13Play a Scale</a>
14<script>   
15  
16mySoundObj.bgcolor = "#0000ff";   
17  
18mySoundObj.embedSWF("scale.swf");   
19  
20</script>   
21  
22播放流同步的SWF   
23  
24Flash文件格式支持四种同步的类型:Event(事件)、Start(开始)Stop(停止)和Stream(流)。事件同步允许你同时播放多个磁道的声音;开始同步可以避免并行的磁道播放;停止同步作用是停止磁道播放;而对于流同步声音包含了声音的帧尺寸样式,它可以反复地天衣无缝地播放。不象其它真实的流声音格式(比如Real Audio),Flash流文件是在播放的时候装载到浏览器中去的。当播放结束的时候,这个流声音就全部被装载浏览器的高度缓冲区中。所以在接下去的播放是来源与浏览器的告诉缓冲区,而不是来源于网页。   
25  
26以下的连接是播放一个流同步,它解释了FlashSound的JavaScript API,代码如下:   
27  
28<html>
29<head>
30<script src="flashsound.js"></script>
31<script>   
32  
33var mySoundObj = new FlashSound();   
34  
35</script>
36</head>
37<body>
38<script>   
39  
40mySoundObj.embedSWF("earsonly.swf");   
41  
42</script>
43</body>
44</html>   
45  
46这里值得注意的是Flash声音被设置在Flash编辑器中来自动开始播放。</p></body></html>
Published At
Categories with 网页设计
comments powered by Disqus