VNDocumentCameraScan到可搜索的PDF

问题描述

PDFDocument的帮助下获得VNDocumentCameraScan之后,我目前正在尝试创建可搜索的VNDocumentCameraViewController

当前,我仅拍摄扫描图像并将其放入PDFDocument实例中。


func documentCameraViewController(_ controller: VNDocumentCameraViewController,didFinishWith scan: VNDocumentCameraScan) {
   let pdf = createPDF(from: scan)
} 

fileprivate func createPDF(from scan: VNDocumentCameraScan) -> PDFDocument {
    let pdfDocument = PDFDocument()
    for i in 0 ..< scan.pageCount {
        let pdfPage = PDFPage(image: scan.imageOfPage(at: i))
            pdfDocument.insert(pdfPage!,at: i)
        }
    return pdfDocument
}

我也知道如何从VNDocumentCameraScan中提取文本。我想念的是如何将文本信息合并到PDFDocument实例中。我需要这样做是因为我想扫描文档,将它们另存为.pdf到文件系统中,然后再搜索。

我进行了很多搜索,但没有找到解决方法。

有人知道我将如何做到这一点吗?

解决方法

这篇博文详细介绍了该主题。我正在链接到系列的第 3 部分,因为它解决了您遇到的流程部分。

https://alexanderweiss.dev/blog/2021-03-29-from-uiimage-to-searchable-pdf-part-3

主要思想是在 pdf 中的图像下方绘制识别的文本。文章中的基本步骤:

  1. 拍照
  2. 识别图片上的文字
  3. 创建具有图像尺寸的 PDF 页面
  4. 使用识别的文本绘制文本
  5. 在 pdf 上的文本上方绘制图像

VNRecognizedText 包含有关已识别文本位置的信息,可让您确定在何处绘制文本。我能够在我的应用程序中成功使用这篇文章中的代码;尽管在处理手写文本时它不是 100% 完美,但它运行得相当好。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...