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

鄂州建设工程造价信息管理网站广州建设技术职业学院官网

鄂州建设工程造价信息管理网站,广州建设技术职业学院官网,图文型官网站,WordPress游览器标签在​​Day 4​​​中我们使用了​​ImmersiveSpace​​并在其中添加了一个立方体,但对这个立方体我们只配置了长宽高,并没有做进一步的操作。 本文中我们会通过纹理和材质对这个立方体的六个面分别进行不同的绘制。首先我们将​​ImmersiveView​​分拆…

在​​Day 4​​​中我们使用了​​ImmersiveSpace​​并在其中添加了一个立方体,但对这个立方体我们只配置了长宽高,并没有做进一步的操作。

本文中我们会通过纹理和材质对这个立方体的六个面分别进行不同的绘制。首先我们将​​ImmersiveView​​分拆出来,先新建一个​​ImmersiveView.swift​​文件,这是一个视图文件,所以请选择User Interface下的Swift View完成创建,其中的内容待我们编写完​​ViewModel​​中的代码后再进行修改。

我们通过点击界面来打开沉浸式视图,所以需要一个​​ContentView.swift​​文件来编写常规的窗口页面,在其中添加一个Toggle开关,用于打开和关闭沉浸式视图。

import SwiftUI
import RealityKitstruct ContentView: View {@State var showImmsersiveSpace = false@Environment(\.openImmersiveSpace) var openImmersiveSpace@Environment(\.dismissImmersiveSpace) var dismissImmersiveSpacevar body: some View {NavigationStack {VStack {Toggle("Show ImmersiveSpace", isOn: $showImmsersiveSpace).toggleStyle(.button)}.padding()}.onChange(of: showImmsersiveSpace) { _, newValue inTask {if newValue {await openImmersiveSpace(id: "ImmersiveSpace")} else {await dismissImmersiveSpace()}}}}
}#Preview {ContentView()
}

首先我们定义了一个​​showImmsersiveSpace​​变量供Toggle按钮开关时使用。然后要打开和关闭沉浸式空间,我们可以分别使用​​@Environment​​中的​​openImmersiveSpace​​和​​dismissImmersiveSpace​​,通过​​onChange​​修饰符来监控​​showImmsersiveSpace​​变量的变化,在切换到打开时,就打开沉浸式空间。我们需要知道打开哪一个视图,所以使用了​​id​​参数,这个参数应与应用入口文件中所设置的一致。

接下来就编写入口文件:

import SwiftUI@main
struct visionOSDemoApp: App {var body: some Scene {WindowGroup() {ContentView()}ImmersiveSpace(id: "ImmersiveSpace") {ImmersiveView()}}
}

注意这里​​ImmersiveSpace​​中所添加的​​id​​与之前​​ContentView​​中的要保持一致,我们在后面会学到在同一个应用中也可以添加多个​​WindowGroup​​,同样通过配置​​id​​进行区分。

接下来是核心文件​​ViewModel.swift​​,

import SwiftUI
import RealityKit@MainActor class ViewModel: ObservableObject {private var contentEntity = Entity()func setupContentEntity() -> Entity {return contentEntity}func addCube() {guardlet texture1 = try? TextureResource.load(named: "Number_1"),let texture2 = try? TextureResource.load(named: "Number_2"),let texture3 = try? TextureResource.load(named: "Number_3"),let texture4 = try? TextureResource.load(named: "Number_4"),let texture5 = try? TextureResource.load(named: "Number_5"),let texture6 = try? TextureResource.load(named: "Number_6")else {fatalError("Unable to load texture.")}let entity = Entity()var material1 = SimpleMaterial()var material2 = SimpleMaterial()var material3 = SimpleMaterial()var material4 = SimpleMaterial()var material5 = SimpleMaterial()var material6 = SimpleMaterial()material1.color = .init(texture: .init(texture1))material2.color = .init(texture: .init(texture2))material3.color = .init(texture: .init(texture3))material4.color = .init(texture: .init(texture4))material5.color = .init(texture: .init(texture5))material6.color = .init(texture: .init(texture6))entity.components.set(ModelComponent(mesh: .generateBox(width: 0.5, height: 0.5, depth: 0.5, splitFaces: true),materials: [material1, material2, material3, material4, material5, material6]))entity.position = SIMD3(x: 0, y: 1, z: -2)contentEntity.addChild(entity)}
}

