IOS10 保存照片到相册:用PHPhotoLibrary来代替ALAssetsLibrary


ios10开始ALAssetsLibrary被标志为弃用(DEPRECATED),并建议使用Photos framework的PHPhotoLibrary

首先引用Photos framework

#import <Photos/Photos.h>


使用代码:

方法1:同步存到系统相册

__block NSString *createdAssetID =nil;//唯一标识,可以用于图片资源获取

    NSError *error =nil;

    [[PHPhotoLibrary sharedPhotoLibrary]performChangesAndWait:^{

        createdAssetID = [PHAssetChangeRequest            creationRequestForAssetFromImage:image].placeholderForCreatedAsset.localIdentifier;

    } error:&error];



方法2:存到某个自定义相册

[[PHPhotoLibrary sharedPhotoLibrary]performChanges:^{

        

        PHAssetChangeRequest *changeAssetRequest = [PHAssetChangeRequest creationRequestForAssetFromImage:image];

        

        PHAssetCollection *targetCollection = [[PHAssetCollection fetchAssetCollectionsWithType:PHAssetCollectionTypeAlbum subtype:PHAssetCollectionSubtypeSmartAlbumUserLibrary options:nil]lastObject];

        

        PHAssetCollectionChangeRequest *changeCollectionRequest = [PHAssetCollectionChangeRequest changeRequestForAssetCollection:targetCollection];

        

        PHObjectPlaceholder *assetPlaceholder = [changeAssetRequest placeholderForCreatedAsset];


        [changeCollectionRequest addAssets:@[assetPlaceholder]];

        

    } completionHandler:^(BOOL success,NSError * _Nullable error) {

        NSLog(@"finished adding");

    }];


讲解:

1.[PHAssetChangeRequest creationRequestForAssetFromImage:image];

作用是建立一个改变Asset的请求,并将Image或者URL对应的资源放入请求,然后等待处理


2. [[PHAssetCollection fetchAssetCollectionsWithType:PHAssetCollectionTypeSmartAlbum subtype:PHAssetCollectionSubtypeSmartAlbumUserLibrary options:nil]lastObject];

作用是获取一个相册,用于作用图片处理结果后的放置位置。fetchAssetCollectionsWithType使用type定位

你要保存的相册'类型/位置',这个需要两级的type来定位,第一级分为Album、Smart和Moment三种,

第二级在第一级的基础上主要分为两种:Album和Smart,Moment是按照时间分类,所以没有二级定位,

任何二级参数都可以。(具体type含义:Album用户创建的相册分组;Smart:系统创建的分组;Moment:系统生成的时间分组)

最后options为nil代表使用默认的获取参数(比如时间排序之类,具体按照个人需求)。按照我的例子写的type是只有返回一个‘相册’,

所以lastobject和下标为firstobject是一样的,但是以Album或者Moment为参数,返回的可能是多个,lastobject取最后一个。


3.[PHAssetCollectionChangeRequest changeRequestForAssetCollection:collection];

作用是建立一个改变Collection的请求


4.PHObjectPlaceholder *assetPlaceholder = [changeAssetRequest placeholderForCreatedAsset];

PHObjectPlaceholder代表一个模型对象的结果,这个结果的提供通过变更请求时创建一个模型对象


5.[changeCollectionRequest addAssets:@[assetPlaceholder]];

最后通过:addAsset来执行最终的结果



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用 AVFoundation 框架开发一个能拍照并保存照片相册iOS app demo 的步骤: 1. 创建一个新的 Xcode 项目,选择 Single View App 模板,并勾选 "Use SwiftUI" 选项。 2. 在 ContentView.swift 文件中,创建一个 preview 块,并添加一个 Button 视图。 3. 在 Button 的 action 中,调用一个名为 takePhoto 的函数。 4. 在 ContentView.swift 文件中,创建一个名为 CameraView 的自定义视图,并在其中导入 AVFoundation 框架。 5. 在 CameraView 中添加 AVCaptureSession、AVCapturePhotoOutput 和 AVCaptureVideoPreviewLayer 属性。 6. 在 CameraView 的 init 方法中,配置 AVCaptureSession,并将 AVCaptureVideoPreviewLayer 添加到视图上。 7. 实现 takePhoto 函数,在其中调用 AVCapturePhotoOutput 的 capturePhoto 方法,并在 completionHandler 中将照片保存相册中。 8. 在 ContentView 中,将 CameraView 添加为一个子视图,并设置其大小和位置。 9. 运行项目,在模拟器或真机上测试拍照和保存照片的功能。 以下是示例代码: ```swift import SwiftUI import AVFoundation import Photos struct ContentView: View { var body: some View { VStack { CameraView() .frame(width: 300, height: 300) Button("Take Photo") { takePhoto() } } } func takePhoto() { // TODO: Call takePhoto function in CameraView } } struct CameraView: UIViewRepresentable { private let captureSession = AVCaptureSession() private let photoOutput = AVCapturePhotoOutput() private let videoPreviewLayer = AVCaptureVideoPreviewLayer() func makeUIView(context: Context) -> UIView { let view = UIView(frame: .zero) configureCaptureSession() videoPreviewLayer.frame = view.layer.bounds view.layer.addSublayer(videoPreviewLayer) captureSession.startRunning() return view } func updateUIView(_ uiView: UIView, context: Context) { videoPreviewLayer.frame = uiView.layer.bounds } func configureCaptureSession() { guard let device = AVCaptureDevice.default(for: .video), let input = try? AVCaptureDeviceInput(device: device) else { return } if captureSession.canAddInput(input) { captureSession.addInput(input) } if captureSession.canAddOutput(photoOutput) { captureSession.addOutput(photoOutput) } videoPreviewLayer.session = captureSession } func takePhoto() { let settings = AVCapturePhotoSettings() photoOutput.capturePhoto(with: settings, delegate: self) } } extension CameraView: AVCapturePhotoCaptureDelegate { func photoOutput(_ output: AVCapturePhotoOutput, didFinishProcessingPhoto photo: AVCapturePhoto, error: Error?) { guard let imageData = photo.fileDataRepresentation(), let image = UIImage(data: imageData) else { return } PHPhotoLibrary.shared().performChanges({ PHAssetChangeRequest.creationRequestForAsset(from: image) }) { (success, error) in if success { print("Photo saved to library") } else if let error = error { print("Error saving photo to library: \(error.localizedDescription)") } } } } ``` 注意:在运行项目之前,需要在 info.plist 文件中添加 "Privacy - Camera Usage Description" 和 "Privacy - Photo Library Additions Usage Description" 权限描述。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值