新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > QML Image獲取資源路徑的細(xì)節(jié)

        QML Image獲取資源路徑的細(xì)節(jié)

        作者: 時間:2016-10-08 來源:網(wǎng)絡(luò) 收藏

        QML是門相當(dāng)新的UI描述語言,因此在文檔上總難免有疏漏之處,如果因此產(chǎn)生了bug,則就需要花費大量的時間去排查。

        本文引用地址:http://www.104case.com/article/201610/305535.htm

        在最近筆者使用QML的過程中,在Image獲取資源路徑的細(xì)節(jié)上就出現(xiàn)了這樣的情況。

        Image 是qml中一個非常普通的元素,通常使用方法如下:

        1Image {
        2width:120; height:120
        3fillMode: Image.TileHorizontally
        4smooth:true
        5source:qtlogo.png
        6}

        其中,source指的Image元素獲取資源的url路徑,這個url可以是本地的絕對路徑或者相對路徑,也可以是qt資源系統(tǒng)的路徑,甚至是網(wǎng)絡(luò)資源的路徑。

        正是這個看起來不起眼的路徑,卻會帶來跟預(yù)期想之外的結(jié)果,并且,僅僅從代碼上來看,沒有半點錯誤的地方。

        要了解這種情況的出現(xiàn),應(yīng)該要知道qml的兩種使用方式:

        1.暴露QML源碼的使用方法,即不對QML文件進行處理,存放在可執(zhí)行文件的目錄下,使用QtDeclarative模塊動態(tài)載入,一般適合以開源程序;

        2.混淆QML源碼的使用方法,即將QML文件加入到qt資源系統(tǒng),編譯成二進制文件供QtDeclarative模塊使用,這樣的好處,是可以隱藏代碼,供商業(yè)項目使用。

        在前種的使用方式中,Image元素對于讀取資源路徑正確無誤,在Mac.OS.X,Ubuntu和windows平臺上表示一致,但是后者,卻出現(xiàn)了不同。

        假設(shè)Image以如下代碼使用:

        QML是門相當(dāng)新的UI描述語言,因此在文檔上總難免有疏漏之處,如果因此產(chǎn)生了bug,則就需要花費大量的時間去排查。

        在最近筆者使用QML的過程中,在Image獲取資源路徑的細(xì)節(jié)上就出現(xiàn)了這樣的情況。

        Image 是qml中一個非常普通的元素,通常使用方法如下:

        1property url imageUrl:
        2Image {
        3width:120; height:120
        4fillMode: Image.TileHorizontally
        5smooth:true
        6source: imageUrl ==:xx/me/My Data/picture.jpg?resource/qtlogo.png
        7}

        QML代碼段所在的QML文件和qtlogo都處在qt資源系統(tǒng)中,xx/me/My Data/picture.jpg則值的是三個系統(tǒng)下實際的絕對路徑,這是很異常的情況發(fā)生了。

        在windows下Image的表現(xiàn)很正常,但是在Ubuntu下,卻無法正常顯示系統(tǒng)路徑中的圖片picure.jpg,一個代碼顯示出不同的結(jié)果來是相當(dāng)費解的事,但是事實確很簡單,這個source提供Url的寫法是錯誤的,一個錯誤的代碼自然會出現(xiàn)異常情況。

        當(dāng)QML處在qt 資源系統(tǒng)中,它獲取圖片的路徑自然也是去qt資源系統(tǒng)中獲得了,也就是說上述的兩個路徑變成了qrc:xx/me/My Data/picture.jpg和qrc:resource/qtlogo.png,前者根本不在資源系統(tǒng)內(nèi),自然就不會顯示了。

        當(dāng)然,對這樣的情況自然有正確的解決辦法,那就是對前者路徑的使用應(yīng)該使用file:///xx/me/My Data/picture.jpg,這樣QML才會正常解析為本地文件的路徑。

        至此,對于Image 資源路徑可以總結(jié)出三個規(guī)律:

        1.在沒用使用qt資源系統(tǒng)時,Image的路徑可以是絕對或者相對,并不需要特殊的表示;

        2.當(dāng)使用qt資源系統(tǒng)時,如果要特定知指向本地路徑中的圖片資源,那就要使用file://標(biāo)示;

        3.當(dāng)獲取網(wǎng)絡(luò)圖片資源并使用使用qt資源系統(tǒng),由于有http表示存在,QML會自然去除qrc:標(biāo)示。

        其中第三點文中并沒有說明,但是有興趣的同學(xué)可以去試試。



        關(guān)鍵詞:

        評論


        相關(guān)推薦

        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 武汉市| 海淀区| 平和县| 夏邑县| 高州市| 马边| 海淀区| 曲沃县| 肃南| 福泉市| 无锡市| 榆林市| 福安市| 克拉玛依市| 平凉市| 宿松县| 军事| 兰溪市| 万宁市| 且末县| 浪卡子县| 湖北省| 宁南县| 五华县| 治县。| 鄱阳县| 揭东县| 宜兴市| 阿尔山市| 内丘县| 顺平县| 巴青县| 安丘市| 长春市| 邹平县| 岑巩县| 锡林浩特市| 特克斯县| 儋州市| 滦南县| 孝感市|