iOS选择相册中的视频并且展示视频第一帧的图片

1、首先要在项目中导入 MediaPlayer.framework 库

2、在使用的地方引入头文件 #import <MediaPlayer/MediaPlayer.h>

3、添加俩个代理方法:UINavigationControllerDelegate 和 UIImagePickerControllerDelegate


下面是我demo中的代码。

注意:只能用真机测试,如果是模拟器会崩溃,这里没有针对模拟器的情况作处理。


#import "ViewController.h"

#import <MediaPlayer/MediaPlayer.h>

@interface ViewController ()<UINavigationControllerDelegate,UIImagePickerControllerDelegate>


@property (strong,nonatomic) UIImageView *videosView;


@end


@implementation ViewController

//第一帧图片显示

-(UIImageView *)videosView

{

    if (!_videosView) {

        _videosView = [[UIImageViewalloc] initWithFrame:CGRectMake(20,20, [UIScreenmainScreen].bounds.size.width -40, [UIScreenmainScreen].bounds.size.width -40)];

        _videosView.layer.masksToBounds =YES;

        _videosView.layer.borderWidth =0.5;

        _videosView.layer.borderColor = [UIColorgrayColor].CGColor;

    }

    return_videosView;

}


//选择视频

-(void)chooseVideos

{

    UIImagePickerController *picker = [[UIImagePickerControlleralloc] init];

    picker.sourceType =UIImagePickerControllerSourceTypePhotoLibrary;

    picker.mediaTypes = [UIImagePickerControlleravailableMediaTypesForSourceType:picker.sourceType];

    picker.delegate = self;

    picker.allowsEditing = YES;

    [selfpresentViewController:picker animated:YEScompletion:nil];

}



- (void)viewDidLoad {

    [superviewDidLoad];

    // Do any additional setup after loading the view, typically from a nib.

    

    [self.viewaddSubview:self.videosView];

}


-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event

{

    [selfchooseVideos];

}


-(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<NSString *,id> *)info

{

    [picker dismissViewControllerAnimated:YEScompletion:nil];

    

//    NSString *mediaType = [info objectForKey:UIImagePickerControllerMediaType];

    

    NSURL *videoURL = [infoobjectForKey:UIImagePickerControllerMediaURL];

    

    //将视频转换成为二进制数据形式,然后可进行上传

//    NSData *videoData = [NSData dataWithContentsOfURL:videoURL];


    NSLog(@"%@",videoURL);

    

    MPMoviePlayerController *play = [[MPMoviePlayerControlleralloc] initWithContentURL:videoURL];

    

    //iOS 3.2 7.0的方法

    UIImage *thumbnail_image = [playthumbnailImageAtTime:1.0timeOption:MPMovieTimeOptionNearestKeyFrame];

//    UIImage *thumbnail_image = [play requestThumbnailImagesAtTimes:[NSArray arrayWithObject:[NSNumber numberWithInteger:1.0]] timeOption:MPMovieTimeOptionNearestKeyFrame];

#if 0

    //ios 7.0 之后的方法,这个地方我没用测试,因为我通知是一个短板,我以后进行完善

    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(handleThumbnailImageRequestFinishNotification:) name:MPMoviePlayerThumbnailImageRequestDidFinishNotification object:play];

    [play requestThumbnailImagesAtTimes:@[@1] timeOption:MPMovieTimeOptionNearestKeyFrame];

#endif

    self.videosView.image = thumbnail_image;

}


-(void)handleThumbnailImageRequestFinishNotification:(NSNotification*)notification

{

    NSDictionary *userinfo = [notification userInfo];

    NSError* value = [userinfoobjectForKey:MPMoviePlayerThumbnailErrorKey];

    if (value != nil)

    {

        NSLog(@"Error creating video thumbnail image. Details: %@", [valuedebugDescription]);

    }

    else

    {

        UIImage *thumbnail = [userinfovalueForKey:MPMoviePlayerThumbnailImageKey];

    }

}


如果大家有更好的方法,请提出供我学习参考,大家同时进步

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这可能是因为在 iOS 视频需要在用户交互的情况下才能自动播放,否则会被视为自动播放而被阻止。如果你在获取视频第一时,视频还没有被用户交互过,那么就会出现黑屏的情况,而且视频也无法播放。 为了解决这个问题,你需要在用户交互的情况下先播放一段视频,然后再获取视频第一。以下是一个修改后的示例代码: ```javascript function captureFirstFrameFromVideo(videoUrl, callback) { const video = document.createElement('video'); video.crossOrigin = 'anonymous'; video.src = videoUrl; video.onloadedmetadata = function() { // 先播放视频 video.play().then(() => { const canvas = document.createElement('canvas'); canvas.width = this.videoWidth; canvas.height = this.videoHeight; const ctx = canvas.getContext('2d'); ctx.drawImage(this, 0, 0); const imgData = canvas.toDataURL('image/png'); callback(imgData); // 获取完第一后暂停视频 video.pause(); video.currentTime = 0; }).catch((error) => { console.log(error); }); }; } ``` 在这个函数,我们在 `onloadedmetadata` 回调函数,创建了一个 `video` 元素,并将其设置为 `videoUrl`。然后,我们在 `play` 方法播放视频,并在播放成功后获取视频第一。获取完第一后,我们暂停视频,并将视频的当前播放时间设置为 0。这样做可以确保视频不会自动播放,同时也不会影响到其他地方对于视频的播放控制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值