从本机扫描UIImage的条形码(即不使用ZBar) [英] Scanning barcode from UIImage natively (i.e., not using ZBar)
问题描述
自iOS7以来,我一直在使用Apple提供的本机条形码扫描器功能,这很棒,但是我需要扫描一些静态图像,以便能够自动对一些条形码进行分类.
I've been using the native barcode scanner functionality provided by apple since iOS7 and it is great, but I needed to scan some static images I had so I could automatically catalogue some barcodes.
我找不到本机执行此操作的方法,因此我使用了一个名为zBar的开源程序包,并且在大多数情况下都可以正常工作.
I couldn't find a way to do this natively, so I used an open source package called zBar, and for the most part, it works fine.
但是,它经常返回假值,有时整齐地找不到条形码.我也从头开始构建c ++库,但是在OS X构建中得到了相同的结果.这似乎也是一个被遗弃的项目.
However, it returns false values often and sometimes flat out fails to find the barcode. I also built the c++ library from scratch but I got the same results in my OS X build. It also seems to be an abandoned project.
即使我从计算机显示器扫描图像,Apple的本机解决方案也会在此静态图像上找到条形码!对于返回错误/错误值的图像也是如此.
Apple's native solution finds the barcode on this static image even if I scan the image from my computer monitor! Same thing goes for the images that return false/incorrect values.
那么反正有使用苹果的库来扫描UIImage吗?
So is there anyway to use apple's libraries to scan a UIImage?
推荐答案
Firebase的MLKit现在可用.
An option available now is MLKit from Firebase.
将Firebase添加到您的项目中. >
Add Firebase to your project after setting up your project in their console https://firebase.google.com
我使用cocoapods管理依赖项,如果您这样做,则将其添加到Podfile和pod update
:
I use cocoapods to manage dependencies, if you do then add this to your Podfile and pod update
:
pod 'Firebase/Core'
pod 'Firebase/MLVision'
pod 'Firebase/MLVisionBarcodeModel'
这是一个演示视图控制器实现,您可以在其中从照片库中选择要通过ML kit扫描的条形码图像,并将结果打印在标签中.
Here's a demo view controller implementation in which you pick a barcode image from your photo library to be scanned by ML kit, and the results are printed in a label.
// (Don't forget to ask for Photos access by including this in your info.plist)
<key>NSPhotoLibraryUsageDescription</key>
<string>Enable photo library access to select a photo from your library.</string>
import Firebase
class MyDemoViewController: UIViewController, UINavigationControllerDelegate, UIImagePickerControllerDelegate {
lazy var vision = Vision.vision()
@IBOutlet var textLabel: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
}
@IBAction func selectImage(_ sender: Any) {
if UIImagePickerController.isSourceTypeAvailable(.savedPhotosAlbum){
print("Button capture")
let imagePicker = UIImagePickerController()
imagePicker.delegate = self
imagePicker.sourceType = .savedPhotosAlbum;
imagePicker.allowsEditing = false
self.present(imagePicker, animated: true, completion: nil)
}
}
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
guard let image = info[UIImagePickerControllerOriginalImage] as? UIImage else {
return
}
dismiss(animated: true, completion: {
self.checkForCodeInImage(image: image)
})
}
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
dismiss(animated: true, completion:nil)
}
internal func checkForCodeInImage(image: UIImage) {
let detector = vision.barcodeDetector(options: VisionBarcodeDetectorOptions(formats: .all))
let vImage = VisionImage(image: image)
detector.detect(in: vImage) { features, error in
guard error == nil, let barcodes = features, barcodes.isEmpty == false else {
DispatchQueue.main.async {
self.textLabel.text = "No code found in selected image."
}
return
}
var text = ""
for barcode in barcodes {
guard let rawValue = barcode.rawValue else {
continue
}
let corners = barcode.cornerPoints
let displayValue = barcode.displayValue
print("Corners: \(String(describing: corners))")
print("Found: \(String(describing: displayValue))")
text.append(rawValue)
text.append("\n\n")
// let valueType = barcode.valueType
// switch valueType {
// case .wiFi:
// let ssid = barcode.wifi!.ssid
// let password = barcode.wifi!.password
// let encryptionType = barcode.wifi!.type
// case .URL:
// let title = barcode.url!.title
// let url = barcode.url!.url
// default:
// // See API reference for all supported value types
// break
// }
}
DispatchQueue.main.async {
self.textLabel.text = text
}
}
}
}
以下是其文档的链接: https://firebase. google.com/docs/ml-kit/ios/read-barcodes
Here's a link to their documentation: https://firebase.google.com/docs/ml-kit/ios/read-barcodes
这篇关于从本机扫描UIImage的条形码(即不使用ZBar)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!