我想在我的游戏中实现奖励插页式广告,但出现很多AdColony错误,例如:“广告请求无填充”或我的区域ID无效。

首先,这就是我配置AdColony区域的方式:

Zone is active? Yes

Zone Type: Preroll/Interstitial (Gives me "No fill for ad request error")
           Value Exchange/V4VC (Gives me "Zone ID invalid, please check config error")

House Ads: Back Fill

Options: 0 0 1

Development: Show Test Ads Only (Although my app is currently Live)

他们为您提供的SDK下载示例仅适用于Apps,不适用于游戏,因此我尝试将其翻译成适用于Games的游戏,尽管并没有什么不同,但是我当前的代码可能存在问题。
所以这就是我在GameViewController.swift中的方式。
// Outside I declare a struct
struct Constants
{
    static let adColonyAppID = "app5aab6bb6aaf3xxxxxx"
    static let adColonyZoneID = "vz19959f95bd62xxxxxx"
    static let currencyBalance = "coinAmount"
}

// Inside GameViewController
var ad: AdColonyInterstitial?!
var spinner: UIActivityIndicatorView!


override func viewDidLoad() {
        super.viewDidLoad()

        self.setupAdRewardBanner()
    }

func setupAdRewardBanner() {

        AdColony.configureWithAppID(Constants.adColonyAppID, zoneIDs: [Constants.adColonyZoneID], options: nil,
            completion: {(zones) in

            let zone = zones.first
                zone?.setReward({ (success, name, amount) in
                if (success) {
                    let storage = NSUserDefaults.standardUserDefaults()
                    let wrappedBalance = storage.objectForKey(Constants.currencyBalance)
                    var balance = 0
                    if let nonNilNumWrappedBalance = wrappedBalance as? NSNumber {
                        balance = Int(nonNilNumWrappedBalance.integerValue)
                    }
                    balance = balance + Int(amount)

                    let newBalance: NSNumber = NSNumber(integerLiteral: balance)
                    storage.setValue(newBalance, forKey: Constants.currencyBalance)
                    storage.synchronize()

                    self.updateCurrencyBalance()
                }


            })


           //If the application has been inactive for a while, our ad might have expired so let's add a check for a nil ad object
                NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(GameViewController.onBecameActive), name: "onBecameActive", object: nil)

                //AdColony has finished configuring, so let's request an interstitial ad
                self.requestInterstitial()

        })

        NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(GameViewController.triggerAdReward), name: "triggerAdReward", object: nil)

        self.updateCurrencyBalance()
    }


    func requestInterstitial()
    {
        //Request an interstitial ad from AdColony
        AdColony.requestInterstitialInZone(Constants.adColonyZoneID, options:nil,

                                     //Handler for successful ad requests
            success:{(newAd) in

                //Once the ad has finished, set the loading state and request a new interstitial
                newAd.setClose({

                    self.requestInterstitial()
                })

                //Interstitials can expire, so we need to handle that event also
                newAd.setExpire( {
                    self.ad = nil


                    self.requestInterstitial()
                })

                //Store a reference to the returned interstitial object
                self.ad = newAd


            },

            //Handler for failed ad requests
            failure:{(error) in
                NSLog("SAMPLE_APP: Request failed with error: " + error.localizedDescription + " and suggestion: " + error.localizedRecoverySuggestion!)
            }
        )
    }

    func triggerAdReward(sender: AnyObject)
    {
        if let ad = self.ad {
            if (!ad!.expired) {
                ad?.showWithPresentingViewController(self)
            }
        }
    }


    func updateCurrencyBalance()
    {
        //Get currency balance from persistent storage and display it
        let storage = NSUserDefaults.standardUserDefaults()
        let wrappedBalance = storage.objectForKey(Constants.currencyBalance)
        var balance: Int = 0
        if let nonNilNumWrappedBalance = wrappedBalance as? NSNumber {
            balance = Int(nonNilNumWrappedBalance.integerValue)
        }

        print("current balance ", balance)
        //XXX Run animation of giving user coins and update view
    }

    func onBecameActive()
    {
        //If our ad has expired, request a new interstitial
        if (self.ad == nil) {
            self.requestInterstitial()
        }
    }

然后,在用户迷失GameScene之后,按下按钮时,我会调用此通知以请求广告非页内广告。
NSNotificationCenter.defaultCenter().postNotificationName("triggerAdReward", object: nil)

我尝试调试,但似乎看不到if (success)块中的代码。因此,那里可能存在问题。

有人知道我在做什么错吗?

调试更多之后,我注意到它没有采用这种方法
self.requestInterstitial()

因此,我的帐户可能有问题吗?为什么不通过成功而通过错误块呢?

控制台中的错误是:



提前致谢。

最佳答案

  • 您的代码似乎应该正常工作。
  • 由于您要实现奖励插页式广告,因此应将区域类型设置为V4VC。
  • 如果它说"Zone ID invalid, please check config error",则应在源代码和Adcolony客户端面板页面中检查两次App ID和Zone ID。
  • 更改区域类型后,等待一段时间(10分钟?)进行测试,服务器应该需要时间来同步状态。
  • 如果可能,在设备而不是模拟器上进行测试。

  • 这是v4vc的文档:https://github.com/AdColony/AdColony-iOS-SDK-3/wiki/Rewarded-Interstitial-Ads-Quick-Start-Guide

    关于ios - 由于某些原因,AdColony的AdReward无法在Swift 2.0上运行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40362875/

    10-10 23:25