使用flash插件來調(diào)用pc的攝像頭如何將它嵌入到TML頁(yè)面中

字號(hào):


    前言
    之所以寫這篇文章,主要是因?yàn)榻M長(zhǎng)給提的一個(gè)新的需求——使用瀏覽器調(diào)用電腦的攝像頭,來實(shí)現(xiàn)即時(shí)拍照的功能。在網(wǎng)上查了很多資料,由于這樣那樣的原因,最終選擇了使用flash插件來調(diào)用pc的攝像頭。當(dāng)然,這個(gè)需求是基于B/S架構(gòu)的,因此,就在想怎么把它嵌入到前端的HTML頁(yè)面中。
    題外話
    當(dāng)然,這里還沒有考慮到封裝,主要是先以實(shí)現(xiàn)為目的,后續(xù)工作再根據(jù)業(yè)務(wù)進(jìn)行抽象,封裝成通用的組件。好了,廢話不多說,看重點(diǎn)。
    嵌入插件
    使用 object 和 embed 標(biāo)簽
    代碼展示
    復(fù)制代碼代碼如下:
    <span><div>
    <object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
    codebase=""
    width="490" height="390" id="Untitled-1">
    <param name="allowScriptAccess" value="sameDomain" />
    <param name="movie" value="cam.swf" />
    <param name="quality" value="high" />
    <param name="bgcolor" value="#ffffff" />
    <embed src="cam.swf" quality="high" bgcolor="#ffffff" width="490" height="390" name="cam" allowScriptAccess="sameDomain"
    type="application/x-shockwave-flash" pluginspage="" />
    </object>
    </div></span>
    這種方法用到的是 Object 和 Embed 標(biāo)簽,可以看到 object 的很多參數(shù)和 embed 里面的很多屬性是重復(fù)的。瀏覽器兼容性,有的瀏覽器支持 object,有的支持 embed,這也是為什么要修改 Flash 的參數(shù)時(shí)兩個(gè)地方都要改的原因。這種方法是 Macromedia 一直以來的官方方法,最大限度的保證了 Flash 的功能,沒有兼容性問題。
    但現(xiàn)在來看,它還是存在很大問題的。
    首先,無法通過驗(yàn)證,由于為了兼容性而嵌入的 embed 標(biāo)簽是不符合 W3C 的規(guī)范的。當(dāng)然,如果你不在乎什么規(guī)范不規(guī)范,另當(dāng)別論。
    其次,微軟由于種種原因,在 sp2 后限制了 IE 的 ActiveX 的使用模式,就是在頁(yè)面中的 ActiveX 有一個(gè)虛框,需要用戶點(diǎn)擊一次才能正常交互。Flash是作為一個(gè) ActiveX 嵌入到網(wǎng)頁(yè)中的,所以它也會(huì)受牽連,只有通過 JS 嵌入 Flash 才能解決這個(gè)問題。
    再次,沒有 Flash 版本檢測(cè),如果版本瀏覽器的flash插件版本不夠,或者不能正常顯示你的 swf 文件,或者會(huì)彈出一個(gè) ActiveX 的確認(rèn)安裝的框——這個(gè)框?qū)芏嘤脩魜碚f是很恐怖的。
    只使用 object 標(biāo)簽
    代碼展示
    復(fù)制代碼代碼如下:
    <span><div>
    <object type="application/x-shockwave-flash data="c.swf?path=cam.swf" width="490" height="390">
    <param name="cam" value="c.swf?path=cam.swf" />
    <img src="defqr.png"
    width="550" height="400" />
    </object>
    </div></span>
    這種方法只用到了 Object 標(biāo)簽,其實(shí)也就是 Flash satay。由于沒有了 embed 標(biāo)簽,可以通過驗(yàn)證,是標(biāo)準(zhǔn)的嵌入 Flash 的方法,瀏覽器兼容性也不錯(cuò),看起來幾乎完美,不過還是有問題的。
    首先,需要一個(gè) holder swf 來加載你的目標(biāo) swf 以保證 IE 中的 stream 能力,如果你需要通過 flashvars 來傳參,或者和頁(yè)面的 JS 交互,會(huì)很麻煩。
    其次,和第一種方法一樣,也會(huì)彈出一個(gè)ActiveX的提示框,沒有版本檢測(cè)。
    再次,一些低版本的瀏覽器(如低版本的Safari等)不認(rèn)同這種方式,對(duì)它的兼容性不好。
    只使用 embed 標(biāo)簽
    代碼展示
    復(fù)制代碼代碼如下:
    <span><div>
    <embed id="cam" src="cam.swf" loop="false" menu="false" quality="best" bgcolor="#ffffff" width="450" height="350" name="webcam" wmode="transparent" allowscriptaccess="always" allowfullscreen="false" type="application/x-shockwave-flash" pluginspage="" flashvars="width=490&height=390&objid=cameradialog">
    </div></span>
    這種方法只用到了 Embed 標(biāo)簽,對(duì)比效果來說,還是很不錯(cuò)的,瀏覽器的兼容性也還不錯(cuò),都是可以加載的。當(dāng)然,由于 embed 標(biāo)簽是不符合 W3C 的規(guī)范的,所以也不推薦使用這種方法。
    使用JavaScript嵌入
    使用 JS 來加載 Flash 插件,網(wǎng)上已經(jīng)有很多的方法了,而且也有很多不錯(cuò)的 JS 插件供大家選擇。我這里只拿 SWFObject 來簡(jiǎn)單的介紹一下。
    首先,你需要下載一個(gè) SWFObject 插件包,該插件包中包含一個(gè) JS 腳本,這個(gè)是你需要引入的腳步文件。還包括兩個(gè) html 的例子,大家可以模仿一下。當(dāng)然,你還可以去 SWFObject 的網(wǎng)站了解一下,網(wǎng)址請(qǐng)點(diǎn)擊 這里 。
    代碼展示
    復(fù)制代碼代碼如下:
    <span><script type="text/javascript" src="swfobject.js"></script>
    <script type="text/javascript">
    swfobject.registerObject("myId", "9.0.0", "cam.swf");
    </script></span>
    復(fù)制代碼代碼如下:
    <span><div>
    <object id="myId" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="490" height="390">
    <param name="movie" value="cam.swf" />
    <!--[if !IE]>-->
    <object type="application/x-shockwave-flash" data="cam.swf" width="490" height="390">
    <!--<![endif]-->
    <div>
    <h1>Alternative content</h1>
    <p><a href="src="" /></a></p>
    </div>
    <!--[if !IE]>-->
    </object>
    <!--<![endif]-->
    </object>
    </div></span>