iOS如何扫描HEIF格式的二维码图片

一、说在前面

iPhone 7 之后系统相机支持HEIF格式的图片,在扫描二维码时,该格式的图片需要转换成JPG格式才能进行扫描成功。

二、思路

用户在打开系统相册选择完一张照片后,要判断该照片是否是HEIF格式,如果是,进行格式转换之后再扫描JPG图片的内容,得到扫描结果。

三、具体实现

因为过程中用到photoKit,因此需要加入该头文件,#import

@protocol TVUImageManagerDelegate <NSObject>
- (void)letQRCodeVCScanQRCodeImageInAlbum:(BOOL)isHEIFFormat;
@end

@interface TVUImageManager : NSObject

@property (strong, nonatomic) UIImage *jpgImage;
@property (strong, nonatomic) UIImage *selectedImage;
@property (strong, nonatomic) PHAsset *selectedAsset;
@property (nonatomic,strong) id <TVUImageManagerDelegate> delegate;

+ (TVUImageManager *)defaultManager;
- (void)doSomethingAfterSelectedImage:(NSDictionary *)info;

@end

自定义类:(.mm)

#define IOS9orLater ([UIDevice currentDevice].systemVersion.integerValue >= 9)

@implementation TVUImageManager

#pragma mark - init part
+ (TVUImageManager *)defaultManager
{
  static TVUImageManager *m_manager = nil;
  if (m_manager == nil) {
    m_manager = [[TVUImageManager alloc] init];
  }
  return m_manager;
}

- (id)init
{
  self = [super init];
  if (self) {

  }
  return self;
}

#pragma mark - image format part
- (void)doSomethingAfterSelectedImage:(NSDictionary *)info
{
  [self getSelectedImagePHAsset:info];
  if (self.selectedAsset == nil) {
    log4cplus_error("TVUImageManagerLog", "%s:selected image is null",__func__);
    return;
  }else {
    BOOL isHEIF = [self judgeIfAnImageIsHeifFormat];
    if (isHEIF) {
      log4cplus_error("TVUImageManagerLog", "%s:selected image is HEIF format",__func__);
      [self convertImageFormatFromHeifToJpegAndThenScanTheImage];
    }else {
      log4cplus_error("TVUImageManagerLog", "%s:selected image is not HEIF format",__func__);
      self.selectedImage = (UIImage *)[info objectForKey:UIImagePickerControllerOriginalImage];
      if (self.selectedImage == nil) {
        log4cplus_error("TVUImageManagerLog", "%s:selected image is null",__func__);
        return;
      }
      [self.delegate letQRCodeVCScanQRCodeImageInAlbum:NO];
    }
  }
}

// Choose a picture from the system album
- (void)getSelectedImagePHAsset:(NSDictionary *)info
{
  log4cplus_error("TVUImageManagerLog", "%s:get selected image PHAsset",__func__);
  NSURL *imageAssetUrl = [info objectForKey:UIImagePickerControllerReferenceURL];
  PHFetchResult *fetchResult = [PHAsset fetchAssetsWithALAssetURLs:[NSArray arrayWithObject:imageAssetUrl] options:nil];
  if (fetchResult.count == 0) {
    log4cplus_error("TVUImageManagerLog", "%s:fetchResult's count is 0",__func__);
    return;
  }
  self.selectedAsset = (PHAsset*)fetchResult.firstObject;
}

// Determine if the picture is in HEIF format
- (BOOL)judgeIfAnImageIsHeifFormat
{
  log4cplus_error("TVUImageManagerLog", "%s:begin to judge if an image is HEIF format",__func__);
  __block BOOL isHEIF = NO;
  if (IOS9orLater) {
    NSArray *resourceList = (NSArray *)[PHAssetResource assetResourcesForAsset:self.selectedAsset];
    [resourceList enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
      PHAssetResource *resource = obj;
      NSString *UTI = resource.uniformTypeIdentifier;
      if ([UTI isEqualToString:@"public.heif"] || [UTI isEqualToString:@"public.heic"]) {
        isHEIF = YES;
        *stop = YES;
      }
    }];
  }else {
    NSString *UTI = [self.selectedAsset valueForKey:@"uniformTypeIdentifier"];
    isHEIF = [UTI isEqualToString:@"public.heif"] || [UTI isEqualToString:@"public.heic"];
  }
  return isHEIF;
}

// Convert image format from HEIF to JPEG and then scan the image
- (void)convertImageFormatFromHeifToJpegAndThenScanTheImage
{
  log4cplus_error("TVUImageManagerLog", "%s:begin to convert image format from HEIF to JPEG",__func__);
  [[PHImageManager defaultManager] requestImageDataForAsset:self.selectedAsset options:nil resultHandler:^(NSData * _Nullable imageData, NSString * _Nullable dataUTI, UIImageOrientation orientation, NSDictionary * _Nullable info) {
    CIImage *ciImage = [CIImage imageWithData:imageData];
    CIContext *context = [CIContext context];
    NSData *jpgData = [context JPEGRepresentationOfImage:ciImage colorSpace:ciImage.colorSpace options:@{}];
    self.jpgImage = [UIImage imageWithData:jpgData];
    [self.delegate letQRCodeVCScanQRCodeImageInAlbum:YES];
  }];
}

@end

调用:

#pragma mark UIImagePickerControllerDelegate
- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
{
  [self.imageMgr doSomethingAfterSelectedImage:info];
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

您可能感兴趣的文章:

  • iOS和Android用同一个二维码实现跳转下载链接的方法
  • IOS生成与读取二维码名片
  • iOS实现二维码的扫描功能
  • IOS笔记061之二维码的生成和扫描
  • ios原生二维码扫描
  • ios swift3.0实现二维码扫描、生成、识别示例代码
  • iOS 条码及二维码扫描(从相册中读取条形码/二维码)及扫码过程中遇到的坑
  • iOS模仿微信长按识别二维码的多种方式
  • iOS自带原生二维码扫描的实现
  • 如何在iphon IOS设备上使用二维码
(0)

相关推荐

  • iOS 条码及二维码扫描(从相册中读取条形码/二维码)及扫码过程中遇到的坑

    文章重点介绍如何解决,从手机相册中读取条形码和二维码的问题 1.扫码. 网上有特别的关于iOS扫码的代码和示例,其中扫码主要使用的是自带的AVFoundation类.这里就不细说了,要注意的是如何设置扫描区域,识别区域(这个值是按比例0~1设置,而且X.Y要调换位置,width.height调换位置) <span style="font-size:14px;">//创建输出流 AVCaptureMetadataOutput * output = [[AVCaptureMet

  • IOS笔记061之二维码的生成和扫描

    如今二维码随处可见,无论是实物商品还是各种礼券都少不了二维码的身影.而手机等移动设备又成为二维码的一个很好的应用平台,不管是生成二维码还是扫码二维码.本篇文章从生成二维码.扫描二维码展开分析,通过内容分析二维码用起来也很easy了. 首先说下生成二维码 二维码可以存放纯文本.名片或者URL 其次生成二维码的步骤: 导入CoreImage框架 再次通过滤镜CIFilter生成二维码 1.创建过滤器 2.恢复滤镜的默认属性 3.设置内容 4.获取输出文件 5.显示二维码 代码实现 CoreImage

  • iOS和Android用同一个二维码实现跳转下载链接的方法

    前言 最近一个项目需要iOS和安卓使用一个二维码,让扫描的机器自己识别操作系统实现跳转到相应的下载链接.比如iPhone用微信进行扫描就让他跳转appStore的下载页面,安卓机器使用微信扫描就直接跳浏览器下载.但是这二维码还有一个需求就是,用户已经下载了这个app,当用户打开app进入到注册页面时,再次扫描这个二维码时,自动填写邀请码进行注册.那么该如何实现,细节就不说了,直接上代码. 使用js实现,其实代码非常简单. 使用时直接拷贝代码,改掉相应的链接就好. PS:该链接在微信环境打开时还是

  • ios swift3.0实现二维码扫描、生成、识别示例代码

    基于swift3.0 1.扫描二维码 设置扫描会话,图层和输入输出 //设置捕捉设备 let device = AVCaptureDevice.defaultDevice(withMediaType: AVMediaTypeVideo) do { //设置设备输入输出 let input = try AVCaptureDeviceInput(device: device) let output = AVCaptureMetadataOutput() output.setMetadataObjec

  • iOS模仿微信长按识别二维码的多种方式

    参考:https://github.com/nglszs/BCQRcode 方式一: #import <UIKit/UIKit.h> @interface ViewController : UIViewController @end ************** #import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDid

  • iOS实现二维码的扫描功能

    直接上代码,就不多废话了 // // ViewController.m // QRCode // // Created by chenchen on 15/7/30. // Copyright (c) 2015年 BSY. All rights reserved. // #import <AVFoundation/AVFoundation.h> #import "ViewController.h" @interface ViewController ()<AVCapt

  • 如何在iphon IOS设备上使用二维码

    下面给大家介绍下二维码简介 二维码 (2-dimensional bar code) 是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的:在代码编制上巧妙地利用构成计算机内部逻辑基础的"0"."1"比特流的概念,使用若干个与二进制相对应的几何形体来表示文字数值信息,通过图象输入设备或光电扫描设备自动识读以实现信息自动处理: 二维条码/二维码能够在横向和纵向两个方位同时表达信息,因此能在很小的面积内表达大量的信息. 下面介绍下如

  • IOS生成与读取二维码名片

    一.概述 1.通过某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的 2.二维码通常可以包含以下内容 纯文本 名片 URL 3.二维码具有非常广泛的应用 二维码名片 扫码付款 网址(URL),扫描后自动打开网址 二.二维码的生成 1.生成原理 通过一个类CIFilter(滤镜)包含二维码中所有的信息,然后生成一张二维码图片 二维码中间的icon(头像),是通过在生成的图片上添加一张图片实现的 2.生成步骤 创建滤镜 初始化滤镜 添加二维码信息 获取生成的二维码

  • ios原生二维码扫描

    做iOS的二维码扫描,有两个第三方库可以选择,ZBar和ZXing.今天要介绍的是iOS7.0后AVFoundation框架提供的原生二维码扫描. 首先需要添加AVFoundation.framework框架到你工程中build phase的"Link Binary With Libraries"之下,然后就可以开始了. 一.做好准备工作,搭建UI UI效果如图 IBOutlet.IBAction如下: @property (weak, nonatomic) IBOutlet UIVi

  • iOS自带原生二维码扫描的实现

    前言 首先说明的是:原生的二维码扫描有一个坑,那就是扫描范围的确定.只要记得扫描范围是X与Y互换位置,W与H互换位置,就没有什么问题了. 下面进入正题: 1.因为使用原生二维码扫描,所以需要加入头文件添加delegate #import <AVFoundation/AVFoundation.h> <AVCaptureMetadataOutputObjectsDelegate> 2.接着是使用到的类 @property (strong,nonatomic)AVCaptureDevic

随机推荐