js前端加載超大圖片(100M以上)實現(xiàn)秒開的最佳解決方案
前言
前端加載超大圖片時,一般可以采取以下措施實現(xiàn)加速:
- 圖片壓縮:將圖片進行壓縮可以大幅減小圖片的大小,從而縮短加載時間。壓縮圖片時需要注意保持圖片質(zhì)量,以免影響圖片顯示效果。
- 圖片分割:將超大圖片分割成多個小圖塊進行加載,可以避免一次性加載整個圖片,從而加快加載速度。這種方式需要在前端實現(xiàn)圖片拼接,需要確保拼接后的圖片無縫銜接。
- CDN 加速:使用 CDN(內(nèi)容分發(fā)網(wǎng)絡(luò))可以將圖片緩存在離用戶更近的節(jié)點上,從而加速圖片加載速度。如果需要加載的圖片是靜態(tài)資源,可以將其存儲在 CDN 上,以便快速訪問。
- 懶加載:懶加載是一種圖片延遲加載的方式,即當(dāng)用戶瀏覽到需要加載的圖片時才進行加載,可以有效避免一次性加載大量圖片而導(dǎo)致頁面加載速度緩慢。
- WebP 格式:使用 WebP 格式可以將圖片大小減小到 JPEG 和 PNG 的一半以下,從而加快圖片加載速度。
- HTTP/2:使用 HTTP/2 協(xié)議可以并行加載多個圖片,從而加快頁面加載速度。
- 預(yù)加載:預(yù)加載是在頁面加載完畢后,提前加載下一步所需要的資源。在圖片加載方面,可以在頁面加載完畢后提前加載下一個需要顯示的圖片,以便用戶快速瀏覽。
而對于幾百M或上G的大圖而言,不管對圖片進行怎么優(yōu)化或加速處理,要實現(xiàn)秒開也是不太可能的事情。而上面介紹的第二條“圖像分割切片”是最佳解決方案。下面介紹下如何對大圖進行分割,在前端進行拼接實現(xiàn)秒開。
圖像切片原理介紹
圖像切片是指將一張大圖分割成若干個小圖的過程,以便于存儲和處理。圖像切片常用于網(wǎng)絡(luò)地圖、瓦片地圖、圖像拼接等應(yīng)用中。
切片原理主要包括以下幾個步驟:
- 定義切片大小:首先需要定義每個小圖的大小,一般情況下是正方形或矩形。
- 計算切片數(shù)量:根據(jù)定義的切片大小,計算原始圖像需要被切成多少個小圖。計算公式為:切片數(shù)量 = 原始圖像寬度 / 切片寬度 × 原始圖像高度 / 切片高度。
- 切割圖像:按照計算出的切片數(shù)量,將原始圖像分割成相應(yīng)數(shù)量的小圖??梢允褂脠D像處理庫或自己編寫代碼實現(xiàn)。
- 存儲切片:將切割后的小圖存儲到磁盤上,可以使用常見的圖片格式,如JPEG、PNG等。
- 加載切片:在需要顯示切片的地方,根據(jù)需要加載相應(yīng)的小圖,組合成完整的圖像。
使用圖像切片可以降低處理大圖像的復(fù)雜度,同時也能夠提高圖像的加載速度,使得用戶可以更快地查看圖像的細節(jié)。圖像切片廣泛應(yīng)用于需要處理大圖像的場景,能夠提高圖像處理和顯示效率,同時也能夠提高用戶的體驗。
實現(xiàn)
先上效果圖
上傳打開圖形
先上傳大圖,至后臺進行切片處理, 上傳相關(guān)代碼為:
async onChangeFile(file) { try { message.info('文件上傳中,請稍候...') this.isSelectFile = false; this.uploadMapResult = await svc.uploadMap(file.raw); if (this.uploadMapResult.error) { message.error('上傳圖形失敗!' + this.uploadMapResult.error) return } this.form.mapid = this.uploadMapResult.mapid; this.form.uploadname = this.uploadMapResult.uploadname; this.maptype = this.uploadMapResult.maptype || ''; this.dialogVisible = true; } catch (error) { console.error(error); message.error('上傳圖形失敗!', error) } }
如果需要上傳后對圖像進行處理,可以新建一個cmd.txt文件,把處理的命令寫進文件中,然后和圖像一起打包成zip上傳。
如需要把1.jpg,2.jpg拼接成一個新的圖片m1.png再打開,cmd.txt的寫法如下:
join 1.jpg 2.jpg m1.png horizontal
再把1.jpg,2.jpg,cmd.txt三個文件打包成zip文件上傳即可
打開圖像相關(guān)代碼
async onOpenMap() { try { let mapid = this.form.mapid; let param = { ...this.uploadMapResult, // 圖名稱 mapid: this.form.mapid, // 上傳完返回的fileid fileid: this.uploadMapResult.fileid, // 上傳完返回的文件名 uploadname: this.form.uploadname, // 地圖打開方式 mapopenway: this.form.openway === "直接打開圖形" ? vjmap.MapOpenWay.Memory : vjmap.MapOpenWay.GeomRender, // 如果要密碼訪問的話,設(shè)置秘鑰值 secretKey: this.form.isPasswordProtection ? svc.pwdToSecretKey(this.form.password) : undefined, style: vjmap.openMapDarkStyle(),// div為深色背景顏色時,這里也傳深色背景樣式 // 圖像類型設(shè)置地圖左上角坐標和分辨率 imageLeft: this.form.imageLeft ? +this.form.imageLeft : undefined, imageTop: this.form.imageTop ? +this.form.imageTop : undefined, imageResolution: this.form.imageResolution ? +this.form.imageResolution : undefined, } let isVectorStyle = this.form.openway === "存儲后渲染矢量"; await openMap(param, isVectorStyle); } catch (error) { console.error(error); message.error('打開圖形失敗!', error) } }
應(yīng)用案例
應(yīng)用一 對圖像進行拼接前端查看
原始圖片為
最終效果為:
體驗地址: https://vjmap.com/app/cloud/#/map/t3c93d14ff09?version=v1&mapopenway=GeomRender&vector=false
應(yīng)用二 對tiff影像進行切片并與CAD圖疊加校準
對tiff影像上傳時可設(shè)置地理坐標范圍。
tiff/tfw, jpg/jpgw坐標文件的格式(6個參數(shù)) 0.030000 0.0000000000 0.0000000000 -0.030000 451510.875000 3358045.000000
以上每行對應(yīng)的含義:
1 地圖單元中的一個象素在X方向上的X分辨率尺度。 2 平移量。 3 旋轉(zhuǎn)量。 4 地圖單元中的一個象素在Y方向上的Y分辨率尺度的負值。 5 象素1,1(左上方)的X地坐標。 6 象素1,1(左上方)的Y地坐標。
在上傳圖時需要根據(jù)文件中的第一個,第五個和第六個值設(shè)置地圖范圍
或者上傳完后,操作菜單中點擊設(shè)置地圖范圍進行設(shè)置
影像地圖切片完成后,可與CAD圖進行疊加校準。效果如下
體驗地址:https://vjmap.com/demo/#/demo/map/comprehensive/04imagecadmap
以上就是js前端加載超大圖片(100M以上)實現(xiàn)秒開的最佳解決方案的詳細內(nèi)容,更多關(guān)于js前端加載超大圖片的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
直接拿來用的頁面跳轉(zhuǎn)進度條JS實現(xiàn)
這篇文章主要為大家分享了一款直接拿來用的頁面跳轉(zhuǎn)進度條,由javascript實現(xiàn),可以直接跳轉(zhuǎn)到相應(yīng)頁面,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-01-01JavaScript面向?qū)ο髮崿F(xiàn)放大鏡案例
這篇文章主要為大家詳細介紹了JavaScript面向?qū)ο髮崿F(xiàn)放大鏡案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10JS監(jiān)聽微信、支付寶等移動app及瀏覽器的返回、后退、上一頁按鈕的事件方法
這篇文章主要介紹了JS監(jiān)聽微信、支付寶等移動app及瀏覽器的返回、后退、上一頁按鈕的事件方法,需要的朋友可以參考下2016-08-08JavaScript??际謱戭}之柯里化與數(shù)組扁平化的實現(xiàn)
這篇文章主要為大家詳細介紹了JavaScript??际謱戭}中柯里化與數(shù)組扁平化、數(shù)組去重的實現(xiàn),文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12有關(guān)div頁面拖動、縮放、關(guān)閉、遮罩效果代碼
有關(guān)div頁面拖動、縮放、關(guān)閉、遮罩效果代碼,比較不錯,適合學(xué)習(xí)用。2009-08-08