TestsTested | ✗ |
LangLanguage | SwiftSwift |
License | MIT |
ReleasedLast Release | Nov 2016 |
SwiftSwift Version | 3.0 |
SPMSupports SPM | ✗ |
Maintained by Daniel Green.
InvertedCircleMaskNode
allows you to create a SpriteKit node that can act as an inverted circular mask. It can be used, for example, to be able to allow the player to see behind walls if your character is behind a wall.
This is possible by using an image of a transparent (alpha 0) circle within a rectangle of the size of the scene. Behind the scenes, this little library will pre-generate this image for you given a position and radius so you don’t have to create any assets manually.
It’s easier to understand if you see for yourself, so try out the included example app.
let cropNode = SKCropNode()
for wall in walls { cropNode.addChild(wall) }
let mask = InvertedCircleMaskNode(size: scene.size,
circleCenter: position,
circleRadius: radius)
cropNode.maskNode = mask
// Mask position and size
mask.position = CGPoint(...)
mask.rectangleCenter = CGPoint(...)
mask.size = CGSize(...)
// Circle position within mask
mask.circleCenter = CGPoint(...)
Note: because rendering the circle is the expensive part, by design there is no inbuilt way to change the radius of the circle on an initialized node. If you want a resizing mask, consider either scaling the node or initializing different sizes upfront.
To run the example project, clone the repo, and run pod install
from the Example directory first.
SpriteKitSeeThrough is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod "SpriteKitSeeThrough"
Daniel Inkpen, [email protected]
SpriteKitSeeThrough is available under the MIT license. See the LICENSE file for more info.