ios - AR App 根据 ARImageAnchor 播放不同的视频
问题描述
我正在为 iOS 创建一个 AR 应用程序来检测立方体上的图像(--> 要识别 6 个不同的图像)。当检测到一个图像时,应该播放一个视频 - 每个不同的图像都有一个不同的视频(对于图像 1,应该播放视频 1...)。
我的问题是我不知道如何跟踪当前跟踪的图像以及要播放的视频
现在,该应用程序跟踪不同的图像,但始终播放相同的视频(视频“1”.mp4)
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
let configuration = ARImageTrackingConfiguration()
if let trackedImages = ARReferenceImage.referenceImages(inGroupNamed: "ARImages", bundle: Bundle.main) {
configuration.trackingImages = trackedImages
configuration.maximumNumberOfTrackedImages = 6
}
sceneView.session.run(configuration)
}
override func viewWillDisappear(_ animated: Bool) {
super.viewWillDisappear(animated)
sceneView.session.pause()
}
func renderer(_ renderer: SCNSceneRenderer, didAdd node: SCNNode, for anchor: ARAnchor) {
guard let imageAnchor = anchor as? ARImageAnchor,
let fileUrlString = Bundle.main.path(forResource: "1", ofType: "mp4") else {
return
}
let videoItem = AVPlayerItem(url: URL(fileURLWithPath: fileUrlString))
let player = AVPlayer(playerItem: videoItem)
let videoNode = SKVideoNode(avPlayer: player)
player.play()
...
}
如何识别当前的 ImageAnchor 并链接相关视频?
解决方案
您可以给 ARReferenceImage 一个名称,因此一种方法是为图像和关联的视频文件提供相同的名称。
guard let imageAnchor = anchor as? ARImageAnchor,
let name = imageAnchor.referenceImage.name,
let fileUrlString = Bundle.main.path(forResource: name, ofType: "mp4") else {
return
}
let videoItem = AVPlayerItem(url: URL(fileURLWithPath: fileUrlString))
let player = AVPlayer(playerItem: videoItem)
let videoNode = SKVideoNode(avPlayer: player)
player.play()
推荐阅读
- react-native - 键盘覆盖 react-native-elements 输入
- javascript - 尝试安装聚合物时出现 npm 错误
- typescript - 如何将查询的值分配给全局变量?
- google-bigquery - 如何将一系列参数传递到 TVF 以获取 Big Query 中的一系列表
- rcpp - 为 Rcpp 函数中的参数设置“NULL”默认值
- javascript - 如何从动态创建的选择元素中获取选定选项的值?
- c++ - 如何修改文件的 LastAccess 时间属性
- c# - 当多个用户同时通过 ASP.NET API 2 发布订单时,无法在 SQL Server 数据库中保存少量订单
- java - 找不到以下类: - android.support.constraint.ConstraintLayou
- java - 有没有办法在不使用循环的情况下获取列表中对象的索引