Tesseract OCR框架(三) —— 基于Tesseract OCR iOS框架的圖片中的文字識別簡單示例(二)

版本記錄

版本號 時間
V1.0 2019.05.26 星期日

前言

Tesseract OCR是谷歌Google維護的一個框架,用于從圖片中提取文字,有iOSC++多種版本,在很多領域都有廣泛的應用荔燎。接下來我們就一起走進這個框架(iOS部分)。感興趣的可以看下面幾篇.
1. Tesseract OCR框架(一) —— 基本概覽(一)
2. Tesseract OCR框架(二) —— 基于Tesseract OCR iOS框架的圖片中的文字識別簡單示例(一)

源碼

1. Swift

首先看下工程組織結構

接著看sb中的內容

下面就是源碼了

1. ViewController.swift
import UIKit
import MobileCoreServices
import TesseractOCR
import GPUImage

class ViewController: UIViewController {
  @IBOutlet weak var textView: UITextView!
  @IBOutlet weak var activityIndicator: UIActivityIndicatorView!
  
  override func viewDidLoad() {
    super.viewDidLoad()
  }
  
  // IBAction methods
  @IBAction func backgroundTapped(_ sender: Any) {
    view.endEditing(true)
  }
  
  @IBAction func takePhoto(_ sender: Any) {
    let imagePickerActionSheet =
      UIAlertController(title: "Snap/Upload Image",
                        message: nil,
                        preferredStyle: .actionSheet)
    
    if UIImagePickerController.isSourceTypeAvailable(.camera) {
      let cameraButton = UIAlertAction(
        title: "Take Photo",
        style: .default) { (alert) -> Void in
          self.activityIndicator.startAnimating()
          let imagePicker = UIImagePickerController()
          imagePicker.delegate = self
          imagePicker.sourceType = .camera
          imagePicker.mediaTypes = [kUTTypeImage as String]
          self.present(imagePicker, animated: true, completion: {
            self.activityIndicator.stopAnimating()
          })
      }
      imagePickerActionSheet.addAction(cameraButton)
    }
    
    let libraryButton = UIAlertAction(
      title: "Choose Existing",
      style: .default) { (alert) -> Void in
        self.activityIndicator.startAnimating()
        let imagePicker = UIImagePickerController()
        imagePicker.delegate = self
        imagePicker.sourceType = .photoLibrary
        imagePicker.mediaTypes = [kUTTypeImage as String]
        self.present(imagePicker, animated: true, completion: {
          self.activityIndicator.stopAnimating()
        })
    }
    imagePickerActionSheet.addAction(libraryButton)
    
    let cancelButton = UIAlertAction(title: "Cancel", style: .cancel)
    imagePickerActionSheet.addAction(cancelButton)
    
    present(imagePickerActionSheet, animated: true)
  }

  // Tesseract Image Recognition
  func performImageRecognition(_ image: UIImage) {
    let scaledImage = image.scaledImage(1000) ?? image
    let preprocessedImage = scaledImage.preprocessedImage() ?? scaledImage
    
    if let tesseract = G8Tesseract(language: "eng+fra") {
      tesseract.engineMode = .tesseractCubeCombined
      tesseract.pageSegmentationMode = .auto
      
      tesseract.image = preprocessedImage
      tesseract.recognize()
      textView.text = tesseract.recognizedText
    }
    activityIndicator.stopAnimating()
  }
}

// MARK: - UINavigationControllerDelegate
extension ViewController: UINavigationControllerDelegate {
}

// MARK: - UIImagePickerControllerDelegate
extension ViewController: UIImagePickerControllerDelegate {
  func imagePickerController(_ picker: UIImagePickerController,
       didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
    guard let selectedPhoto =
      info[.originalImage] as? UIImage else {
        dismiss(animated: true)
        return
    }
    activityIndicator.startAnimating()
    dismiss(animated: true) {
      self.performImageRecognition(selectedPhoto)
    }
  }
}

// MARK: - UIImage extension
extension UIImage {
  func scaledImage(_ maxDimension: CGFloat) -> UIImage? {
    var scaledSize = CGSize(width: maxDimension, height: maxDimension)

    if size.width > size.height {
      scaledSize.height = size.height / size.width * scaledSize.width
    } else {
      scaledSize.width = size.width / size.height * scaledSize.height
    }

    UIGraphicsBeginImageContext(scaledSize)
    draw(in: CGRect(origin: .zero, size: scaledSize))
    let scaledImage = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()
    
    return scaledImage
  }
  
  func preprocessedImage() -> UIImage? {
    let stillImageFilter = GPUImageAdaptiveThresholdFilter()
    stillImageFilter.blurRadiusInPixels = 15.0
    let filteredImage = stillImageFilter.image(byFilteringImage: self)
    return filteredImage
  }
}

后記

本篇主要講述了基于Tesseract OCR iOS框架的圖片中的文字識別簡單示例的基本情況销钝,感興趣的給個贊或者關注~~~

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末有咨,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蒸健,更是在濱河造成了極大的恐慌座享,老刑警劉巖婉商,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異渣叛,居然都是意外死亡丈秩,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門淳衙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來癣籽,“玉大人,你說我怎么就攤上這事滤祖。” “怎么了瓶籽?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵匠童,是天一觀的道長。 經常有香客問我塑顺,道長汤求,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任严拒,我火速辦了婚禮扬绪,結果婚禮上,老公的妹妹穿的比我還像新娘裤唠。我一直安慰自己挤牛,他們只是感情好,可當我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布种蘸。 她就那樣靜靜地躺著墓赴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪航瞭。 梳的紋絲不亂的頭發(fā)上诫硕,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天,我揣著相機與錄音刊侯,去河邊找鬼章办。 笑死,一個胖子當著我的面吹牛滨彻,可吹牛的內容都是我干的藕届。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼疮绷,長吁一口氣:“原來是場噩夢啊……” “哼翰舌!你這毒婦竟也來了?” 一聲冷哼從身側響起冬骚,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤椅贱,失蹤者是張志新(化名)和其女友劉穎懂算,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體庇麦,經...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡计技,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了山橄。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片垮媒。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖航棱,靈堂內的尸體忽然破棺而出睡雇,到底是詐尸還是另有隱情,我是刑警寧澤饮醇,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布它抱,位于F島的核電站,受9級特大地震影響朴艰,放射性物質發(fā)生泄漏观蓄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一祠墅、第九天 我趴在偏房一處隱蔽的房頂上張望侮穿。 院中可真熱鬧,春花似錦毁嗦、人聲如沸亲茅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽芯急。三九已至,卻和暖如春驶俊,著一層夾襖步出監(jiān)牢的瞬間娶耍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工饼酿, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留榕酒,地道東北人。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓故俐,卻偏偏與公主長得像想鹰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子药版,可洞房花燭夜當晚...
    茶點故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內容

  • 版本記錄 前言 Tesseract OCR是谷歌Google維護的一個框架笤受,用于從圖片中提取文字西土,有iOS和C++...
    刀客傳奇閱讀 4,786評論 0 11
  • 細步走在通往你家的小路上瑞筐。 穿著淡粉的碎花裙裾,剛下過雨肢础,路上稍有泥濘,打濕了桃紅的鞋尖碌廓,裙上星星點點传轰,像塵世的心...
    清兮館閱讀 131評論 1 2
  • 2018年9月13日紅源悟語 自我覺醒:想,都是問題谷婆;做慨蛙,才是答案! 今日成長 其實很多時候纪挎,缺期贫,并不意味著遺憾。...
    紅源隨筆閱讀 179評論 0 0
  • --淺析影片《英和白》 這是張以慶導演在1999年的一個巨著唯灵,英和白是影片的名字也是片中主人公的名字,白是...
    嶼歧閱讀 263評論 0 0
  • 我們所處的時代隙轻,很少有人會相信一個抽象的論證會生效,其中的原因可能是眾人隱約地覺得這個由物理規(guī)律所決定的世界垢揩,不會...
    圖林根人閱讀 594評論 0 1