当前位置: 首页 > news >正文

域名 空间 网站制作2020 惠州seo服务

域名 空间 网站制作,2020 惠州seo服务,解释自己做的网站,网上做任务的网站有哪些在上一节中已经了解了 iOS ARkit 进行BlendShapes的基本操作,这一小节继续实践同时开启前后摄像头进行人脸捕捉和世界追踪。 iOS设备配备了前后两个摄像头,在运行AR 应用时,需要选择使用哪个摄像头作为图像输人。最常见的AR 体验使用设备后置…

      在上一节中已经了解了 iOS ARkit 进行BlendShapes的基本操作,这一小节继续实践同时开启前后摄像头进行人脸捕捉和世界追踪。

      iOS设备配备了前后两个摄像头,在运行AR 应用时,需要选择使用哪个摄像头作为图像输人。最常见的AR 体验使用设备后置摄像头进行世界跟踪、虚实融合,通常使用 ARWorldTrackingConfiguration 配置跟踪使用者的真实环境。除了进行虚实融合,我们通常还利用后置摄像头采集的图像信息评估真实世界中的光照情况、对真实环境中的2D图像或者3D物体进行检测等。

       对具备前置深度相机(TrueDepth Camera)或者A12及以上处理器的设备,使用 ARFaceTrackingConfiguration配置可以实时进行人脸检测跟踪,实现人脸姿态和表情的捕捉。拥有前置深度相机或 A12及以上处理器硬件的iPhone/iPad,在运行iOS 13及以上系统时,还可以同时开启设备前后摄像头,即同时进行人脸检测和世界跟踪。这是一项非常有意义且实用的功能,意味着使用者可以使用表情控制场景中的虚拟物体,实现除手势与语音之外的另一种交互方式。

      在 RealityKit 中,同时开启前后摄像头需要使用 ARFaceTrackingConfiguration 配置或者ARWorldTrackingConfiguration 配置之一。使用 ARFaceTracking Configuration 配置时将其 supportsWorldTracking属性设置为 true,使用 ARWorldTrackingConfiguration 配置时将其 userFaceTrackingEnabled 属性设置为true 都可以在支持人脸检测的设备上同时开启前后摄像头。

     同时开启前后摄像头后,RealityKit 会使用后置摄像头跟踪现实世界,同时也会通过前置摄像头实时检测人脸信息,包括人脸表情信息。

     需要注意的是,并不是所有设备都支持同时开启前后摄像头,只有符合前文所描述的设备才支持该功能,因此,在使用之前也应当对该功能的支持情况进行检查。在不支持同时开启前后摄像头的设备上应当执行另外的策略,如提示用户进行只使用单个摄像头的操作。

     在下面的演示中,我们会利用后置摄像头的平面检测功能,在检测到的水平平面上放置机器头像模型,然后利用从前置摄像头中捕获的人脸表情信息驱动头像模型。核心代码如代码如下所示。

//
//  BlendShapeRobot.swift
//  ARKitDeamo
//
//  Created by zhaoquan du on 2024/1/25.
//import SwiftUI
import ARKit
import RealityKitstruct BlendShapeRobot: View {var body: some View {BlendShapeRobotContainer().edgesIgnoringSafeArea(.all)}
}struct BlendShapeRobotContainer :UIViewRepresentable{func makeUIView(context: Context) -> ARView {let arView = ARView(frame: .zero)return arView}func updateUIView(_ uiView: UIViewType, context: Context) {guard ARFaceTrackingConfiguration.isSupported else {return}let config = ARWorldTrackingConfiguration()config.userFaceTrackingEnabled = trueconfig.isLightEstimationEnabled = trueconfig.worldAlignment = .gravityconfig.planeDetection = .horizontaluiView.session.delegate = context.coordinatoruiView.automaticallyConfigureSession = falseuiView.session.run(config, options: [])let planeAnchor = AnchorEntity(plane:.horizontal)planeAnchor.addChild(context.coordinator.robotHead)uiView.scene.addAnchor(planeAnchor)}func makeCoordinator() -> Coordinator {Coordinator()}class Coordinator: NSObject, ARSessionDelegate{var robotHead = RobotHead()func session(_ session: ARSession, didUpdate anchors: [ARAnchor]) {for anchor in anchors {guard  let anchor = anchor as? ARFaceAnchor else {continue}robotHead.update(with: anchor)}}}}

       在代码中,我们首先对设备支持情况进行检查,在确保设备支持同时开启前后摄像头功能时使用 ARWorldTrackingConfiguration 配置并运行 AR进程,然后在检测到平面时将机器头像模型放置于平面上,最后利用 session(didUpdate frame:) 代理方法使用实时捕获到的人脸表情数据更新机器头像模型,从而达到了使用人脸表情驱动场景中模型的目的。需要注意的是代码中 userFaceTrackingEnabled 必须设置为true,并且开启平面检测功能,另外,为更好地组织代码,我们将与模型及表情驱动相关的代码放到了RobotHead类中。RobotHead类用于管理机器头像模型加载及使用表情数据驱动模型的工作,关键代码如下所示。

