当前位置: 首页 > 编程笔记 >

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

公胤运
2023-03-14
本文向大家介绍iOS如何扫描HEIF格式的二维码图片,包括了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原生二维码扫描,包括了ios原生二维码扫描的使用技巧和注意事项,需要的朋友参考一下 做iOS的二维码扫描,有两个第三方库可以选择,ZBar和ZXing。今天要介绍的是iOS7.0后AVFoundation框架提供的原生二维码扫描。 首先需要添加AVFoundation.framework框架到你工程中build phase的"Link Binary With Libraries

  • 本文向大家介绍iOS二维码的生成和扫描,包括了iOS二维码的生成和扫描的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下 属性 二维码的生成  * createNonInterpolatedUIImageFormCIImage:outputImage方法的实现  二维码的扫描  *扫描到结果后会调用的方法 以上就是本文的全

  • 本文向大家介绍iOS实现二维码的扫描功能,包括了iOS实现二维码的扫描功能的使用技巧和注意事项,需要的朋友参考一下 直接上代码,就不多废话了

  • 本文向大家介绍iOS 二维码扫描和应用跳转,包括了iOS 二维码扫描和应用跳转的使用技巧和注意事项,需要的朋友参考一下 前面我们已经调到过怎么制作二维码,在我们能够生成二维码之后,如何对二维码进行扫描呢? 在iOS7之前,大部分应用中使用的二维码扫描是第三方的扫描框架,例如ZXing或者ZBar。使用时集成麻烦,出错也不方便调试。在iOS7之后,苹果自身提供了二维码的扫描功能,从效率上来说,原生的

  • 本文向大家介绍iOS自带原生二维码扫描的实现,包括了iOS自带原生二维码扫描的实现的使用技巧和注意事项,需要的朋友参考一下 前言 首先说明的是:原生的二维码扫描有一个坑,那就是扫描范围的确定。只要记得扫描范围是X与Y互换位置,W与H互换位置,就没有什么问题了。 下面进入正题: 1.因为使用原生二维码扫描,所以需要加入头文件添加delegate 2.接着是使用到的类 3.懒加载一个扫描动画的图片 4

  • 本文向大家介绍扫描二维码控件的封装iOS实现,包括了扫描二维码控件的封装iOS实现的使用技巧和注意事项,需要的朋友参考一下 扫描二维码效果   源码:https://github.com/YouXianMing/Animations  以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。