ARKit应用之识别图像播放视频

卧闻海棠花

前言

ARKit为iOS系统提供了对图像的识别功能。可通过检测用户环境中的已知2D图像,使用其位置放置AR内容。其中的AR内容可以是一个立体模型,也可以是一张图片或一个视频。

这一功能必将使得未来的app更加有趣,也让我们有了新的实现形式,让我们来尝试一下基于ARkit的图片识别功能在app内播放视频吧。

环境:iOS 11.3+ | Xcode 10.0+

Framework:ARkit

启用图像检测

首先,构建目标图像

目标图像即通过摄像头扫描识别的目标图像,使用自己的图像进行检测,需要将目标图像添加到Xcode中的Assets目录中。

添加目标图片

  1. 打开项目的Assets目录,然后添加新的AR资源组。
  2. 将所需添加的图片添加到创建的资源组中。
  3. 对于每个图片,使用检查器来描述你希望在用户的真实环境中找到它的图像的物理大小。(可使用预览来查看图片大小,注意单位,获取后必须添加图片的Size,图片的宽高不得小于480 pixels)

使用ARkit需要引入所需的系统库:

1
2
#import <SceneKit/SceneKit.h>
#import <ARKit/ARKit.h>

viewWillAppear:

1
2
3
4
5
6
7
8
9
// 添加一个或多个目标图像
ARWorldTrackingConfiguration *configuration = [ARWorldTrackingConfiguration new];
configuration.detectionImages = [ARReferenceImage referenceImagesInGroupNamed:@"AR Resources" bundle:nil];

// 创建'world-tracking'配置
[self.sceneView.session runWithConfiguration:configuration options:ARSessionRunOptionResetTracking | ARSessionRunOptionRemoveExistingAnchors];

// 使用runWithConfiguration:方法使用配置运行会话
[self.sceneView.session runWithConfiguration:configuration];

初始化Scene View

Main.storyboard中添加ARSCNView,设置全屏幕约束。

viewDidLoad中初始化sceneView:

1
2
3
self.sceneView.delegate = self;
SCNScene *scene = [SCNScene new];
self.sceneView.scene = scene;

可视化图像结果

在前文中我们已经添加了识别的目标图像,当应用程序检测到目标图像时我们需要可视化图像结果,根据当前目标,我们在目标图像上播放视频。

在这里,需要实现ARSCNViewDelegate中的代理方法:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#pragma mark - ARSCNViewDelegate

- (void)renderer:(id<SCNSceneRenderer>)renderer didAddNode:(SCNNode *)node forAnchor:(ARAnchor *)anchor {
ARImageAnchor *imageAnchor = (ARImageAnchor *)anchor;

// 获取参考图片对象
ARReferenceImage *referenceImage = imageAnchor.referenceImage;
// 根据图片对象播放对应视频
if (referenceImage.name) {
NSString *fileName = referenceImage.name;
[self setFileForPlayerWithFileName:fileName];

SCNNode *tempNode = [SCNNode new];
CGFloat imageWidth = referenceImage.physicalSize.width;
CGFloat imageHeight = referenceImage.physicalSize.height;

SCNBox *bgBox = [SCNBox boxWithWidth:imageWidth height:imageHeight length:0.01 chamferRadius:0];
tempNode.geometry = bgBox;
tempNode.eulerAngles = SCNVector3Make(-M_PI/2.0, 0.0, 0.0);
tempNode.opacity = 1.0;

SCNMaterial *material = [[SCNMaterial alloc] init];
material.diffuse.contents = self.player;
tempNode.geometry.materials = @[material];
[self.player play];

[node addChildNode:tempNode];
}
}

- (void)setFileForPlayerWithFileName:(NSString *)fileName {
NSString *urlStr = [[NSBundle mainBundle] pathForResource:fileName ofType:@"mp4"];
NSURL *url = [NSURL fileURLWithPath:urlStr];
AVPlayerItem *playerItem = [AVPlayerItem playerItemWithURL:url];
self.player = [[AVPlayer alloc] initWithPlayerItem:playerItem];
}

至此,我们就能简单地实现利用ARKit识别图像并播放对应的视频。

为了更加清楚的展现,附上代码以供参考:RecognizingImagesToPlayVideo

其中的视频文件可前往这里下载,当然,你也可以相应修改项目中配置更换你的目标图像和视频文件。