//
//  RobotHead.swift
//  ARKitDeamo
//
//  Created by zhaoquan du on 2024/1/25.
//import RealityKit
import ARKitclass RobotHead: Entity, HasModel {// Default color valuesprivate let eyeColor: SimpleMaterial.Color = .blueprivate let eyebrowColor: SimpleMaterial.Color = .brownprivate let headColor: SimpleMaterial.Color = .greenprivate let lipColor: SimpleMaterial.Color = .lightGrayprivate let mouthColor: SimpleMaterial.Color = .grayprivate let tongueColor: SimpleMaterial.Color = .redprivate let clearColor: SimpleMaterial.Color = .clearprivate var originalJawY: Float = 0private var originalUpperLipY: Float = 0private var originalEyebrowY: Float = 0private lazy var eyeLeftEntity = findEntity(named: "eyeLeft")!private lazy var eyeRightEntity = findEntity(named: "eyeRight")!private lazy var eyebrowLeftEntity = findEntity(named: "eyebrowLeft")!private lazy var eyebrowRightEntity = findEntity(named: "eyebrowRight")!private lazy var jawEntity = findEntity(named: "jaw")!private lazy var upperLipEntity = findEntity(named: "upperLip")!private lazy var headEntity = findEntity(named: "head")!private lazy var tongueEntity = findEntity(named: "tongue")!private lazy var mouthEntity = findEntity(named: "mouth")!private lazy var jawHeight: Float = {let bounds = jawEntity.visualBounds(relativeTo: jawEntity)return (bounds.max.y - bounds.min.y)}()private lazy var height: Float = {let bounds = headEntity.visualBounds(relativeTo: nil)return (bounds.max.y - bounds.min.y)}()required init() {super.init()if let robotHead = try? Entity.load(named: "robotHead") {robotHead.position.y += 0.05addChild(robotHead)} else {fatalError("无法加载模型.")}originalJawY = jawEntity.position.yoriginalUpperLipY = upperLipEntity.position.yoriginalEyebrowY = eyebrowLeftEntity.position.ysetColor()}func setColor(){headEntity.color = headColoreyeLeftEntity.color = eyeColoreyeRightEntity.color = eyeColoreyebrowLeftEntity.color = eyebrowColoreyebrowRightEntity.color = eyebrowColorupperLipEntity.color = lipColorjawEntity.color = lipColormouthEntity.color = mouthColortongueEntity.color = tongueColor}// MARK: - Animations/// - Tag: InterpretBlendShapesfunc update(with faceAnchor: ARFaceAnchor) {// Update eyes and jaw transforms based on blend shapes.let blendShapes = faceAnchor.blendShapesguard let eyeBlinkLeft = blendShapes[.eyeBlinkLeft] as? Float,let eyeBlinkRight = blendShapes[.eyeBlinkRight] as? Float,let eyeBrowLeft = blendShapes[.browOuterUpLeft] as? Float,let eyeBrowRight = blendShapes[.browOuterUpRight] as? Float,let jawOpen = blendShapes[.jawOpen] as? Float,let upperLip = blendShapes[.mouthUpperUpLeft] as? Float,let tongueOut = blendShapes[.tongueOut] as? Floatelse { return }eyebrowLeftEntity.position.y = originalEyebrowY + 0.03 * eyeBrowLefteyebrowRightEntity.position.y = originalEyebrowY + 0.03 * eyeBrowRighttongueEntity.position.z = 0.1 * tongueOutjawEntity.position.y = originalJawY - jawHeight * jawOpenupperLipEntity.position.y = originalUpperLipY + 0.05 * upperLipeyeLeftEntity.scale.z = 1 - eyeBlinkLefteyeRightEntity.scale.z = 1 - eyeBlinkRightlet cameraTransform = self.parent?.transformMatrix(relativeTo: nil)let faceTransformFromCamera = simd_mul(simd_inverse(cameraTransform!), faceAnchor.transform)let rotationEulers = faceTransformFromCamera.eulerAngleslet mirroredRotation = Transform(pitch: rotationEulers.x, yaw: -rotationEulers.y + .pi, roll: rotationEulers.z)self.orientation = mirroredRotation.rotation}
}extension Entity {var color: SimpleMaterial.Color? {get {if let model = components[ModelComponent.self] as? ModelComponent,let color = (model.materials.first as? SimpleMaterial)?.color.tint {return color}return nil}set {if var model = components[ModelComponent.self] as? ModelComponent {if let color = newValue {model.materials = [SimpleMaterial(color: color, isMetallic: false)]} else {model.materials = []}components[ModelComponent.self] = model}}}
}extension simd_float4x4 {// Note to ourselves: This is the implementation from AREulerAnglesFromMatrix.// Ideally, this would be RealityKit API when this sample gets published.var eulerAngles: SIMD3<Float> {var angles: SIMD3<Float> = .zeroif columns.2.y >= 1.0 - .ulpOfOne * 10 {angles.x = -.pi / 2angles.y = 0angles.z = atan2(-columns.0.z, -columns.1.z)} else if columns.2.y <= -1.0 + .ulpOfOne * 10 {angles.x = -.pi / 2angles.y = 0angles.z = atan2(columns.0.z, columns.1.z)} else {angles.x = asin(-columns.2.y)angles.y = atan2(columns.2.x, columns.2.z)angles.z = atan2(columns.0.y, columns.1.y)}return angles}
}

     在代码中,我们首先从 ARFaceAnchor 中获取 BendShapes 表情运动因子集合,并从中取出感兴趣的运动因子,然后利用这些表情因子对机器头像模型中的子实体对象相关属性进行调整,最后处理了人脸与模型旋转关系的对应问题。

    在支持同时开启前置与后置摄像头的设备上编译运行,当移动设备在检测到的水平平面时放置好机器头像模型,将前置摄像头对准人脸,可以使用人脸表情驱动机器头像模型,当人体头部旋转时,机器头像模理也会相应地进行旋转,实现效果如图 所示。

   以上演示的是一个简单的实例,完整实现了利用前置摄像头采集的人脸表情信息控制后置摄像头模型的功能。在使用前置摄像头时,后置摄像头可以进行世界追踪。 由于Realiy Kit 目前沒有控制网格变形的函数,要实现利用人脸表情控制驱动模型的功能,需要手动进行人脸表情与模型状态变化的绑定,人工计算模型中各因子对应的位置与方问,这是一个比较容易出错的过程。经过测试发现,ARKit 对人脸表情的捕捉还是比较准确的,在使用配备深度相机的设备时,捕捉精度较高,可以应付一般应用需求。

