SKView 官方说明

继承自 UIView:UIResponder:NSObject
符合 NSCoding(UIView)
UIAppearance(UIView)
UIAppearanceContainer(UIView)
UIDynamicItem(UIView)
NSObject(NSObject)
框架  /System/Library/Frameworks/SpriteKit.framework
可用性 可用于iOS 7.0或者更晚的版本
声明于 SKView.h
参考指南 Sprite Kit Progamming Guide

概览

重要提示:这是一个初步的API或者开发技术文档。虽然已经审阅了本文档的技术准确性,但是它不是最终的版本。本机密信息仅适用于苹果开发者计划的注册会员。苹果提供这些机密信息来帮助你采用这些技术和编程接口。此信息如果有变更,根据本文档实现的软件应使用操作系统软件和最终文档测试。新版本的文档可能会拥有新的API或者技术。

一个SKView实例是一个显示Sprite Kit内容的视图。这个内容是由场景所提供的。

通过调用视图的presentScene:方法可以弹出一个场景。当一个场景被弹到视图上,它交替运行场景的模拟和场景的渲染。你可以通过将视图的pause属性设置为YES来暂停这个场景。

方法

弹出场景

- presentScene:

弹出一个场景

- (void)presentScene:(SKScene *)scene

参数 scene:待显示的场景
返回值  

论述

如果新场景存在,将直接替换旧场景。

- presentScene:transition:

弹出一个场景并播放一个过场动画。

- (void)presentScene:(SKScene *)scene transition:(SKTransition)transition

参数 scene:待显示的场景
transition:两个场景之间的过场动画
返回值  

论述

如果视图当前有一个显示的场景,视图的场景属性将立即更新,然后执行过场动画来交换两个场景。否则,新场景将直接弹出,并且过场动画将被忽视。

从场景内容中获取图片

- textureFromNode:

渲染并返回一个节点中的纹理。

- (SKTexture *)textureFromNode:(SKNode *)node

参数 node:你想要绘制的纹理的节点实例
返回值 持有渲染图片的纹理

论述

节点不需要添加到场景中就可以被绘制。新纹理的大小是通过节点的calculateAccumulatedFrame方法计算得出的。如果这个节点不是一个场景,它将绘制一个背景色[SKColor clearColor]。

转换视图和场景的坐标系

- converPoint:fromScene:

将场景坐标系转换为视图坐标系。

- (CGPoint)convertPoint:(CGPoint)point fromScene:(SKScene *)scene

参数 point:场景坐标系中的一个点
scene:一个场景
返回值 这个点在视图坐标系中的位置

论述

这个方法转换坐标系上的点,使他就好像在视图坐标系上一样。

- converPoint:toScene:

将视图坐标系转换为场景坐标系。

- (CGPoint)convertPoint:(CGPoint)point toScene:(SKScene *)scene

参数 point:视图坐标系中的一个点
scene:一个场景
返回值 这个点在场景坐标系中的位置

论述

这个方法转换坐标系上的点,使他就好像在场景坐标系上一样。

属性

当前场景

scene

视图当前弹出的场景。

@property (nonatomic, readnoly) SKScene *scene

论述

默认值为nil。

暂停场景

paused

一个布尔值,表示视图中场景的动画是否暂停。

@property (nonatomic, getter=isPaused) BOOL paused

论述

如果该值为YES,那么场景的内容将固定在屏幕上。没有动作和物理模拟会被执行。

异步渲染

asychronous

一个布尔值,表示内容是否异步渲染。

@property(getter=isAsychronous) BOOL asychronous

论述

默认值为YES。如果该值为NO,那么视图内容和动画更新将是同步的。

显示调试信息

showsFPS

是否显示FPS。

@property(nonatomic) BOOL showsFPS

论述

帧率是表现场景的一个很好的指标。尽量避免创建的场景的帧率差别过大。

showsDrawCount

是否显示绘制次数。

@property(nonatomic) BOOL showsDrawCount

论述

Sprite Kit中的一些操作可能会需要多次绘制。例如,一个特效节点必须先将其子节点单独绘制到一个缓冲区,要使用这个特效,还需要将这些结果混合输出的父节点。这些额外的绘制次数会消耗更多地绘制资源,减少游戏的帧率或者增加总消耗。使用绘制次数可以从另一方面分析你游戏的性能。

showsNodeCount

是否显示节点个数。

@property(nonatomic) BOOL showsNodeCount

定义帧率

frameInterval

场景更新之前必须经过的帧数。

@property(nonatomic) NSInteger frameInterval

论述

默认值为1,表示场景每帧更新一次。如果是一个大于1的是,场景的更新率可能是一个分数。例如,如果值为2,表示场景每隔一帧更新一次。

将值设为一个小于1的数是一个未定义的行为,是一个编程错误。

你可能感兴趣的:(游戏,文档,开发者,OpenGL,Object_C)