родной AdMob для iOS - PullRequest
       13

родной AdMob для iOS

0 голосов
/ 24 марта 2019

Попытка показа Google Ad в UITablewViewCell с использованием родной документации по Google Ad * . Но я продолжал получать

Failed Ad Request:  Error Domain=com.google.admob Code=1 "Request Error: No ad to show." UserInfo={NSLocalizedDescription=Request Error: No ad to show.}

Это моя конфигурация:

Мне нужно отобразить персонализированную рекламу в 3-й строке табличного представления.

GoogleAdBannerView.swift импорт UIKit импортировать GoogleMobileAds

class GoogleAdBannerView: GADUnifiedNativeAdView {

    let modMediaView: GADMediaView = {
        let mediaView = GADMediaView()
        mediaView.translatesAutoresizingMaskIntoConstraints = false
        return mediaView
    }()

    let bannerImageView: UIImageView = {
        let imageview = UIImageView()
        imageview.translatesAutoresizingMaskIntoConstraints = false
        return imageview
    }()

    let adTitle: UILabel = {
        let label = UILabel()
        label.font = UIFont.mySFMedium(ofSize: 16)
        label.textColor = UIColor.black.withAlphaComponent(0.87)
        label.translatesAutoresizingMaskIntoConstraints = false
        return label
    }()

    let refreshBtn: UIButton = {
        let btn = UIButton()
        btn.setTitle("Refresh", for: .normal)
        btn.setTitleColor(.blue, for: .normal)
        btn.layer.cornerRadius = 2
        btn.layer.borderWidth = 1
        btn.layer.borderColor = UIColor(red:0.85, green:0.85, blue:0.85, alpha:1.0).cgColor
        btn.translatesAutoresizingMaskIntoConstraints = false
        return btn
    }()

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)!
        setupViews()
    }

    override init(frame: CGRect) {
        super.init(frame: frame)
        setupViews()
    }

    func setupViews() {

        mediaView = modMediaView
        iconView = bannerImageView
        headlineView = adTitle

        addSubview(mediaView!)
        addSubview(iconView!)
        addSubview(headlineView!)
        addSubview(refreshBtn)

        mediaView?.widthAnchor.constraint(equalTo: widthAnchor, constant: -32).isActive = true
        mediaView?.heightAnchor.constraint(equalToConstant: 160).isActive = true
        mediaView?.centerXAnchor.constraint(equalTo: centerXAnchor).isActive = true
        mediaView?.topAnchor.constraint(equalTo: topAnchor, constant: 16).isActive = true

        iconView?.widthAnchor.constraint(equalToConstant: 40).isActive = true
        iconView?.heightAnchor.constraint(equalToConstant: 40).isActive = true
        iconView?.leftAnchor.constraint(equalTo: leftAnchor, constant: 16).isActive = true
        iconView?.topAnchor.constraint(equalTo: mediaView!.bottomAnchor, constant: 16).isActive = true

        headlineView?.leftAnchor.constraint(equalTo: iconView!.rightAnchor, constant: 16).isActive = true
        headlineView?.topAnchor.constraint(equalTo: iconView!.topAnchor).isActive = true
        headlineView?.rightAnchor.constraint(equalTo: rightAnchor, constant: -16).isActive = true

        refreshBtn.bottomAnchor.constraint(equalTo: bottomAnchor, constant: -16).isActive = true
        refreshBtn.heightAnchor.constraint(equalToConstant: 45).isActive = true
        refreshBtn.widthAnchor.constraint(equalTo: widthAnchor, multiplier: 2/3, constant: -32).isActive = true
        refreshBtn.leftAnchor.constraint(equalTo: leftAnchor, constant: 16).isActive = true
    }
}

Ячейка табличного представления:

FieldListLiteAdCell.swift

import UIKit
import GoogleMobileAds

class FieldListLiteAdCell: UITableViewCell, GADUnifiedNativeAdLoaderDelegate {

    let mainView: GoogleAdBannerView = {
        let view = GoogleAdBannerView()
        view.backgroundColor = .white
        view.translatesAutoresizingMaskIntoConstraints = false
        return view
    }()

    var controller: FieldListView? {
        didSet {
            if let _ = controller {
                fetchAds()
            }
        }
    }
    var adLoader: GADAdLoader!

    override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
        super.init(style: style, reuseIdentifier: reuseIdentifier)
        self.backgroundColor = UIColor.white
        self.selectionStyle = .none

        addSubview(mainView)

        mainView.widthAnchor.constraint(equalTo: widthAnchor).isActive = true
        mainView.heightAnchor.constraint(equalTo: heightAnchor).isActive = true
        mainView.centerXAnchor.constraint(equalTo: centerXAnchor).isActive = true
        mainView.centerYAnchor.constraint(equalTo: centerYAnchor).isActive = true
        mainView.refreshBtn.addTarget(self, action: #selector(refreshFieldAds(_:)), for: .touchUpInside)

        fetchAds()
    }

    @IBAction func refreshFieldAds(_ sender: UIButton) {
        fetchAds()
    }

    private func fetchAds() {

        adLoader = GADAdLoader(adUnitID: "ca-app-pub-3940256099942544/3986624511", rootViewController: controller, adTypes: [GADAdLoaderAdType.unifiedNative], options: nil)
        adLoader.delegate = self

        let adRequest = GADRequest()
        adRequest.testDevices = [kGADSimulatorID]
        adLoader.load(adRequest)
//        adLoader.load(GADRequest())
    }

    func adLoader(_ adLoader: GADAdLoader, didReceive nativeAd: GADUnifiedNativeAd) {
        mainView.nativeAd = nativeAd
        nativeAd.delegate = self

        print("Ad has been received.")

        mainView.mediaView?.mediaContent = nativeAd.mediaContent

        (mainView.iconView as? UIImageView)?.image = nativeAd.icon?.image

        (mainView.headlineView as? UILabel)?.text = nativeAd.headline
    }

    func adLoaderDidFinishLoading(_ adLoader: GADAdLoader) {
    }

    func adLoader(_ adLoader: GADAdLoader, didFailToReceiveAdWithError error: GADRequestError) {
        print("Failed Ad Request: ", error)
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

// MARK: - GADUnifiedNativeAdDelegate implementation
extension FieldListLiteAdCell: GADUnifiedNativeAdDelegate {

    func nativeAdDidRecordClick(_ nativeAd: GADUnifiedNativeAd) {
        print("\(#function) called")
    }

    func nativeAdDidRecordImpression(_ nativeAd: GADUnifiedNativeAd) {
        print("\(#function) called")
    }

    func nativeAdWillPresentScreen(_ nativeAd: GADUnifiedNativeAd) {
        print("\(#function) called")
    }

    func nativeAdWillDismissScreen(_ nativeAd: GADUnifiedNativeAd) {
        print("\(#function) called")
    }

    func nativeAdDidDismissScreen(_ nativeAd: GADUnifiedNativeAd) {
        print("\(#function) called")
    }

    func nativeAdWillLeaveApplication(_ nativeAd: GADUnifiedNativeAd) {
        print("\(#function) called")
    }
}

Я не знаю, что я делаю неправильно. Попробовал несколько Идентификатор модуля приложения , создал несколько учетных записей, ждал более 2 часов, как предлагали некоторые ответы StackOverflow . Гарантированный идентификатор устройства добавлен в запрос.

Редактировать 1

Кто-то пометил вопрос как возможный дубликат с неподтвержденным предложением. Мне нужно было создать пример приложения, в котором реализована та же логика, и он работает нормально.

Я просмотрел файл Info.plist, чтобы убедиться, что для Allow Arbitrary Loads установлено значение YES. Мне еще предстоит определить причину ошибки.

Пример собственной реализации GoogleAd

Любая помощь будет принята с благодарностью. Спасибо.

1 Ответ

0 голосов
/ 26 марта 2019

Видимо, я не делал ничего плохого.

Закомментируя модификацию UserAgent всего приложения, выполненную, когда приложение инициализировано в делегате приложения, Google Ad Mod работает нормально.

Мой UserAgent выглядит так:

UserAgent: iOS-CompanyName/versionNumber.

Я не знаю, почему мой пользовательский пользовательский агент мешает мне получить Ads.

...