沙盒路径获取以及图片保存到相簿的方法

来自:互联网
时间:2020-05-26
阅读:
免费资源网 - https://freexyz.cn/

iphone沙盒(sandbox)中的几个目录获取方式:

// 获取沙盒主目录路径 
NSString *homeDir = NSHomeDirectory(); 
// 获取Documents目录路径 
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); 
NSString *docDir = [paths objectAtIndex:0]; 
// 获取Caches目录路径 
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES); 
NSString *cachesDir = [paths objectAtIndex:0]; 
// 获取tmp目录路径 
NSString *tmpDir = NSTemporaryDirectory(); 
// 获取当前程序包中一个图片资源(apple.png)路径 
NSString *imagePath = [[NSBundle mainBundle] pathForResource:@"apple" ofType:@"png"]; 
UIImage *appleImage = [[UIImage alloc] initWithContentsOfFile:imagePath]; 

保存图片到相册的三种方法:

1、使用UIImageWriteToSavedPhotosAlbum函数将图片保存到相册,如:

- (void)loadImageFinished:(UIImage *)image
{
 UIImageWriteToSavedPhotosAlbum(image, self, @selector(image:didFinishSavingWithError:contextInfo:), (__bridge void *)self);
}
- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo
{
 NSLog(@"image = %@, error = %@, contextInfo = %@", image, error, contextInfo);
}

第一个参数是要保存到相册的图片对象

第二个参数是保存完成后回调的目标对象

第三个参数就是保存完成后回调到目标对象的哪个方法中,方法的声明要如代码中所示的:

- (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo;

第四个参数在保存完成后,会原封不动地传回到回调方法的contextInfo参数中。

2、使用AssetsLibrary框架中的ALAssetsLibrary类来实现。具体代码如下:

- (void)loadImageFinished:(UIImage *)image
{
 __block ALAssetsLibrary *lib = [[ALAssetsLibrary alloc] init];
 [lib writeImageToSavedPhotosAlbum:image.CGImage metadata:nil completionBlock:^(NSURL *assetURL, NSError *error) {
  NSLog(@"assetURL = %@, error = %@", assetURL, error);
  lib = nil;
 }];
}

使用了ALAssetsLibrary类的writeImageToSavedPhotosAlbum:metadata:completionBlock:方法实现。其中第一个参数是一个CGImageRef的对象,表示要传入的图片。第二个参数是图片的一些属性,这里没有设置所以传入nil。最后一个completionBlock是保存完成后的回调,在这个回调中可以取到保存后的图片路径以及保存失败时的错误信息。

注意:使用该类时需要导入AssetsLibrary.framework。而且该类需要在iOS4.0以上可以使用,但是在iOS9.0之后就被标记为过时方法。官方建议使用Photos.framework中的PHPhotoLibrary进行代替,也就是下面所说的第三种方法。

3、使用Photos框架的PHPhotoLibrary类来实现保存到相册功能。代码如下:

- (void)loadImageFinished:(UIImage *)image
{
 [[PHPhotoLibrary sharedPhotoLibrary] performChanges:^{
   /写入图片到相册
   PHAssetChangeRequest *req = [PHAssetChangeRequest creationRequestForAssetFromImage:image];

  } completionHandler:^(BOOL success, NSError * _Nullable error) {
   NSLog(@"success = %d, error = %@", success, error);
 }];
}

该例子中先调用PHPhotoLibrary类的performChanges:completionHandler:方法,然后在它的changeBlock中,通过PHAssetChangeRequest类的creationRequestForAssetFromImage:方法传入一个图片对象即可实现保存到相册的功能。然后completionHandler中会告诉我们是否操作成功。

也许会有人需要在保存相册后得到图片的PHAsset对象来进行后续操作(昨天刚好碰到有朋友遇到这样的问题)。那么,这里对上面例子进行改进,在创建PHAssetChangeRequest后将它的placeholderForCreatedAsset属性的localIdentifier属性保存到一个数组中,等待操作完成后再通过这个数组来查找刚刚添加的图片对象。

请看下面栗子:

- (void)loadImageFinished:(UIImage *)image
{
 NSMutableArray *imageIds = [NSMutableArray array];
  [[PHPhotoLibrary sharedPhotoLibrary] performChanges:^{
   //写入图片到相册
   PHAssetChangeRequest *req = [PHAssetChangeRequest creationRequestForAssetFromImage:image];
   //记录本地标识,等待完成后取到相册中的图片对象
   [imageIds addObject:req.placeholderForCreatedAsset.localIdentifier];

  } completionHandler:^(BOOL success, NSError * _Nullable error) {
   NSLog(@"success = %d, error = %@", success, error);
   if (success)
   {
    //成功后取相册中的图片对象
    __block PHAsset *imageAsset = nil;
    PHFetchResult *result = [PHAsset fetchAssetsWithLocalIdentifiers:imageIds options:nil];
    [result enumerateObjectsUsingBlock:^(PHAsset * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
     imageAsset = obj;
     *stop = YES;
    }];
    if (imageAsset)
    {
     //加载图片数据
     [[PHImageManager defaultManager] requestImageDataForAsset:imageAsset
       options:nil
       resultHandler:^(NSData * _Nullable imageData, NSString * _Nullable dataUTI, UIImageOrientation orientation, NSDictionary * _Nullable info) {
        NSLog("imageData = %@", imageData);
       }];
    }
   }
  }];
}

以上这篇沙盒路径获取以及图片保存到相簿的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

免费资源网 - https://freexyz.cn/
返回顶部
顶部