Java多媒體框架設(shè)計(jì)自動(dòng)播放機(jī)_JSP教程
推薦:如何實(shí)現(xiàn)javabean的屬性拷貝在struts的實(shí)踐過程中,經(jīng)常兩個(gè)javabean交換數(shù)據(jù)的情況,如ActionForm與數(shù)據(jù)庫(kù)中的表相關(guān)的bean交換數(shù)據(jù)。通常情況下要寫很多get和set語句,一個(gè)個(gè)屬性依次拷貝。這樣的話,如此重復(fù)繁重的工
如果把Java媒體框架(http://java.sun.com/jmf)看作客戶端安裝的媒體播放機(jī)的話,那么這種框架并不是非常激動(dòng)人心。它只支持少量媒體類型,并且事實(shí)上這些媒體類型都被象Windows媒體播放機(jī)以及QuickTime等其它的應(yīng)用程序支持。
但是從內(nèi)容供應(yīng)商的觀點(diǎn)來看,下面這個(gè)事實(shí)更加有意義:JMF在所有的Java類型中都可用,這使在客戶端上不必要有任何特定的媒體技術(shù)就可以部署媒體--所需要的只是J2SE Java運(yùn)行時(shí)間。
更重要的是它能利用.jar文件格式的一些性能把解碼器和媒體組成到一個(gè)文件中,創(chuàng)建一個(gè)"自我播放電影",使用了象WinZip和StuffIt這樣的壓縮應(yīng)用程序大致相同的方式來創(chuàng)建自我展開文檔。
我們把此分為三個(gè)階段:
1.使JMF能夠播放.jar文件中的媒體。
2.只使用需要播放本地媒體所需的JMF的一部分創(chuàng)建一個(gè)輕量級(jí).jar文件。
3.將代碼和媒體放入.jar文件,并且創(chuàng)建一個(gè)合適的manifest文檔以使它可以雙擊。
基本的JMF播放的關(guān)鍵是獲得Player,能解碼和渲染你的媒體。一般來說,這通過使用Manager獲得合適的DataSource來完成,在一個(gè)播放實(shí)例中提供了媒體流和流元數(shù)據(jù),例如媒體格式。Manager然后找到一個(gè)Player來處理DataSource。在兩種情況下,Manager結(jié)合一個(gè)帶有程序包前綴列表(象javax.media、com.ibm.media等等)的反射方案來試圖尋找合適的類,例如如果一個(gè)計(jì)劃的播放程序不能接受提供給它的DataSource,那么它就會(huì)拋出異常。
Manager沒有太多事要做,只是察看一下URL中的協(xié)議和文件擴(kuò)展名,所以雖然它可以很容易的知道如何處理file:///Users/cadamson/mymp3stash/some.mp3,但是它不知道如何處理象jar:file:/Users/cadamson/dev/jmftests/spmovie-old/src/gatsbymovie.jar!/movie/themovie.mov這樣的URL。
為了緩和這種情況,我們可以寫一個(gè)DataSource,說得更準(zhǔn)確一點(diǎn)就是一個(gè)PullDataSource,擔(dān)負(fù)為Manager描述細(xì)節(jié)的責(zé)任。JarEntryDataSource中沒有一個(gè)方法特別難;我們提供的PullSourceStream還需要實(shí)現(xiàn)幾個(gè)超級(jí)接口。
它有些不夠完美,但是這個(gè)類依靠文件擴(kuò)展名來返回"內(nèi)容類型"。這多多少少有點(diǎn)象一個(gè)MIME類型,除了使用句號(hào)代替斜線符號(hào)來格式化以外,所以它可被用于程序包名稱(例如video/mpeg MIME類型變成video.mpeg,所以Manager可以找到com.sun.media.codec.video.mpeg包)。下面是我們的簡(jiǎn)單的實(shí)現(xiàn):
public String getContentType() { try { URL url = getLocator().getURL(); String urlFile = url.getFile(); if (urlFile.endsWith(".mov")) return "video.quicktime"; else if (urlFile.endsWith(".mpg")) return "video.mpeg"; else if (urlFile.endsWith(".avi")) // Manager needs '_' insted of '-' return "video.x_msvideo"; else return "unknown"; } catch (MalformedURLException murle) { return "unknown"; } }
另一個(gè)煩惱是JMF源代碼表明如果提供的流是Seekable的話(這是一個(gè)提供隨機(jī)存取seek()方法的接口),默認(rèn)Player只能播放一個(gè)QuickTime DataSource。如果尋找點(diǎn)在流的非常上流的地方,那么JarEntryDataSource中的策略是使用InputStream.skip()。如果尋找點(diǎn)在當(dāng)前讀取點(diǎn)之后(調(diào)用tellPoint,因?yàn)樗闹低ㄟ^Seekable.tell ()方法返回),然后它必須關(guān)閉InputStream,再重新打開,跳到尋找點(diǎn)。它使用一個(gè)內(nèi)部的thoroughSkip()方法來確定我們實(shí)際上停在哪里。
public long seek (long position) { try { if (position > tellPoint) { thoroughSkip (position - tellPoint); } else { close(); open(); thoroughSkip (position); } return tellPoint; } catch (IOException ioe) { return 0; // bogus... } }
使用這個(gè)類,Manager可以找到一個(gè)可用的Player用于播放.jar文件中的.mov或者.avi文件。我們的示例的TinyPlayer使用ClassLoader.getResource ()方法來在類路徑中尋找movie/themovie.mov或者movie/themovie.avi。當(dāng)類路徑只包含.jar文件的時(shí)候,我們將對(duì)其進(jìn)行設(shè)置。
準(zhǔn)備一個(gè)合適的.jar文件中的第一步是使用JMF的jmfcustomizer工具來創(chuàng)建一個(gè)jar,只使用播放我們的媒體所需要類,去掉用于流、捕捉、譯碼和其它對(duì)于一個(gè)簡(jiǎn)化的播放程序不需要的函數(shù)。不幸的是,Sun在各種Java版本的JMF中都不包含jmfcustomizer的幫助文件,但是各種定制屏幕很容易設(shè)計(jì)出來:
1.媒體源和媒體匯點(diǎn):選擇"媒體文件"和"播放"。
2.協(xié)議:只是"文件"。
3.源媒體格式:"QuickTime (.mov)"和"Avi"。
4.解碼器:無論你計(jì)劃在你的媒體中使用什么解碼器,但是用于音頻的大部分都是"A - law"、"U - law"或"IMA4",用于視頻的是"H263"。不要為編碼器、封包器和解包器而費(fèi)心。
5.渲染:在音頻中,我們需要"JavaSound"用于Java 1.3及1.3以上的版本,SunAudio用于Sun的pre-1.3 JVM。對(duì)于視頻,我們只需要AWT。
其結(jié)果是本來用于我們的播放器的jar被從1.9 MB壓縮到700K。
假定你已經(jīng)編譯了兩個(gè)com.mac.invalidname.spmovie類,把它們添加到定制的jar中:
jar uf customized.jar com/mac/invalidname/spmovie/*.class
JMF的許可證有效期需要它的readme文件使用任何JMF或者定制子集來分布。我已經(jīng)在misc目錄中提供了,在TinyPlayer的菜單項(xiàng)可以找到它:
jar uf customized.jar misc/
為了使這個(gè).jar文件可雙擊,我們提供一個(gè)manifest文件告訴Java運(yùn)行時(shí)間在.jar文件中的哪個(gè)類中有在雙擊或者使用簡(jiǎn)單jar命令行變量的時(shí)候調(diào)用的main()方法。manifest還提供一個(gè)只包含jar自己的類路徑:
Main-Class: com.mac.invalidname.spmovie.TinyPlayer
Class-Path: .
這個(gè)manifest使用下面的命令來添加:
jar ufm customized.jar manifest-stub.txt
這個(gè)文件現(xiàn)在有用于播放jar中的一個(gè)電影的所有的代碼。為了將來之用,請(qǐng)把它保存為spmovie-engine.jar文件,或者類似的文件。
現(xiàn)在引擎已經(jīng)具備了,我們所需要的只有媒體了。正如你可從JMF支持類型頁(yè)面看到的那樣,所有Java版本的JMF有一個(gè)相當(dāng)有限的所支持解碼器的集合。對(duì)于視頻來說最好的選擇可能是H.263,在很廣泛的比特率下能夠工作的很好,然而它可能在老機(jī)器上會(huì)執(zhí)行得很困難,除非你壓縮視頻或者保持較低的幀速率。雖然音頻較少是事先準(zhǔn)備好的,但是我想IMA 4:1執(zhí)行得相當(dāng)好。適當(dāng)?shù)鼐幋a或者譯碼你的媒體,并且把它復(fù)制為movie/themovie.mov或者movie/themovie.avi。如果你喜歡你也可以把.jar文件改名(我使用spmovie.jar)并且添加媒體:
jar u0f spmovie.jar media/
注意這里的"0"是數(shù)字零,而不是字母O;這表明我們不想壓縮這個(gè)輸入項(xiàng),因?yàn)槲覀兊拿襟w已經(jīng)被壓縮了。
千辛萬苦,我們的自我播放電影終于做成了,這個(gè)文件知道在雙擊的時(shí)候運(yùn)行什么類,提供了多路解編、解碼和渲染一部電影所需的所有的代碼,以及電影本身。如果你想看看這種小型自我播放電影,你可以去看看。
它擴(kuò)展了小應(yīng)用程序的概念,允許媒體在任何可用于Java的瀏覽器中播放。
說白了,它是一個(gè)Java虛擬機(jī)而不是媒體播放機(jī)。但是我們這種"一次編輯,到處播放"的思想是完全符合Java的原先的目的的。
分享:JSF和Struts框架的錯(cuò)誤控制與封裝處理在struts中,通常采用的全局錯(cuò)誤控制模式是構(gòu)建一個(gè)baseAction,在其execute方法中完成前臺(tái)傳回方法的dispatch操作,并由 try……catch……捕獲程序錯(cuò)誤,實(shí)現(xiàn)錯(cuò)誤的控制和展示。一個(gè)典型的B
- jsp response.sendRedirect不跳轉(zhuǎn)的原因分析及解決
- JSP指令元素(page指令/include指令/taglib指令)復(fù)習(xí)整理
- JSP腳本元素和注釋復(fù)習(xí)總結(jié)示例
- JSP FusionCharts Free顯示圖表 具體實(shí)現(xiàn)
- 網(wǎng)頁(yè)模板:關(guān)于jsp頁(yè)面使用jstl的異常分析
- JSP頁(yè)面中文傳遞參數(shù)使用escape編碼
- 基于jsp:included的使用與jsp:param亂碼的解決方法
- Java Web項(xiàng)目中連接Access數(shù)據(jù)庫(kù)的配置方法
- JDBC連接Access數(shù)據(jù)庫(kù)的幾種方式介紹
- 網(wǎng)站圖片路徑的問題:絕對(duì)路徑/虛擬路徑
- (jsp/html)網(wǎng)頁(yè)上嵌入播放器(常用播放器代碼整理)
- jsp下顯示中文文件名及絕對(duì)路徑下的圖片解決方法
- 相關(guān)鏈接:
- 教程說明:
JSP教程-Java多媒體框架設(shè)計(jì)自動(dòng)播放機(jī)
。