SKTileMap从GKNoiseMap获取值

时间:2017-10-07 08:34:37

标签: ios swift sprite-kit perlin-noise sktilemapnode

我一直关注GKNoiseMaps上的Apple Docs,我设法得到一个图像来生成它看起来非常好

在这里使用此代码

class GameScene: SKScene {


class Noise: GKNoise {
    var NoiseSource = GKPerlinNoiseSource(frequency: 0.05, octaveCount: 3, persistence: 1, lacunarity: 1, seed: Int32(arc4random_uniform(UInt32(500 - 1))))
    override init(_ noiseSource: GKNoiseSource, gradientColors: [NSNumber : UIColor]) {
        super.init(NoiseSource, gradientColors: [ (+1.0 as NSNumber): UIColor.red, (-1.0 as NSNumber) : UIColor.black])
    }
}
let noise = Noise()
let Vector1 = vector_double2(1.0, 1.0)

override func didMove(to view: SKView) {
    let NoiseMap = GKNoiseMap(noise, size: vector_double2(300.0, 300.0),
                              origin: vector_double2(0.0, 0.0),
                              sampleCount: vector_int2(100),
                              seamless: true)
    let texture = SKTexture(noiseMap: NoiseMap)
    let Node = SKSpriteNode(texture: texture)

    Node.size = CGSize(width: 1000,height: 1000)
    Node.position = CGPoint(x: 0,y: 0)
    self.addChild(Node)
}

    override func update(_ currentTime: TimeInterval) {
        // Called before each frame is rendered
    }
}

现在如何使用此更新代码创建SKTileMap

class GameScene: SKScene {


class Noise: GKNoise {
    var NoiseSource = GKPerlinNoiseSource(frequency: 0.05, octaveCount: 3, persistence: 1, lacunarity: 1, seed: Int32(arc4random_uniform(UInt32(500 - 1))))
    override init(_ noiseSource: GKNoiseSource, gradientColors: [NSNumber : UIColor]) {
        super.init(NoiseSource, gradientColors: [(+1.0 as NSNumber): UIColor.red, (-1.0 as NSNumber) : UIColor.black])
    }
}
let noise = Noise()
let Vector1 = vector_double2(1.0, 1.0)

override func didMove(to view: SKView) {
    let NoiseMap = GKNoiseMap(noise, size: vector_double2(300.0, 300.0),
                              origin: vector_double2(0.0, 0.0),
                              sampleCount: vector_int2(100),
                              seamless: true)
    let tileGroup = [SKTileGroup]()
    let tileSet = SKTileSet(tileGroups: tileGroup)
    let map = SKTileMapNode(tileSet: tileSet, columns: 10, rows: 10, tileSize: CGSize(width: 20,height: 20), tileGroupLayout: tileGroup)
}

    override func update(_ currentTime: TimeInterval) {
        // Called before each frame is rendered
    }
}

并使用Apple Docs中所述的GKNoiseMap生成SKTileMap?

任何帮助都会受到赞赏,因为我真的不知道SKTileMaps以及它们是如何工作的

1 个答案:

答案 0 :(得分:5)

您可以使用从SKTileDefinition创建的纹理创建NoiseMap。然后可以在任何位置将此图块绘制到SKTileMapNode。此示例遍历所有列和行并设置切片。我制作了NoiseMap 64 x 64的大小,因为这是瓷砖的典型尺寸。

override func sceneDidLoad() {
    let noise = Noise()
    let noiseMap = GKNoiseMap(noise, size: vector_double2(64.0, 64.0), origin: vector_double2(0.0, 0.0), sampleCount: vector_int2(100), seamless: true)
    let bgTexture = SKTexture(noiseMap: noiseMap)

    let bgDefinition = SKTileDefinition(texture: bgTexture, size: bgTexture.size())
    let bgGroup = SKTileGroup(tileDefinition: bgDefinition)
    bgGroup.name = "noiseTest"

    let tileSet = SKTileSet(tileGroups: [bgGroup])

    let bgNode = SKTileMapNode(tileSet: tileSet, columns: 10, rows: 10, tileSize: bgTexture.size())
    let tile = bgNode.tileSet.tileGroups.first(where: { $0.name == "noiseTest" })

    for column in 0 ..< bgNode.numberOfColumns {
        for row in 0 ..< bgNode.numberOfRows {
            bgNode.setTileGroup(tile, forColumn: column, row: row)
        }
    }

    bgNode.position = CGPoint(x: 0, y: 0)
    bgNode.setScale(1)

    self.addChild(bgNode)
}
相关问题