ARKit 在模型上播放视频(附进度控制)

国际惯例先上效果图

Untitled.gif

原理

把模型的material 设置成AVPlayer  就可以了

SCNMaterial * material = [[SCNMaterial alloc]init];

material.diffuse.contents = self.player;

self.showNode.geometry.materials = @[material];

代码

//
//  ViewController.m
//  palyVoidOnSCNNode
//
//  Created by LJP on 2018/5/3.
//  Copyright © 2018年 ljp. All rights reserved.
//

#import "ViewController.h"

@interface ViewController () <ARSCNViewDelegate>

@property (nonatomic, strong) IBOutlet ARSCNView *sceneView;

/**
 *  添加模型按钮
 */
@property (nonatomic, strong) UIButton * addNodeBtn;

/**
 *  把视频加在模型上的按钮
 */
@property (nonatomic, strong) UIButton * playVoidBtn;

/**
 *  播放器对象
 */
@property (nonatomic, strong) AVPlayer *player;

/**
 *  展示的模型
 */
@property (nonatomic, strong) SCNNode *showNode;

/**
 *  调节进度的滑竿
 */
@property (nonatomic, strong) UISlider *slider;

/**
 *  调节的时间
 */
@property (nonatomic, assign) CMTime chaseTime;

@end

    
@implementation ViewController

#pragma mark ========================= 生命周期 =========================
- (void)viewDidLoad {
    [super viewDidLoad];
    
    [self initUI];
}

- (void)viewWillAppear:(BOOL)animated {
    [super viewWillAppear:animated];
    
    ARWorldTrackingConfiguration *configuration = [ARWorldTrackingConfiguration new];

    [self.sceneView.session runWithConfiguration:configuration];
}

- (void)viewWillDisappear:(BOOL)animated {
    [super viewWillDisappear:animated];
    
    [self.sceneView.session pause];
}


#pragma mark ========================= 初始化方法 ========================
- (void)initUI {
    
    self.sceneView.delegate = self;
    SCNScene *scene = [SCNScene new];
    self.sceneView.scene = scene;
    
    [self.sceneView addSubview:self.addNodeBtn];
    [self.sceneView addSubview:self.playVoidBtn];
    [self.sceneView addSubview:self.slider];

}


#pragma mark ========================= 私有方法 ==========================
- (void)trySeekToChaseTime{
    
    if (_player.currentItem.status == AVPlayerItemStatusReadyToPlay) {
        
        [self actuallySeekToTime];
        
    }
    
}

- (void)actuallySeekToTime {
    
    CMTime seekTimeInProgress = self.chaseTime;

    [self.player seekToTime:seekTimeInProgress
            toleranceBefore:kCMTimeZero
            toleranceAfter :kCMTimeZero
          completionHandler:^(BOOL finished) {
        
//        [self.player play]; 打开就会自动播放了

    }];
    
}

#pragma mark ========================= 事件处理 ==========================
- (void)clickAddNodeBtn {
    
    [self.sceneView.scene.rootNode addChildNode:self.showNode];
    
}

- (void)clickPlayVoidBtn {
   
    SCNMaterial * material = [[SCNMaterial alloc]init];
    
    material.diffuse.contents = self.player;
    
    self.showNode.geometry.materials = @[material];
    
    [self.player play];
    
}

- (void)playerProcess:(UISlider *)slider{

    NSString * urlStr = [[NSBundle mainBundle]pathForResource:@"movie.MP4" ofType:nil];
    
    NSURL * url = [NSURL fileURLWithPath:urlStr];
    
    AVAsset * asset = [AVAsset assetWithURL:url];
    
    float totalTime = CMTimeGetSeconds(asset.duration);
    
    [self.player pause];
    
    CMTime newChaseTime = CMTimeMake(totalTime * slider.value * asset.duration.timescale, asset.duration.timescale);
    
    self.chaseTime = newChaseTime;
    
    [self actuallySeekToTime];

}


#pragma mark ========================= 代理方法 ==========================


#pragma mark ========================= 访问器方法 =========================
- (UIButton *)addNodeBtn {
    if (_addNodeBtn == nil) {
        _addNodeBtn = [UIButton buttonWithType:UIButtonTypeSystem];
        _addNodeBtn.frame = CGRectMake(self.view.frame.size.width/4-40, self.view.frame.size.height-160, 80, 48);
        [_addNodeBtn setTitle:@"添加模型" forState:0];
        [_addNodeBtn addTarget:self action:@selector(clickAddNodeBtn) forControlEvents:UIControlEventTouchUpInside];
    }
    return _addNodeBtn;
}

- (UIButton *)playVoidBtn {
    if (_playVoidBtn == nil) {
        _playVoidBtn = [UIButton buttonWithType:UIButtonTypeSystem];
        _playVoidBtn.frame = CGRectMake(self.view.frame.size.width/4*3-40, self.view.frame.size.height-160, 80, 48);
        [_playVoidBtn setTitle:@"播放视频" forState:0];
        [_playVoidBtn addTarget:self action:@selector(clickPlayVoidBtn) forControlEvents:UIControlEventTouchUpInside];
    }
    return _playVoidBtn;
}

- (UISlider *)slider{
    if (!_slider) {
        _slider = [[UISlider alloc] initWithFrame:CGRectMake(30, 600, 300, 30)];
        _slider.maximumValue = 1;
        _slider.minimumValue = 0;
        _slider.thumbTintColor = [UIColor blueColor];
        _slider.tintColor = [UIColor redColor];
        _slider.continuous = YES;
        [_slider addTarget:self action:@selector(playerProcess:) forControlEvents:UIControlEventValueChanged];
    }
    return _slider;
}

-(AVPlayer *)player{
    if (!_player) {
        AVPlayerItem *playerItem=[self getPlayItem:0];
        _player=[AVPlayer playerWithPlayerItem:playerItem];
    }
    return _player;
}

-(AVPlayerItem *)getPlayItem:(int)videoIndex{
    NSString * urlStr = [[NSBundle mainBundle]pathForResource:@"movie.MP4" ofType:nil];
    
    NSURL *url=[NSURL fileURLWithPath:urlStr];
    
    AVPlayerItem *playerItem=[AVPlayerItem playerItemWithURL:url];
    return playerItem;
}

- (SCNNode *)showNode {
    if (_showNode == nil) {
        _showNode = [SCNNode new];
        SCNBox * box = [SCNBox boxWithWidth:0.3 height:0.3 length:0.3 chamferRadius:0];
        _showNode.geometry = box;
        _showNode.position = SCNVector3Make(0, 0.5, -1);
    }
    return _showNode;
}

@end

代码

我的博客即将搬运同步至腾讯云+社区

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,530评论 25 709
  • 昨晚写了一篇《成为一个华德福老师的准备》,今天便遇到一个同事,见面第一句话问到,“你是明年一年级的主班啊?”我瞬间...
    在水之湄_ym阅读 260评论 0 1
  • 文/暄妍❣若梅在路上孤身跋涉在路上前路茫茫,黑暗崎岖也许争不过天与地也许逃不脱生与死也许天道不一定酬勤但是,那又如...
    暄妍若梅阅读 692评论 6 4
  • 深夜里电话铃响,是朋友的电话。她说:“忍不住要给你打个电话,我忽然心里难过,非常非常难过,就是这样,没别的。”说...
    大宝最最最酷阅读 269评论 2 1
  • 文来着高哥视界 作者:高哥 吃完晚饭后,一岁半的女儿在手机上听儿歌,老爸在手机上看搞笑视频和鸡汤味十足的段子,媳妇...
    高哥视界阅读 194评论 0 0