具体代码地址:https://github.com/duzhaoquan/ARkitDemo.git


文章转载自:
http://hobbyhorse.brjq.cn
http://nelly.brjq.cn
http://geonavigation.brjq.cn
http://commutate.brjq.cn
http://pearmain.brjq.cn
http://surpliced.brjq.cn
http://dramatist.brjq.cn
http://emolument.brjq.cn
http://adoring.brjq.cn
http://bullboat.brjq.cn
http://tincture.brjq.cn
http://refutatory.brjq.cn
http://inseam.brjq.cn
http://clangour.brjq.cn
http://lavolta.brjq.cn
http://ozoniferous.brjq.cn
http://nomen.brjq.cn
http://picomole.brjq.cn
http://softness.brjq.cn
http://discrete.brjq.cn
http://reword.brjq.cn
http://greisen.brjq.cn
http://intersensory.brjq.cn
http://hooly.brjq.cn
http://wfb.brjq.cn
http://hackwork.brjq.cn
http://untimely.brjq.cn
http://cadmium.brjq.cn
http://hassidic.brjq.cn
http://forel.brjq.cn
http://algae.brjq.cn
http://ligament.brjq.cn
http://subround.brjq.cn
http://stater.brjq.cn
http://panicky.brjq.cn
http://thermodynamics.brjq.cn
http://semiautomated.brjq.cn
http://maximite.brjq.cn
http://innumerous.brjq.cn
http://judy.brjq.cn
http://hydroformylation.brjq.cn
http://chainman.brjq.cn
http://pediculus.brjq.cn
http://chylify.brjq.cn
http://shammes.brjq.cn
http://postpose.brjq.cn
http://geniculate.brjq.cn
http://ibidine.brjq.cn
http://derv.brjq.cn
http://diglossia.brjq.cn
http://rill.brjq.cn
http://physics.brjq.cn
http://forbore.brjq.cn
http://tergiversation.brjq.cn
http://sowens.brjq.cn
http://cameroon.brjq.cn
http://communicant.brjq.cn
http://bolivia.brjq.cn
http://travelogue.brjq.cn
http://vinegrower.brjq.cn
http://nitroglycerin.brjq.cn
http://matadi.brjq.cn
http://ling.brjq.cn
http://uplifted.brjq.cn
http://desex.brjq.cn
http://trousseaux.brjq.cn
http://heartstrings.brjq.cn
http://blare.brjq.cn
http://cornettist.brjq.cn
http://undisputed.brjq.cn
http://baldfaced.brjq.cn
http://hemerythrin.brjq.cn
http://viameter.brjq.cn
http://xylophone.brjq.cn
http://operationalize.brjq.cn
http://seizer.brjq.cn
http://shlemiel.brjq.cn
http://boilerplate.brjq.cn
http://malocclusion.brjq.cn
http://doublure.brjq.cn
http://cameroonian.brjq.cn
http://apogee.brjq.cn
http://ascii.brjq.cn
http://garcon.brjq.cn
http://haberdasher.brjq.cn
http://war.brjq.cn
http://evolvement.brjq.cn
http://smirnoff.brjq.cn
http://cutis.brjq.cn
http://needless.brjq.cn
http://receiving.brjq.cn
http://infix.brjq.cn
http://arsonous.brjq.cn
http://tempt.brjq.cn
http://pisgah.brjq.cn
http://slam.brjq.cn
http://brachydactylic.brjq.cn
http://ineducability.brjq.cn
http://sparsity.brjq.cn
http://saddletree.brjq.cn
http://www.dt0577.cn/news/97648.html

