近来业务不忙, 研究研究iOS的3D开发, 看起来很有意思.分享下.
data:image/s3,"s3://crabby-images/b3cd7/b3cd779d99490f9b12ffce48bc18015ce700c4b9" alt=""
data:image/s3,"s3://crabby-images/da6ef/da6ef897f73587cc4eef06b62390ae62aedb5edf" alt=""
data:image/s3,"s3://crabby-images/887f4/887f4c3fc634229e43721d7098f88772a8428f00" alt=""
data:image/s3,"s3://crabby-images/c9e22/c9e2241438439c0a53a1f266aeeea6f25b41ee42" alt=""
以上是制作的一个房间魔性的渲染图
下面总结一下制作上面的模型需要做哪些工作:
1、创建项目:
创建项目采用的是game模式
data:image/s3,"s3://crabby-images/d6d94/d6d9449925769f738a7fc3efb3a0f63fc82262d3" alt=""
2、创建SCNView(场景)
SCNView的创建和常规的UIView创建是一样的。因为他继承自UIView
data:image/s3,"s3://crabby-images/2e834/2e83430c62254d6f29a410c4a702a82eefd6011d" alt=""
scnView= SCNView(frame: CGRect(x: 0, y: 0, width: view.bounds.size.width, height: view.bounds.size.height))
view.addSubview(scnView);
scnView.backgroundColor = UIColor.black
3、设置相机的信息(3D内容是以相机视角进行渲染的)
data:image/s3,"s3://crabby-images/34bf0/34bf082760ab50948cd06d28dafd8b8627105d73" alt=""
4、创建并引入SCNScene
SCNScene是一个Xcode自带的3D场景文件
data:image/s3,"s3://crabby-images/b222e/b222e4c54076b138ea0fa30a1ffd72eee7db8d6d" alt=""
引入场景文件
data:image/s3,"s3://crabby-images/0fb07/0fb078c0c20343e62d7b3836279e52766c4b6a66" alt=""
5、创建节点
创建节点采用的是贝塞尔曲线进行渲染的, 贝塞尔曲线可以创建多种自定义图形
// 绘制一个曲线
letpath =UIBezierPath()
path.lineWidth=3
path.move(to:CGPoint(x:0,y:1))
path.addLine(to:CGPoint(x:0,y: -1))
path.addLine(to:CGPoint(x:8,y: -1))
path.addLine(to:CGPoint(x:8,y:1))
path.lineCapStyle= .round
UIColor.red.setStroke()
path.close()
// 绘制
path.stroke()
创建节点
// 创建 extrusionDept 线的宽度
letshape =SCNShape(path: path,extrusionDepth:0.3);
letboxNodeshape =SCNNode()
boxNodeshape.geometry= shape
boxNodeshape.position=SCNVector3Make(0,0,0)// xzy
其中position代表节点的初始位置
6、将节点内容添加到场景中
data:image/s3,"s3://crabby-images/f3597/f359789e8f1d8751fb59f95c93579d2d738a24dc" alt=""
7、其他的一些设置
data:image/s3,"s3://crabby-images/91d9c/91d9c9ba3275e928ab6e31422f3693e4a9817592" alt=""
8、动画相关
我这里只运用了一个动画,是用SCNAction进行触发的
data:image/s3,"s3://crabby-images/7d734/7d734460131ce1c64bfc562d500483d1f9738f5d" alt=""
9、一些自带的模型
data:image/s3,"s3://crabby-images/92747/92747c36c89c9e9f1e780981ff47b476ab7e2d8f" alt=""
data:image/s3,"s3://crabby-images/fe009/fe0097639a2c8fb5db39706bae1e1cfe2e4685a9" alt=""
data:image/s3,"s3://crabby-images/c489b/c489b434a233a34ba6da7067f63676a5146fdbbd" alt=""
10、给节点添加贴纸
let shape = SCNShape(path: path, extrusionDepth: 0.3);
shape.firstMaterial?.diffuse.contents = "cat.png";
letboxNodeshape =SCNNode()
boxNodeshape.geometry= shape
网友评论