SCNNode 用法講解
學(xué)習(xí)目標(biāo)
理解游戲場景和節(jié)點的概念
你必須知道的概念
場景
簡單的說,就是把人物细疚,地圖,道具等放在一個空間里,組成一個大的環(huán)境,這個大的環(huán)境就被稱為場景!
節(jié)點
在SceneKit 節(jié)點是個抽象的概念,節(jié)是個看不見,摸不到的東西,沒有幾何形狀,但是它有位置达皿,以及自身坐標(biāo)系姐刁。通俗的講芥牌,在場景中創(chuàng)建一個添加節(jié)點后,你就可以在這個節(jié)點上放我們游戲元素了,比如人物模型聂使,燈光壁拉,攝像機等等! 節(jié)點上可以添加節(jié)點的,每個節(jié)點都有自身坐標(biāo)系。如圖柏靶,我們把節(jié)點2添加到節(jié)點1上去弃理。
實戰(zhàn)目標(biāo)
1.掌握如何添加節(jié)點到場景中 2.給節(jié)點綁定幾何物體 3.給節(jié)點添加節(jié)點
開始吧
第一步.創(chuàng)建工程
我們已經(jīng)完成了創(chuàng)建工程的任務(wù),有的人就問了,你不是要將SceneKit 游戲開發(fā),怎么創(chuàng)建的是應(yīng)用工程,往下看,就這么任性!
第二步屎蜓,添加我們的游戲框架到我們的控制器ViewController中
到這里,準(zhǔn)備工作已經(jīng)全部做完,開始敲代碼啦痘昌!
第三步:創(chuàng)建一個游戲引擎專屬View視圖(SCNView)
@property(nonatomic,strong)SCNView *gameView; // 設(shè)置一個引用屬性
- (void)addSCNView{
// 1.創(chuàng)建一個邊長為300 的視圖,放在屏幕中心
self.gameView = [[SCNView alloc]initWithFrame:CGRectMake(0, 0, 300, 300)];
self.gameView.center = CGPointMake(CGRectGetMidX(self.view.bounds), CGRectGetMidY(self.view.bounds));
// 2.設(shè)置背景顏色為黑色
self.gameView.backgroundColor = [UIColor blackColor];
// 3.添加到父視圖中去
[self.view addSubview:self.gameView];
}
- (void)viewDidLoad {
[super viewDidLoad];
[self addSCNView];
}
此刻運行一下程序結(jié)果如下圖
第四步.添加場景
-(void)createScene{
SCNScene *scene = [SCNScene scene];
self.gameView.scene = scene;
}
此時梆靖,如果你運行程序控汉,就和上面的效果一樣,沒有變化返吻,因為我們的場景中什么都沒有姑子。
第五步.添加節(jié)點
// 創(chuàng)建節(jié)點,添加到scene的根節(jié)點上
SCNNode *node = [SCNNode node];
[scene.rootNode addChildNode:node];
提示:
scene.rootNode 有些朋友很好奇测僵,為什么Scene也有一個節(jié)點街佑,上面說個,沒有節(jié)點你沒法放游戲元素上去捍靠,并且它有自身坐標(biāo)系沐旨,這就是為什么scene也有一個根節(jié)點的原因。
此時你運行程序也和上面結(jié)果一樣,因為節(jié)點沒有幾何形狀!
第六步.給節(jié)點綁定一個幾何形狀的物體
// 創(chuàng)建一個球體幾何綁定到節(jié)點上去
SCNSphere *sphere = [SCNSphere sphereWithRadius:0.5];
node.geometry = sphere;
運行一下
此時我們已經(jīng)完成了實戰(zhàn)任務(wù)的1和2,繼續(xù)加油!
第七步.給節(jié)點添加節(jié)點
// 創(chuàng)建子節(jié)點 給子節(jié)點添加幾何形狀
SCNNode *childNode = [SCNNode node];
// 設(shè)置節(jié)點的位置
childNode.position = SCNVector3Make(-0.5, 0, 1);
// 設(shè)置幾何形狀榨婆,我們選擇立體字體
SCNText *text = [SCNText textWithString:@"讓學(xué)習(xí)成為一種習(xí)慣" extrusionDepth:0.03];
// 設(shè)置字體顏色
text.firstMaterial.diffuse.contents = [UIColor redColor];
// 設(shè)置字體大小
text.font = [UIFont systemFontOfSize:0.15];
// 給幾點綁定幾何物體
childNode.geometry = text;
[node addChildNode:childNode];
友情提示:
extrusionDepth 字體的深度 firstMaterial.diffuse.contents 不知道沒關(guān)系磁携,后面會講的,單詞意思就可以理解.firstMaterial 第一個材質(zhì) diffuse 自身發(fā)散的contents內(nèi)容,我們設(shè)置為red 也可以設(shè)置圖片的!
我們用一鍵大招讓你自由旋轉(zhuǎn)物體
self.gameView.allowsCameraControl = true;
本節(jié)內(nèi)容已將講解完畢,趕緊動手操練一遍吧良风!讓學(xué)習(xí)成為一種習(xí)慣