Swift iAd - 超过 10 个 ADBannerView 警告和 CGAffineTransformInvert 实例:奇异矩阵输出

Swift iAd - More than 10 instances of ADBannerView warning and CGAffineTransformInvert: singular matrix output

所以我尝试在我的应用程序中设置一个简单的 iAd 横幅,但我在输出中收到以下两个警告:

WARNING: More than 10 instances of ADBannerView or ADInterstitialView 
currently exist. This is a misuse of the iAd API, and ad performance will 
suffer as a result. This message is printed only once.

<Error>: CGAffineTransformInvert: singular matrix.

这就是我用来实现我的 ADBannerView:

var adBannerView = ADBannerView()

func loadAds() {
    adBannerView = ADBannerView(frame: CGRect.zeroRect)
    adBannerView.center = CGPoint(x: adBannerView.center.x, y: view.bounds.size.height - adBannerView.frame.size.height / 2)
    adBannerView.delegate = self
    adBannerView.hidden = true
    view.addSubview(adBannerView)
}

//BannerView did load ad
func bannerViewDidLoadAd(banner: ADBannerView!) {
    adBannerView.hidden = false
}
//BannerView failed to load
func bannerView(banner: ADBannerView!, didFailToReceiveAdWithError error: NSError!) {
    adBannerView.hidden = true
}

override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view, typically from a nib.
    loadAds()
    //(rest of the code is from here onwards)

我尝试添加这个来阻止第一个错误:(没用)

//BannerView will disappear
override func viewWillDisappear(animated: Bool) {
    adBannerView.removeFromSuperview()
    adBannerView.delegate = nil
}

问题是每次加载视图时都会创建 ADBannerView 的新实例。我们需要做的是在我们的 AppDelegate.swift 中创建一个 ADBannerView 一次,然后将这个 ADBannerView 显示在我们希望有 iAd 横幅的任何视图上。这也称为 Shared iAd Banner。在此示例中,我在 AppDelegate.swift 中创建了一个 ADBannerView,然后将其添加到 ViewController.swift 的视图中。

AppDelegate.swift

import UIKit
import iAd // Import iAd

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate, ADBannerViewDelegate { // Include the delegate for our banner

    var window: UIWindow?
    var adBannerView = ADBannerView() // Create our one ADBannerView

    func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
        // Set delegate and hide banner initially
        adBannerView.delegate = self
        adBannerView.hidden = true
        return true
    }

    func bannerViewDidLoadAd(banner: ADBannerView!) {
        print("bannerViewDidLoadAd")
        adBannerView.hidden = false
    }

    func bannerViewActionDidFinish(banner: ADBannerView!) {
        print("bannerViewActionDidFinish")
    }

    func bannerView(banner: ADBannerView!, didFailToReceiveAdWithError error: NSError!) {
        print("didFailToReceiveAdWithError: \(error)")
        adBannerView.hidden = true
    }

ViewController.swift

import UIKit

class ViewController: UIViewController {

    let appDelegate = UIApplication.sharedApplication().delegate as! AppDelegate // Create reference to our app delegate

    override func viewWillAppear(animated: Bool) {
        // Position
        appDelegate.adBannerView.center = CGPoint(x: view.frame.midX,
            y: view.frame.height - appDelegate.adBannerView.frame.height / 2)
        // Add to view
        view.addSubview(appDelegate.adBannerView)
    }

不要忘记从您之前添加的 viewWillDisappear(animated: Bool) 函数中删除代码。如果您单击横幅然后将其关闭,将调用此函数并从我们的视图中删除我们的横幅并将我们的横幅委托设置为 nil 过早会导致问题。

如果您不想关心横幅广告的大小、位置、错误处理和委托方法,您还可以使用:

self.canDisplayBannerAds = true

这解决了我的应用程序中的错误,因为 Apple 也关心实例数

我写了一个关于这个的简短教程: link

如果您希望横幅在标签之间持续存在并且在快速切换标签时不消失,您必须采用 iAd Suite 方法:http://developer.apple.com/library/ios/#samplecode/iAdSuite/Introduction/Intro.html(查看 BannerViewController.m 文件 - 不是在 Swift 中,但转换它并不难)

这种方法也不需要您修改选项卡中的任何视图控制器。您只需要将选项卡栏控制器与嵌入了容器视图的视图控制器建立关系即可。在你的故事板中这样做。此外,您需要为每个选项卡将 Custom Class 设置为 BannerViewController,并将您的内容嵌入到嵌入视图中。看看这个 post 以了解如何在情节提要中执行此操作的详细信息:

如果您不使用 Storyboard - 您需要将 BannerViewController 设置为每个选项卡的父视图控制器。