Skip to content

[0129] 优化 PDF 缩放性能:页面缓存、可见性裁剪与防抖#3371

Merged
Yuki-Nagori merged 1 commit into
mainfrom
da/0129/pdf_scale
May 15, 2026
Merged

[0129] 优化 PDF 缩放性能:页面缓存、可见性裁剪与防抖#3371
Yuki-Nagori merged 1 commit into
mainfrom
da/0129/pdf_scale

Conversation

@da-liii
Copy link
Copy Markdown
Contributor

@da-liii da-liii commented May 15, 2026

Summary

  • 参考 Okular Tile-based 渲染架构,对 PDFReaderWidget 进行缩放性能优化
  • 引入页面级渲染缓存、可见性裁剪、缩放/Resize 防抖、滚动按需渲染

核心改动

  1. 页面渲染缓存 (PdfPageCacheKey + QHash):以 (pageNumber, targetWidth) 为键缓存 QPixmap,相同尺寸页面直接命中,跳过 MuPDF 光栅化
  2. 可见性裁剪rebuildPages() 只渲染视口 ±200px 范围内的页面;不可见页面若缓存存在则显示降级缩放图
  3. 缩放防抖 (zoomDebounceTimer_, 200ms):Ctrl+滚轮连续缩放时只渲染最终状态
  4. Resize 防抖 (resizeDebounceTimer_, 300ms):窗口大小调整后防抖统一重建
  5. 滚动按需渲染:垂直滚动 valueChanged 连接 rebuildPages(),新进入视口的页面自动渲染
  6. 预计算宽高比loadFromFile() 时一次性读取所有页面的宽高比,避免重复打开文档

Test plan

  • xmake build stem 通过
  • xmake run qt_pdf_reader_widget_test 10 passed, 0 failed
  • 手动测试:打开多页 PDF,Ctrl+滚轮缩放验证流畅度
  • 手动测试:快速调整窗口大小验证无卡顿
  • 手动测试:滚动长文档验证新页面按需加载

🤖 Generated with Claude Code

参考 Okular Tile-based 渲染架构,引入以下优化:
- 页面渲染缓存:以 (pageNumber, targetWidth) 为键缓存 QPixmap
- 可见性裁剪:rebuildPages 只渲染视口 ±200px 范围内的页面
- 缩放防抖:Ctrl+滚轮缩放后 200ms 防抖,避免连续触发重渲染
- Resize 防抖:窗口大小调整 300ms 防抖后统一重建
- 滚动按需渲染:垂直滚动时自动触发新进入视口页面的渲染

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
Copy link
Copy Markdown
Contributor

@Yuki-Nagori Yuki-Nagori left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@Yuki-Nagori Yuki-Nagori merged commit 141a90b into main May 15, 2026
5 checks passed
@Yuki-Nagori Yuki-Nagori deleted the da/0129/pdf_scale branch May 15, 2026 09:54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants