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

宁波网站优化软件南昌网站建设推广专家

宁波网站优化软件,南昌网站建设推广专家,知名的深圳小程序开发公司,wordpress中文 插件细心的读者会发现在在​​Day1​​​和​​Day2​​​的示例中我们使用的都是​​WindowGroup​​。 main struct visionOSDemoApp: App {var body: some Scene {WindowGroup {ContentView()}} } 本节我们来认识在visionOS开发中会经常用到的另一个概念​​ImmersiveSpace​​…细心的读者会发现在在​​Day1​​​和​​Day2​​​的示例中我们使用的都是​​WindowGroup​​。 main struct visionOSDemoApp: App {var body: some Scene {WindowGroup {ContentView()}} } 本节我们来认识在visionOS开发中会经常用到的另一个概念​​ImmersiveSpace​​。 沉浸式空间为内容提供了一个无界的区域可在空间内控制内容的大小和摆放位置。在获取用户的授权后我们还可以使用开启了沉浸空间的ARKit来将内容集成到周遭环境中。例如可以使用ARKit场景重建来获取家具的网格(mesh)及其附近的对象让内容可以与网格进行交互。 首先我们需要创建一个​​ViewModel.swift​​文件用于进行内容的相关配置。 import SwiftUI import RealityKit import ARKitMainActor class ViewModel: ObservableObject {private let session ARKitSession()private let worldTracking WorldTrackingProvider()private var contentEntity Entity()func setupContentEntity() - Entity {let box ModelEntity(mesh: .generateBox(width: 0.5, height: 0.5, depth: 0.5))contentEntity.addChild(box)return contentEntity}func runSession() async {print(WorldTrackingProvider.isSupported: \(WorldTrackingProvider.isSupported))print(PlaneDetectionProvider.isSupported: \(PlaneDetectionProvider.isSupported))print(SceneReconstructionProvider.isSupported: \(SceneReconstructionProvider.isSupported))print(HandTrackingProvider.isSupported: \(HandTrackingProvider.isSupported))Task {let authorizationResult await session.requestAuthorization(for: [.worldSensing])for (authorizationType, authorizationStatus) in authorizationResult {print(Authorization status for \(authorizationType): \(authorizationStatus))switch authorizationStatus {case .allowed:breakcase .denied:// TODObreakcase .notDetermined:breakunknown default:break}}}Task {try await session.run([worldTracking])for await update in worldTracking.anchorUpdates {switch update.event {case .added, .updated:print(Anchor position updated.)case .removed:print(Anchor position now unknown.)}}}} } 在​​setupContentEntity​​​方法中我们通过​​ModelEntity​​​创建了一个模型实体其中对​​mesh​​​参数使用​​MeshResource.generateBox​​创建了一个立方体可使用参数的说明如下 mesh: 定义模型几何形状的网格。materials: 定义模型外观的材质资源。collisionShape: 定义合成碰撞开关的形状资源集合。mass: 按公斤计的模型质量。 另一个异步方法​​runSession​​​用于进行配置和授权的处理其中包含两个​​Task​​。 通常我们会创建一个​​ImmersiveView​​来显示沉浸空间的效果但本例我们都放到了入口文件中 import SwiftUI import RealityKitmain struct visionOSDemoApp: App {StateObject var model ViewModel()var body: some SwiftUI.Scene {ImmersiveSpace {RealityView { content incontent.add(model.setupContentEntity())}.task{await model.runSession()}}} } 注意因为这里导入了​​RealityKit​​​所以为避免歧义我们使用了​​SwiftUI.Scene​​​然后在主体内容中是一个​​RealityView​​​其中添加了我们在​​ViewModel​​​中所创建的立方体同时使用异步任务去执行授权部分的​​runSession()​​方法。 代码部分就是这么多但在运行应用前我们还要配置一下​​Info.plist​​​文件我们需要将​​Preferred Default Scene Session Role​​​选项修改为​​Immersive Space Application Session Role​​ 这时运行应用就会看到本文前面显示的效果最后我们再来了解一个调试的工具在代码区下方点击图标即可打开Visualizations弹窗通过显示检测到表面、遮挡和锚点等来辅助我们的开始我们的示例图片便是勾选了​​Surfaces​​之后的效果。 示例代码​​GitHub仓库​​ 其它相关内容请见​​虚拟现实(VR)/增强现实(AR)visionOS开发学习笔记​​
http://www.huolong8.cn/news/52582/

相关文章:

  • 做旅行的网站微网站 案例
  • 织梦cms 做视频网站wordpress 文章页不显示侧边栏
  • 网站建设数据处理东丽做网站公司
  • 网站建设的费用计入t型布局网站的样子
  • 韩文网站建设期末成绩管理网站开发背景
  • 电话销售做网站打官司白银区住房和城乡建设局网站
  • 宁波网站设计建站服务公司品牌设计图片
  • 深圳网站营销型建设余姚网站建设
  • 余姚厂家高端网站设计怎么免费建个人网站
  • 做网站金山区凡科网站建设网页怎么建
  • 很色h做游戏网站wordpress国外主题优化
  • 平面设计网站有哪些诚信企业查询系统
  • 大丰区城乡和住房建设局网站自己搭建小程序
  • win7 建设网站服务器wordpress 更改自带域名
  • 哪个网站看电影做便宜网页打包app
  • 网站 全屏幻灯片做的网站用户密码在哪里找
  • 东莞网站推广排名工作室是干什么的
  • 重庆公司大学派斯学院自动seo网站源码
  • 做一手楼盘的网站做物流网站注意什么
  • 网站主页设计优点给菠菜网站做支付
  • saas建站平台带导航栏的网站
  • 自己编程怎么做网站教程编写软件开发文档
  • 利用wordpress建站微信电脑网站是什么原因
  • 中国十大流量网站坪山网站建设方案
  • 内蒙古建设厅官网站重庆沙坪坝邮编
  • 简历电商网站开发经验介绍建设一个电商网站的流程是什么
  • 高端网站价格长沙招聘网站哪个最好
  • 非模板网站企业电商网站建设
  • 技术先进的网站建设学校门户网站模板
  • asp网站源码安装教程建设网站用图片需要版权