SCNGeometry
学习目标
1.了解SceneKit 游戏框架中系统包含的几何对象.
2.学习如何将几何形状物体绑定的节点上,显示到视图中.
系统提供的几何形状讲解
正方体
data:image/s3,"s3://crabby-images/bf3e0/bf3e004b7d659b82a4f99f8836c4388ddd0a09ab" alt=""
代码如下:
SCNBox *box = [SCNBox boxWithWidth:1 height:1 length:1 chamferRadius:0];
box.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *boxNode = [SCNNode node];
boxNode.position = SCNVector3Make(0, 0, 0);
boxNode.geometry = box;
[scnView.scene.rootNode addChildNode:boxNode];
创建平面
data:image/s3,"s3://crabby-images/ff79a/ff79a72236fdb9af34c7a2a811407f80d780fc83" alt=""
代码如下:
SCNPlane *plane =[SCNPlane planeWithWidth:2 height:2];
plane.firstMaterial.diffuse.contents = [UIImage imageNamed:@"2.PNG"];
SCNNode *planeNode = [SCNNode nodeWithGeometry:plane];
planeNode.position = SCNVector3Make(0, 0, 0);
[scnView.scene.rootNode addChildNode:planeNode];
金子塔
data:image/s3,"s3://crabby-images/43612/43612c50afe349a515450415b58299e5a4441c77" alt=""
代码如下:
SCNPyramid *pyramid = [SCNPyramid pyramidWithWidth:1 height:1 length:1];
pyramid.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *pyramidNode = [SCNNode nodeWithGeometry:pyramid];
pyramidNode.position = SCNVector3Make(0, 0, 0);
[scnView.scene.rootNode addChildNode:pyramidNode];
球体
data:image/s3,"s3://crabby-images/c2ae8/c2ae8bc3e563467982c058dc2027f815d94576c6" alt=""
代码如下:
SCNSphere *sphere = [SCNSphere sphereWithRadius:1];
sphere.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *sphereNode =[SCNNode nodeWithGeometry:sphere];
sphereNode.position = SCNVector3Make(0, 0, 0);
[scnView.scene.rootNode addChildNode:sphereNode];
圆柱体
data:image/s3,"s3://crabby-images/5fe0e/5fe0e314a9914865c76a88c9f45f460388ec2578" alt=""
代码如下:
SCNCylinder *cylinder = [SCNCylinder cylinderWithRadius:1 height:2];
cylinder.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *cylinderNode =[SCNNode nodeWithGeometry:cylinder];
cylinderNode.position = SCNVector3Make(0, 0, 0);
[scnView.scene.rootNode addChildNode:cylinderNode];
圆锥体
data:image/s3,"s3://crabby-images/c3149/c3149ae27df00927d545a1f281e764c0704240eb" alt=""
代码如下:
SCNCone *cone = [SCNCone coneWithTopRadius:0 bottomRadius:1 height:1];
cone.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *coneNode = [SCNNode nodeWithGeometry:cone];
coneNode.position = SCNVector3Make(0,0, 0);
[scnView.scene.rootNode addChildNode:coneNode];
管道
data:image/s3,"s3://crabby-images/0e8d8/0e8d80332e2994f1e1e7ea670064d75602c14a95" alt=""
代码如下:
SCNTube *tube = [SCNTube tubeWithInnerRadius:1 outerRadius:1.2 height:2];
tube.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *tubeNode =[SCNNode nodeWithGeometry:tube];
tubeNode.position = SCNVector3Make(0, 0, 0);
[scnView.scene.rootNode addChildNode:tubeNode];
环面
data:image/s3,"s3://crabby-images/b2662/b26623bd23a5813606a2b81457d69ec7f390b291" alt=""
代码如下:
SCNTorus *torus = [SCNTorus torusWithRingRadius:1 pipeRadius:0.5];
torus.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *torusNode = [SCNNode nodeWithGeometry:torus];
torusNode.position = SCNVector3Make(0, 0, 0);
[scnView.scene.rootNode addChildNode:torusNode];
地板
data:image/s3,"s3://crabby-images/ea714/ea7143c2b16fd3a4047f1e2b1fd3e959ccf91994" alt=""
代码如下:
SCNFloor *floor = [SCNFloor floor];
floor.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *floorNode = [SCNNode nodeWithGeometry:floor];
floorNode.position = SCNVector3Make(0, -5, 0);
[scnView.scene.rootNode addChildNode:floorNode];
立体文字
data:image/s3,"s3://crabby-images/afcbf/afcbf210e6d7c824551a050c2fa3e98c47ceef23" alt=""
代码如下:
SCNText *text = [SCNText textWithString:@"好好学习" extrusionDepth:0.5];
text.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
text.font = [UIFont systemFontOfSize:1];
SCNNode *textNode =[SCNNode nodeWithGeometry:text];
textNode.position = SCNVector3Make(-2, 0, 0);
[scnView.scene.rootNode addChildNode:textNode];
自定义形状
data:image/s3,"s3://crabby-images/ccffb/ccffb0fdec510c336d2ba32453d3e45f0fe1b2a7" alt=""
代码如下:
// 定义贝塞尔曲线
SCNShape *shape = [SCNShape shapeWithPath:[UIBezierPath bezierPathWithRoundedRect:CGRectMake(0, 0, 1, 1) cornerRadius:0.5] extrusionDepth:3];
shape.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
SCNNode *shapdeNode =[SCNNode nodeWithGeometry:shape];
[scnView.scene.rootNode addChildNode:shapdeNode];
手把手教你写代码
第一步.创建工程
data:image/s3,"s3://crabby-images/a2b0b/a2b0b545145e631185ae961338bc442ef2cf1aee" alt=""
第二步.添加游戏框架
data:image/s3,"s3://crabby-images/f90fb/f90fb211dce613fc02575fb319115c05d20ca768" alt=""
第三步.添加游戏专用视图SCNView
SCNView *scnView = [[SCNView alloc]initWithFrame:self.view.bounds];
scnView.backgroundColor = [UIColor blackColor];
[self.view addSubview:scnView];
scnView.allowsCameraControl = TRUE;
第四步.创建游戏场景
scnView.scene = [SCNScene scene];
第五步.添加照相机
SCNNode *cameraNode =[SCNNode node];
cameraNode.camera = [SCNCamera camera];
cameraNode.position = SCNVector3Make(0, 0, 5);
[scnView.scene.rootNode addChildNode:cameraNode];
第六步.添加节点并且绑定几何形状物体
// 创建几何对象
SCNTorus *torus = [SCNTorus torusWithRingRadius:1 pipeRadius:0.5];
torus.firstMaterial.diffuse.contents = [UIImage imageNamed:@"1.PNG"];
// 绑定到节点上
SCNNode *torusNode = [SCNNode nodeWithGeometry:torus];
// 设置节点的位置
torusNode.position = SCNVector3Make(0, 0, 0);
// 添加到场景中去
[scnView.scene.rootNode addChildNode:torusNode];
运行结果:
data:image/s3,"s3://crabby-images/c97dc/c97dc0d51eb2804a20db1af8997458db4c904946" alt=""
问题:有人问我SegmentCount属性到底干了什么事情?
下面举个例子演示
创建一个有切面的正方体
let box = SCNBox(width: 1, height: 1, length: 1, chamferRadius: 0.5)
data:image/s3,"s3://crabby-images/57638/57638e74ed9fb9a91025d1832cd2ca2a8c9b7faa" alt=""
设置一下下面属性
box.chamferSegmentCount = 20
data:image/s3,"s3://crabby-images/b1f7c/b1f7cbf7a5762e87217ed79e228fbd9923a4e782" alt=""
上面的现象就是答案,不需要我解释了吧!
本节内容比较重要,请大家务必掌握,后面需要内容都建立在今天的内容之上!
网友评论