iOS -- SKSpriteNode类

SKSpriteNode类

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

概览

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

一个SKSpriteNode实例是一个节点,可以绘制带图片,有色方块,经过颜色混合的图片。

类方法

创建一个新的实例

+ spriteNodeWithColor:size:

创建并返回一个有色的精灵。

+ (id)spriteNodeWithColor:(SKColor *)color size:(CGSize)size

参数 color:精灵的颜色
size:精灵的大小
返回值 一个创建好的并初始化好的精灵实例
+ spriteNodeWithImageNamed:

通过图片文件创建并返回一个纹理精灵。

+ (id)spriteNodeWithImageNamed:(NSString *)name

参数 name:放在项目中的图片文件的名字
返回值 一个创建好的并初始化好的精灵实例
+ spriteNodeWithTexture:

通过纹理实例创建并返回一个纹理精灵。

+ (id)spriteNodeWithTexture:(SKTexture *)texture

参数 texture:一个Sprite Kit纹理实例
返回值 一个创建好的并初始化好的精灵实例
+ spriteNodeWithTexture:size:

通过纹理实例创建并返回一个纹理精灵并制定大小。

+ (id)spriteNodeWithTexture:(SKTexture *)texture size:(CGSize)size

参数 texture:一个Sprite Kit纹理实例
size:精灵的大小
返回值 一个创建好的并初始化好的精灵实例

实例方法

初始化一个新的实例

- initWithColor:size:

使用颜色和大小初始化一个精灵。

- (id)initWithColor:(SKColor *)color size:(CGSize)size

参数 color:精灵的颜色
size:精灵的大小
返回值 一个新的初始化好的精灵实例

论述

通过这个方法返回的精灵实例,它的texture属性值为nil。

- initWithImageNamed:

使用图片文件初始化一个精灵。

- (id)initWithImageNamed:(NSString *)name

参数 name:放在项目中的图片文件的名字
返回值 一个新的初始化好的精灵实例

论述

这个方法会创建一个新的纹理实例,并且把这个实例分配给texture属性。精灵的size属性是由图片的大小来决定的。颜色属性为白色(1.0,1.0,1.0)。

- initWithTexture:

使用一个纹理实例初始化一个精灵。

- (id)initWithTexture:(SKTexture *)texture

参数 texture:一个Sprite Kit纹理
返回值 一个新的初始化好的精灵实例

论述

精灵的size属性是由纹理的大小来决定的。颜色属性为白色(1.0,1.0,1.0)。

- initWithImageTexture:color:size:

使用一个纹理实例和一个颜色初始化一个精灵。

- (id)initWithTexture:(SKTexture *)texture color:(SKColor *)color size:(CGSize)size

参数 texture:一个Sprite Kit纹理
color:精灵的颜色
size:精灵的大小
返回值 一个新的初始化好的精灵实例

论述

要给纹理混合颜色,你还需要设置精灵的colorBlendFactor属性。

属性

查看物理属性

size

精灵的大小。

@property(atomic) CGSize size

anchorPoint

精灵的参考点。

@property(atomic) CGPoint anchorPoint

论述

你指定一个位于单元坐标空间的值。默认值为(0.5,0.5),表示精灵的参考点在正中。

查看精灵的纹理

texture

精灵的纹理

@property(atomic, retain) SKTexture *texture

论述

如果该值为nil,精灵将会使用颜色属性绘制一个颜色矩形。否则,精灵将会绘制这个纹理。相关的属性影响了纹理的应用。

centerRect

定义了纹理是如何应用到精灵的。

@property(atomic) CGRect centerRect

论述

这个矩形在单元坐标空间中。默认值为(0,0)-(1.0,1.0),表示整个纹理被拉伸到充满精灵。如果指定一个不同的矩形,矩形的坐标会变成一个3X3网格。网格的四个角不经过缩放直接应用。它的上和中下部分将水平缩放,左和中右部分将垂直缩放。中心是所有方向缩放。

colorBlendFactor

一个浮点point,描述了颜色是怎样与纹理混合的。

@property(atomic) CGFloat colorBlendFactor

论述

该值必须在0.0到1.0之间。默认值为0.0,表示颜色属性将被忽视,纹理的值不做任何改变。如果是一个大于0.0的值,纹理将与颜色混合,然后再绘制到场景。

查看颜色属性

color

纹理的颜色

@property(atomic, retain) SKColor *color

论述

如果纹理属性非空,那么颜色的红绿蓝值将会混合到纹理,然后绘制到场景,alpha属性将被忽视。如果纹理属性为nil,那么颜色属性将会被用于绘制一个颜色矩形。

blendMode

将精灵绘制到父缓冲区的混合模式。

@property(atomic) SKBlendMode blendMode

论述

默认值为SKBlendModeAlpha。

