# 高解析度大圖像可縮放 Web 查看器的實踐 ## 一、使用 vips 將高解析度大圖像轉換為 DZI 1. 安裝 vips 具體安裝步驟請參考[libvips Install](https://www.libvips.org/install.html)。 註意,在 windows 11 中安裝 ...
高解析度大圖像可縮放 Web 查看器的實踐
一、使用 vips 將高解析度大圖像轉換為 DZI
-
安裝 vips
具體安裝步驟請參考libvips Install。
註意,在 windows 11 中安裝 v8.14.2 版本後,在運行
vips dzsave **.jpg mydz
命令時,出現vips: unknown action "dzsave"
報錯,解決辦法是重裝低版本 v8.14.1,因為在 v8.14.2 中 dzsave 功能被移除了,但有可能在後續版本中會添加回來。 -
安裝 pyvips
pip install pyvips
pyvips API 參考文檔:pyvips
-
生成 DZI
import os import pyvips vipsbin = r'F:\vips-dev-8.14\bin' add_dll_dir = getattr(os, 'add_dll_directory', None) if callable(add_dll_dir): add_dll_dir(vipsbin) else: os.environ['PATH'] = os.pathsep.join((vipsbin, os.environ['PATH'])) current_abspath = os.path.dirname(os.path.abspath(__file__)) # 打開圖像 image = pyvips.Image.new_from_file(os.path.join(current_abspath, 'bigimage.png')) # 生成 DZI image.dzsave(os.path.join(current_abspath, 'mydz'), suffix='.jpg', tile_size=512, overlap=1)
dzsave
參數說明:- 第一個參數為 DZI 文件夾的路徑,將在此處生成 DZI 文件。
- suffix:生成的 DZI 圖像文件的尾碼名。
- tile_size:DZI 圖像的瓷磚大小。
- overlap:DZI 圖像的瓷磚之間的重疊區域大小。
上述代碼運行後,將在代碼文件目錄下生成
mydz.dzi
文件和mydz_fils
文件夾。其中,dzsave
方法的使用請參考官方文檔:pyvips.Image.dzsave。
二、使用 flask 為 DZI 提供 HTTP 服務
from flask import Flask, send_from_directory
app = Flask(__name__)
@app.route('/<path:path>')
def static_file(path):
return send_from_directory('.', path)
if __name__ == '__main__':
app.run(port=8008)
三、使用 OpenSeadragon 實現 Web 訪問
關於 OpenSeadragon 的使用請參考官方文檔 OpenSeadragon。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Big Image Viewer</title>
<script src="./openseadragon/openseadragon.min.js"></script>
<style type="text/css">
html,
body,
.openseadragon-ctr {
width: 100%;
height: 100%;
margin: 0;
background-color: #111;
}
</style>
</head>
<body>
<div id="contentDiv" class="openseadragon-ctr"></div>
<script type="text/javascript">
OpenSeadragon({
id: "contentDiv",
prefixUrl: "openseadragon/images/",
showNavigator: false,
navigatorPosition: "BOTTOM_LEFT",
tileSources: {
Image: {
xmlns: "http://schemas.microsoft.com/deepzoom/2008",
// 生成的 DZI 文件 HTTP 訪問路徑
Url: "../mydz_files/",
Format: "jpg",
Overlap: "1",
TileSize: "512",
Size: {
Height: "3971",
Width: "73364",
},
},
},
});
</script>
</body>
</html>
查看效果:
-
初始狀態
-
放大狀態
作者:飛仔FeiZai
出處:https://www.cnblogs.com/yuzhihui/p/17448525.html
聲明:歡迎任何形式的轉載,但請務必註明出處!!!
更多相關文章
-
這個資料庫中不但包含了常規的朝代、作者、教材分類之外,還有詩集和分類欄位。 詩集檢索可以讓用戶選擇喜歡的詩集開始誦讀。類型檢索是指按詩歌的題材檢索,如果你在寫作時想引用詩句,類型檢索會效率很多。 朝代有:先秦、兩漢、魏晉、南北朝、隋代、唐代、五代、宋代、金朝、元代、明代、清代; 出處有:唐詩三百首、 ...
-
**【導讀】** 在PC 互聯網到移動互聯網的演進過程,隨著人們對交互和信息獲取的智能化要求越來越高,移動終端上的應用生態發展到今天也面臨著變革。傳統厚重的App,功能齊全,但開發成本高、周期長,且存在搜索、安裝、卸載等一系列需要用戶主動關註的顯性操作,這些顯性操作給用戶帶來了實質性的使用成本。輕量 ...
-
這段時間破解了中高學生知識題庫,包含高中英語題庫、小學英語題庫、初中地理題庫、初中歷史題庫、高中歷史題庫、初中生物題庫,數據表結構都一樣,今天發的這份是上萬條的初中歷史題庫,截圖包含所有欄位,截圖下方有顯示共有記錄數。 參考項有:步入近代(1484)、國家的產生和社會的變革(1261)、侵略與反抗( ...
-
## strings.xml匹配替換 將兩個Android項目中的多語言字元串文件(strings.xml)進行比較,如果其中一個項目中包含另一個項目沒有的字元,則合併到單一的輸出文件,並以 key 在原始 XML 文件中更新 value 值。如果key匹配不准確則忽略它。 具體來說: 1. 引入 ...
-
這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 發現一個很有創意的小工具網站,如封面圖所示功能很簡單,就是將一個URL地址轉換為都是 ooooooooo 的樣子,通過轉換後的地址訪問可以轉換回到原始地址,簡單流程如下圖所示。轉換的邏輯有點像短鏈平臺一樣,只不過這個是將你的URL地址變的 ...
-
**歷時一年多,我也體驗了不少的靜態博客托管服務了,這裡進行一下對比吧。主要列舉一下優缺點,所有的內容基於該平臺免費版,並且不添加任何增值服務的情況。 速度體驗基於浙江電信的個人測試結果。** # GitHub Pages > 速度:尚可,並不很慢,但有時候會抽風。 自定義功能變數名稱:一個。 限制: 單個 ...
-
# 如何在 CloudFlare Pages 上建站? > 幾分鐘、零基礎搭建個人網頁!- 高速直連,基於Cloudflare Page: `https://zhuanlan.zhihu.com/p/416269228` 使用 Cloudflare Worker 免費搭建網址導航網站 `https: ...
-
setTimeout 倒計時誤差的出現主要與 JavaScript 的事件迴圈機制和計時器的執行方式有關。 在 JavaScript 中,事件迴圈是用於管理和調度代碼執行的機制。setTimeout 函數用於設置一個定時器,在指定的延遲時間後執行回調函數。然而,由於事件迴圈的機制,setTimeou ...