при покупке приложения в SKScene

Можно ли реализовать покупку в приложении в рамках SKScene? Если да, то как? Я пытаюсь использовать SKSpriteNode как кнопку «купить», но безуспешно. Я не уверен, нужно ли коду идти в SKScene или в контроллер представления. Я просмотрел множество руководств, но все они, похоже, нацелены на приложения с одним представлением, а не на SpriteKit.


person JGrn84    schedule 09.08.2015    source источник


Ответы (1)


Во-первых, поместите это в строку вашей игровой сцены и убедитесь, что вы импортировали фреймворк «StoreKit».

class GameScene: SKScene, SKPaymentTransactionObserver, SKProductsRequestDelegate {

Затем вы захотите поместить эти строки в свой didmovetoview. Имейте в виду, что после «objects:» строка, которую вы помещаете, должна быть идентификатором покупки в приложении, который вы установили с помощью iTunes connect.

// Set IAPS
    if(SKPaymentQueue.canMakePayments()) {
        println("IAP is enabled, loading")
        var productID:NSSet = NSSet(objects: "Put IAP id here")
        var request: SKProductsRequest = SKProductsRequest(productIdentifiers: productID as Set<NSObject>)
        request.delegate = self
        request.start()
    } else {
        println("please enable IAPS")
    }

Вне любых других функций, но все еще внутри игровой сцены, вставьте эти функции и переменные.

//In App Purchases
var list = [SKProduct]()
var p = SKProduct()

func buyProduct() {
    println("buy " + p.productIdentifier)
    var pay = SKPayment(product: p)
    SKPaymentQueue.defaultQueue().addTransactionObserver(self)
    SKPaymentQueue.defaultQueue().addPayment(pay as SKPayment)
}

func productsRequest(request: SKProductsRequest!, didReceiveResponse response: SKProductsResponse!) {
    println("product request")
    var myProduct = response.products

    for product in myProduct {
        println("product added")
        println(product.productIdentifier)
        println(product.localizedTitle)
        println(product.localizedDescription)
        println(product.price)

        list.append(product as! SKProduct)
    }
}

func paymentQueueRestoreCompletedTransactionsFinished(queue: SKPaymentQueue!) {
    println("transactions restored")

    var purchasedItemIDS = []
    for transaction in queue.transactions {
        var t: SKPaymentTransaction = transaction as! SKPaymentTransaction

        let prodID = t.payment.productIdentifier as String

        switch prodID {
        case "IAP id here":

            //Right here is where you should put the function that you want to execute when your in app purchase is complete
        default:
            println("IAP not setup")
        }

    }

    var alert = UIAlertView(title: "Thank You", message: "Your purchase(s) were restored. You may have to restart the app before banner ads are removed.", delegate: nil, cancelButtonTitle: "OK")
    alert.show()
}


func paymentQueue(queue: SKPaymentQueue!, updatedTransactions transactions: [AnyObject]!) {
    println("add paymnet")

    for transaction:AnyObject in transactions {
        var trans = transaction as! SKPaymentTransaction
        println(trans.error)

        switch trans.transactionState {

        case .Purchased, .Restored:
            println("buy, ok unlock iap here")
            println(p.productIdentifier)

            let prodID = p.productIdentifier as String
            switch prodID {
            case "IAP id here":

                //Here you should put the function you want to execute when the purchase is complete
                var alert = UIAlertView(title: "Thank You", message: "You may have to restart the app before the banner ads are removed.", delegate: nil, cancelButtonTitle: "OK")
                alert.show()
            default:
                println("IAP not setup")
            }

            queue.finishTransaction(trans)
            break;
        case .Failed:
            println("buy error")
            queue.finishTransaction(trans)
            break;
        default:
            println("default")
            break;

        }
    }
}

func finishTransaction(trans:SKPaymentTransaction)
{
    println("finish trans")
}
func paymentQueue(queue: SKPaymentQueue!, removedTransactions transactions: [AnyObject]!)
{
    println("remove trans");
}

Затем вы должны назвать узел, который вам нужен для выполнения iAP.

whateverYourNodeIs.name = "inAppPurchaseNode"

Наконец, сделайте это в TouchesBegan

  let touch =  touches.first as? UITouch
  let positionInScene = touch!.locationInNode(self)
  let touchedNode = self.nodeAtPoint(positionInScene)

if let name = touchedNode.name {
        if name == "inAppPurchaseNode" {

                for product in list {
                    var prodID = product.productIdentifier
                    if(prodID == "iAp id here") {
                        p = product
                        buyProduct()  //This is one of the functions we added earlier
                        break;
                    }
                }
            }

    }

Вы также хотите, чтобы ваши касания начали восстанавливать покупки с помощью другого узла.

    if let name = touchedNode.name {
        if name == "restore" {

             SKPaymentQueue.defaultQueue().restoreCompletedTransactions()
            SKPaymentQueue.defaultQueue().addTransactionObserver(self)
             }
        }
person Aidan Kaiser    schedule 10.08.2015
comment
Где бы я ни размещал здесь идентификатор строки iAP, я имею в виду, что вы должны использовать идентификатор покупки в приложении, который вы сделали в iTunes connect. - person Aidan Kaiser; 10.08.2015
comment
Большое спасибо за вашу помощь, я везде искал такой ответ !! :) :) - person JGrn84; 10.08.2015
comment
Добро пожаловать. Кроме того, я заметил, что оставил несколько UIAlertViews в коде из игры, которую сделал некоторое время назад. Вы можете удалить их или просто изменить текст, если хотите. - person Aidan Kaiser; 10.08.2015