时间: 2024-10-13 16:04:18

iOS -- SKSpriteNode类的相关文章

ios系类教程之用instruments来检验你的app

ios系类教程之用instruments来检验你的app 为了节省大家的时间,提供一个演示的Demo给大家.代码传送门.下载后解压然后用xcode打开.编译运行APP后 然后在搜索框内输入任意词汇,点击结果你会看到下面的结果 正如你所见的,这个app很简单.程序其实调用的是Flickr的API,通过app顶部的搜索框执行搜索后在下面的tableview显示你搜索的搜索词,搜索词后面的括号内有搜索结果的个数,点击此行进入一个略所图的结果列表页面 如上图. 点击其中一行 进入图像的大图模式,在这个页

iOS方法类:CGAffineTransform

iOS方法类:CGAffineTransform的使用大概 CoreGraphics框架中的CGAffineTransform类可用于设定UIView的transform属性,控制视图的缩放.旋转和平移操作: 另称放射变换矩阵,可参照线性代数的矩阵实现方式0.0 这里附上的CGAffineTransform官方文档: https://developer.apple.com/library/ios/documentation/GraphicsImaging/Reference/CGAffineTr

iOS 在类实现定义中声明成员变量的怪异方式

WebGL 规范(WebGL Specification) 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一致"创作公用协议 转载请保留此句:太阳火神的漂亮人生 -  本博客专注于 敏捷开发及移动和物联设备研究:iOS.Android.Html5.Arduino.pcDuino,否则,出自本博客的文章拒绝转载或再转载,谢谢合作. 看看下面的使用方法,几年前系统地看过 Objective-C 2.0 的官方文档和那本

IOS中 类扩展 xib

IOS中 类扩展 xib 一.类扩展(class extension,匿名分类) 1.格式 @interface 类名 () { // 成员变量... } // 方法声明... @end 2.作用 1> 写在.m文件中 2> 一般用来扩充私有成员变量.@property属性.方法等 二.随机数生成 1.arc4random() 会生成任意正整数和0 2.arc4random_uniform(100) 会生成0~99的整数(包括0和99) 三.UIView常见方法 1.addSubview:(U

一位iOS教育类应用开发者是如何赚到60多万美元?

注:伯乐在线12月19日在@程序员的那些事 微博推荐了此文的英文原文,非常感谢@dotSlash 的翻译.  转眼距我写<我如何在iOS教育类应用中赚到20万美元>这篇博文已经一年多了,它在独立社区中相当受欢迎,要知道它曾经在Hacker News上排过第一呢!我觉得是时候继续跟进一下我2012年的经验了.先交代一下我的背景,我是法国一个全职独立开发者,当iPad一开始发售的时候我就开始做教育类App了.我之所以决定做教育类App是因为我和我内人几年前决定让我们的孩子在家里接受教育,我意识到i

iOS -- SKScene类

SKScene类 继承自 SKEffectNode:SKNode:UIResponder:NSObject 符合 NSCoding(SKNode)NSCopying(SKNode)NSObject(NSObject) 框架  /System/Library/Frameworks/SpriteKit.framework 可用性 可用于iOS 7.0或者更晚的版本 声明于 SKScene.h 参考指南 Sprite Kit Progamming Guide 概览 重要提示:这是一个初步的API或者开

iOS -- SKPhysicsWorld类

SKPhysicsWorld类 继承自 NSObject 符合 NSCodingNSObject(NSObject) 框架  /System/Library/Frameworks/SpriteKit.framework 可用性 可用于iOS 7.0或者更晚的版本 声明于 SKPhysicsWorld.h 参考指南 Sprite Kit Progamming Guide 概览 重要提示:这是一个初步的API或者开发技术文档.虽然已经审阅了本文档的技术准确性,但是它不是最终的版本.本机密信息仅适用于

iOS 日历类(NSCalendar)

对于时间的操作在开发中很常见,但有时候我们需要获取到一年后的时间,或者一周后的时间.靠通过秒数计算是不行的.那就牵扯到另外一个日历类(NSCalendar).下面先简单看一下 NSDate let date = NSDate()let formatter = NSDateFormatter() formatter.dateFormat = "yyyy-MM-dd HH-mm-ss"formatter.stringFromDate(date)// 延迟多少秒为正数 前多少秒为负数let

iOS方法类:CGAffineTransform的使用大概

CoreGraphics框架中的CGAffineTransform类可用于设定UIView的transform属性,控制视图的缩放.旋转和平移操作: 另称放射变换矩阵,可参照线性代数的矩阵实现方式0.0 这里附上的CGAffineTransform官方文档: https://developer.apple.com/library/ios/documentation/GraphicsImaging/Reference/CGAffineTransform/index.html 总得来说,这个类中包含