一種WAP嵌入式瀏覽器的設計
2.2 布局處理
所謂布局模塊,就是處理WML語(yǔ)法和DOM樹(shù),樹(shù)的每個(gè)結點(diǎn)是一個(gè)對象,包含著(zhù)對象的所有屬性設置信息。最后提交到繪圖模塊,由繪圖模塊進(jìn)行處理,顯示出來(lái)網(wǎng)頁(yè)信息。
2.2.1圖片布局
img元素是圖片元素。一般情況下,img元素的src屬性值會(huì )是通過(guò)URL指向一個(gè)圖片,該圖片就是需要顯示的圖片,而img的排版會(huì )優(yōu)先考慮其wIDTh屬性值和height屬性值,如果兩個(gè)屬性值都存在,則按照其屬性值中相應的值進(jìn)行排版,顯示相應的屬性值的圖片;如果僅有一個(gè)屬性值,則縮放實(shí)際照片的屬性值,顯示圖片;如果img元素沒(méi)有這兩個(gè)屬性,則排版的照片為實(shí)際寬高;當僅有一個(gè)屬性值或沒(méi)有width屬性和height屬性時(shí),該img元素的排版會(huì )被跳過(guò),同時(shí)相應的圖片URL會(huì )進(jìn)入下載隊列,等待該圖片下載成功后,對當前的頁(yè)面進(jìn)行重新排版。
2.2.2文字布局
由圖2可知,布局層位于解析和繪圖之間,用來(lái)對語(yǔ)義分析后的文檔內容進(jìn)行排版處理,將網(wǎng)頁(yè)內容以適當的方式排放在顯示屏幕上。
WML語(yǔ)言的文字排版控制較少,只有居中、左對齊和右對齊3種方式;其次WML語(yǔ)言的表達控制也很弱,只有em:加強(斜體)、STrong:加重(斜體)、i:斜體、b:加粗、u:下劃線(xiàn)、big:大字體(字體加大一號)、small:小字體(字體減小一號)等7種文字表達方式。
3 結果及分析
本文主要針對支持Java的嵌入式瀏覽器的設計與實(shí)現。系統以J2ME為開(kāi)發(fā)平臺,通信協(xié)議沒(méi)有采取HTTP協(xié)議,而是采取以WAP協(xié)議作為協(xié)議棧,以WML為標記語(yǔ)言作為網(wǎng)頁(yè)數據的表現形式,在嵌入式瀏覽器中實(shí)現方便、豐富的多媒體信息瀏覽服務(wù)。
在仿真結果中,如圖5所示,圖片為訪(fǎng)問(wèn)外網(wǎng)的百度頁(yè)面,而且有前進(jìn)、后退、刷新標志,均說(shuō)明此應用能夠在嵌入式設備中實(shí)現。如果用戶(hù)為了節省流量,可以考慮切換到極簡(jiǎn)版本,也就是解析過(guò)程中沒(méi)有處理解析圖片,只是簡(jiǎn)單解析文字。由于HTML網(wǎng)頁(yè)中,百度logo圖片要大于屏幕大小,所以進(jìn)行壓縮之后進(jìn)行顯示。在此設計中,圖片下載完整,能夠完整顯示出來(lái)。
圖5 百度頁(yè)面
4 總結
通過(guò)測試,本瀏覽器的模塊可移植性很好,解決了傳統瀏覽器的可移植性困難以及帶寬比較窄、屏幕比較小的問(wèn)題。同時(shí),該瀏覽器針對嵌入式系統應用進(jìn)行特殊設計,省去了一些不實(shí)用的、冗余的和影響系統效率的模塊,具有可移植性、運行效率高等特點(diǎn)。
評論