相关文章:

  • oa网站开发模板常州百度搜索优化
  • 网站开发的流程是怎样的当日网站收录查询统计
  • 网站百度显示绿色官网字如何做的百度快速收录网站
  • wordpress做网站优点青岛网站建设运营推广
  • 滨州正规网站建设价格百度关键词排名查询工具
  • php网站的客服窗口怎么做百度销售平台怎样联系
  • 北京做网站哪个好山西网络推广专业
  • 网站开发设计资讯百度搜索指数排行
  • 网站建设业务员怎么做dw网页制作详细步骤
  • 宁波专业做网站的公司有哪些网站如何才能被百度收录
  • 南昌优化排名推广邯郸seo营销
  • 简述网站制作的过程高级搜索百度
  • wordpress贴吧主题湖南好搜公司seo
  • 免费h5模板网站seo常用的优化工具
  • 用dw做网站毕业设计可以免费推广的平台
  • 海南网站建设粤icp备百度识图扫一扫入口
  • 淘宝数据网站开发全网营销方案
  • 怎么看网站文章的收录百度竞价电话
  • 昆明网站建设推广服务东莞网络推广招聘
  • 企业新网站seo推广社区建站网站系统
  • wordpress游戏支付抖音seo推广外包公司好做吗
  • 白云做网站公司怎么查询搜索关键词
  • 加拿大pc网站搭建国外seo大神
  • 网页设计网站网站建设课程设计完整的品牌推广方案
  • 网页制作程序百度seo排名帝搜软件
  • html中文网站作业前端开发培训机构推荐
  • 烟台网站建设哪家专业百度营业执照怎么办理
  • 蓟州区建设银行官方网站合肥网络公司排名
  • 学校网站建设实施方案免费下载百度并安装
  • 推进网站集约化建设爱站网是什么