GADMobileAds クラスには、Google Mobile Ads SDK が収集する特定の情報を制御するための全般設定があります。
動画広告の音量調整
アプリに独自の音量調節機能(音楽や効果音のカスタム音量設定など)が備わっている場合、アプリの音量設定を Google Mobile Ads SDK に開示すれば、動画広告の音量にもアプリ側の音量設定を反映できます。これにより、動画広告をユーザーの想定どおりの音量で視聴してもらうことが可能になります。
デバイスの音声出力の大きさは、デバイスのボリューム(ボリューム ボタンや OS レベルのボリューム スライダーで制御)で決まります。ただし、音声の聞こえ方を独自にコントロールするために、デバイスの設定に対する相対的な音量レベルをアプリ側で独自に調節できます。
アプリ起動、バナー、インタースティシャル、リワード、リワード インタースティシャル広告フォーマットでは、applicationVolume プロパティを設定することで、相対的なアプリの音量を Google Mobile Ads SDK にレポートできます。広告の音量設定値の有効範囲は、0.0(無音)から 1.0(デバイスの現在の音量)までです。アプリ側の相対音量設定を SDK に伝えるコードは、たとえば次のようになります。
Swift
func viewDidLoad() {
  super.viewDidLoad()
  // Set app volume to be half of the current device volume.
  MobileAds.shared.applicationVolume = 0.5
  ...
}
Objective-C
- (void)viewDidLoad {
  [super viewDidLoad];
  // Set app volume to be half of the current device volume.
  GADMobileAds.sharedInstance.applicationVolume = 0.5;
  ...
}
アプリオープニング、バナー、インタースティシャル、リワード、リワード インタースティシャル広告フォーマットでは、applicationMuted プロパティを設定することで、アプリの音量がミュートになっていることを Google Mobile Ads SDK に通知できます。
Swift
MobileAds.shared.applicationMuted = true
Objective-C
GADMobileAds.sharedInstance.applicationMuted = YES;
デフォルトでは、applicationVolume は 1(現在のデバイス ボリューム)に設定され、applicationMuted は NO に設定されています。
ネイティブ広告
ミュート設定の制御手順については、GADVideoOptions をご覧ください。ネイティブ広告では、カスタム音量調節機能はサポートされていません。
オーディオ セッション
オーディオ セッションでは、アプリの音声動作について、ご自身の意図をシステムに表明できます。オーディオ セッションについて詳しくは、Apple の Audio Session Programming Guide をご覧ください。Google Mobile Ads SDK のオーディオを管理するために利用できるオプションは、audioVideoManager プロパティを介して設定します。
オーディオを使用しないアプリでは、これらの API は不要です。その場合はオーディオの再生時に、Google Mobile Ads SDK によってオーディオ セッション カテゴリが自動的に管理されます。これらの API は、アプリ内でオーディオを再生し、Google Mobile Ads SDK によるオーディオ再生の方法とタイミングを厳密に管理したい場合にご利用ください。
オーディオ セッション カテゴリをご自身の責任で管理する場合は、オーディオ動画管理で audioSessionIsApplicationManaged プロパティに YES を設定します。
オーディオ セッション カテゴリを管理する場合は、GADAudioVideoManagerDelegate を実装し、オーディオ動画管理で delegate プロパティを設定して、広告動画イベントとオーディオ再生イベントの通知を有効にできます。そして、Apple の Audio Session Programming Guide に沿って、オーディオ セッション カテゴリを関連するカテゴリに変更します。
次のサンプルコードでは、上記の API を使用してアプリで音楽を再生する場合の推奨手法を示します。
Swift
func setUp() {
  MobileAds.shared.audioVideoManager.delegate = self
  MobileAds.shared.audioVideoManager.audioSessionIsApplicationManaged = false
}
// MARK: - GADAudioVideoManagerDelegate
func audioVideoManagerWillPlayAudio(_ audioVideoManager: GADAudioVideoManager) {
  // The Google Mobile Ads SDK is notifying your app that it will play audio. You
  // could optionally pause music depending on your apps design.
  MyAppObject.shared.pauseAllMusic()
}
func audioVideoManagerDidStopPlayingAudio(_ audioVideoManager: GADAudioVideoManager) {
  // The Google Mobile Ads SDK is notifying your app that it has stopped playing
  // audio. Depending on your design, you could resume music here.
  MyAppObject.shared.resumeAllMusic()
}
Objective-C
- (void)setUp {
  GADMobileAds.sharedInstance.audioVideoManager.delegate = self;
  GADMobileAds.sharedInstance.audioVideoManager.audioSessionIsApplicationManaged = NO;
}
#pragma mark - GADAudioVideoManagerDelegate
- (void)audioVideoManagerWillPlayAudio:(GADAudioVideoManager *)audioVideoManager {
  // Google Mobile Ads SDK is notifying your app that it will play audio. You
  // could optionally pause music depending on your apps design.
  [MyAppObject.sharedInstance pauseAllMusic];
}
- (void)audioVideoManagerDidStopPlayingAudio:(GADAudioVideoManager *)audioVideoManager {
    // Google Mobile Ads SDK is notifying your app that it has stopped playing
    // audio. Depending on your design, you could resume music here.
  [MyAppObject.sharedInstance resumeAllMusic];
}
クラッシュ レポート
iOS アプリで発生した例外は Google Mobile Ads SDK で調査され、SDK が原因の場合には記録されます。これらの例外は、今後の SDK バージョンで対処されます。
クラッシュ レポートはデフォルトで有効になっています。SDK 関連の例外記録を希望されない場合は、disableSDKCrashReporting メソッドを呼び出すことで、この機能を無効にできます。このメソッドは、次のようにアプリの起動時に呼び出すのが最適です。
Swift
import GoogleMobileAds
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
  func application(_ application: UIApplication,
      didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
    MobileAds.shared.disableSDKCrashReporting()
    return true
  }
}
Objective-C
@import GoogleMobileAds;
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  [GADMobileAds disableSDKCrashReporting];
  return YES;
}
@end
Cookie の設定に対する同意
アプリに特別な要件がある場合は、オプションの NSUserDefaults
gad_has_consent_for_cookies を設定できます。gad_has_consent_for_cookies がゼロに設定されている場合、Google Mobile Ads SDK により制限付き広告(LTD)が有効にされます。
Swift
UserDefaults.standard.set(0, forKey: "gad_has_consent_for_cookies")
Objective-C
NSUserDefaults.standardUserDefaults().setObject(Int(0),
    forKey: "gad_has_consent_for_cookies");