同样我们创建了​​setupContentEntity()​​方法,但并没有在方法里添加任何模型,而是将添加的工作交给了​​addCube()​​方法,整个方法虽然很长,但有大量重复的代码,分别为六个面设置不同的图片。

  1. 通过​​TextureResource.load()​​方法设置了不同的纹理
  2. 接着使用​​SimpleMaterial()​​创建了六个材质
  3. 通过材质的​​color​​属性分别添加前面配置好的纹理

​Number_1.jpg​​等图片请见我们GitHub的演示代码,我们先来说一下visionOS中的材质,常见的材质请见下图:

材质 Material

其中​​PhysicallyBasedMaterial​​也即PBR和​​SimpleMaterial​​是带光照信息的,而​​UnlitMaterial​​和​​VideoMaterial​​都是不带光照信息的。

在​​ModelComponent​​方法中,我们使用了​​mesh​​和​​materials​​参数,​​mesh​​参数我们同样使用了​​MeshResource.generateBox​​来创建一个立方体,不同的是这次我们指定了​​splitFaces​​参数,该参数设为​​true​​表示顶点不进行合并,因为我们要对六个面分别设置颜色或图像,不指定该参数六个面都会使用相同的材质,在本例中也就是都显示为​​1​​。

最后我们配置了​​position​​,这里x, y, z坐标轴方向示意如下:

visionOS坐标轴方向

接下来我们修改​​ImmersiveView.swift​​的内容如下:

import SwiftUI
import RealityKitstruct ImmersiveView: View {@StateObject var model = ViewModel()private var contentEntity = Entity()var body: some View {RealityView { content incontent.add(model.setupContentEntity())model.addCube()}}
}

这里的代码相对简单,就是在​​RealityView​​中展示​​ViewModel​​中所添加的模型。

在运行应用前将Info.plist文件中的Preferred Default Scene Session Role切换回Window Application Session Role

点击Show ImmersiveSpace按钮,会得到如下界面:

Show ImmersiveSpace

再次点击按钮就会收起这个模型。

示例代码:​​GitHub仓库​​

其它相关内容请见​​虚拟现实(VR)/增强现实(AR)&visionOS开发学习笔记​​

http://www.yayakq.cn/news/738733/

相关文章:

  • 宁波企业自助建站系统WordPress首页播放音乐
  • 大型门户网站制作流程工商工事上哪个网站做
  • 带产品展示的个人网站模板协会网站建设必要性
  • 北京保障性住房建设投资中心网站低学历吃香的十大职业
  • wpf可以做网站吗柳州网站定制
  • 长春网站建设wordpress 媒体库空白
  • 专业的营销型网站制作金阊做网站价格
  • 深圳有做网站的公司660元免费建站平台哪个好
  • 网站建设方案进行工期安排wordpress本地图片不显示
  • 济南品牌网站建设郓城住房和城乡建设局网站
  • 芜湖做网站哪个公司好Wordpress query 参数
  • 上海网站建设seo零基础可以做网站吗
  • 安阳网站怎么优化公司建设网站的申请信用卡
  • 视频制作网站推荐seo公司怎样找客户
  • 兰州优化网站公司制作网站需要多少时间
  • 东莞广告公司有哪些宁波seo平台
  • 蓝色大气企业网站phpcms模板个人网站备案 拍照
  • 南京做中英文网站设计WordPress 视频cdn
  • 河北省建设信息中心网站生成小程序
  • 无锡网站优化价格手机制作封面教程网站
  • 临沂网站建设多少钱购物网站的图片轮播怎么做
  • 济宁营销型网站建设东莞建设工程招标网
  • 网站注销申请怎么做淘宝客网站赚钱吗
  • 网页生成应用seo是什么车
  • 素材下载网站开发常见的网络营销推广方法
  • 太原网站推广优化wordpress批量删除图片
  • 数码家电商城网站源码wap网站是什么
  • 榆林华科网站建设58企业网站如何做
  • 泰安集团网站建设多少钱400电话安装佛山营销网站建设
  • 四川网站网站建设平台推广公众平台营销