Parametry żądań specyficznych dla sieci

Niektóre adaptery sieciowe obsługują dodatkowe parametry, które można przekazać do adaptera podczas tworzenia żądania reklamy. Są one nazywane dodatkami sieci.

Wtyczka Google Mobile Ads udostępnia interfejsy API na Androida i iOS, które umożliwiają przekazywanie dodatkowych informacji o sieci do adapterów zapośredniczenia. Aby to zrobić, musisz wdrożyć MediationNetworkExtrasProvider na Androida i FLTMediationNetworkExtrasProvider na iOS, a następnie zarejestrować implementację dostawcy dodatków w pliku dodatkowym. Następnie w ramach tworzenia żądania reklamy na Androida lub iOS wtyczka przekaże te informacje jako dodatkowe informacje sieci.

Rejestrowanie klasy MediationNetworkExtrasProvider na Androidzie

Utwórz implementację MediationNetworkExtrasProvider:

class MyMediationNetworkExtrasProvider implements MediationNetworkExtrasProvider {

  @Override
  public Map<Class<? extends MediationExtrasReceiver>, Bundle> getMediationExtras(
      String adUnitId, @Nullable String identifier) {
    // This example passes extras to the AppLovin adapter.
    // This method is called with the ad unit of the associated ad request, and
    // an optional string parameter which comes from the dart ad request object.
    Bundle appLovinBundle = new AppLovinExtras.Builder().setMuteAudio(true).build();
    Map<Class<? extends MediationExtrasReceiver>, Bundle> extras = new HashMap<>();
    extras.put(ApplovinAdapter.class, appLovinBundle);
    // Note: You can pass extras to multiple adapters by adding more entries.
    return extras;
  }
}

Następnie zarejestruj go w GoogleMobileAdsPlugin:

// Register a MediationNetworkExtrasProvider with the plugin.
public class MainActivity extends FlutterActivity {

  @Override
  public void configureFlutterEngine(@NonNull FlutterEngine flutterEngine) {
    super.configureFlutterEngine(flutterEngine);

    // Register your MediationNetworkExtrasProvider to provide network extras to ad requests.
    GoogleMobileAdsPlugin.registerMediationNetworkExtrasProvider(
        flutterEngine, new MyMediationNetworkExtrasProvider());
  }
}

Informacje o tym, które dodatkowe funkcje są obsługiwane przez różne sieci, oraz jak je tworzyć, znajdziesz w dokumentacji Androida dotyczącej danej sieci.

Rejestrowanie klasy FLTMediationNetworkExtrasProvider na iOS

Utwórz implementację FLTMediationNetworkExtrasProvider:

@implementation MyFLTMediationNetworkExtrasProvider

- (NSArray<id<GADAdNetworkExtras>> *_Nullable)getMediationExtras:(NSString *_Nonnull)adUnitId
                                       mediationExtrasIdentifier:
                                           (NSString *_Nullable)mediationExtrasIdentifier {
  // This example passes extras to the AppLovin adapter.
  // This method is called with the ad unit of the associated ad request, and
  // an optional string parameter which comes from the dart ad request object.
  GADMAdapterAppLovinExtras *appLovinExtras = [[GADMAdapterAppLovinExtras alloc] init];
  appLovinExtras.muteAudio = NO;
  // Note: You can pass extras to multiple adapters by adding more entries.

  return @[ appLovinExtras ];
}
@end

i zarejestruj go w usłudze FLTGoogleMobileAdsPlugin:


@implementation AppDelegate

- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
  [GeneratedPluginRegistrant registerWithRegistry:self];

  // Register your network extras provider if you want to provide
  // network extras to specific ad requests.
  MyFLTMediationNetworkExtrasProvider *networkExtrasProvider =
      [[MyFLTMediationNetworkExtrasProvider alloc] init];
  [FLTGoogleMobileAdsPlugin registerMediationNetworkExtrasProvider:networkExtrasProvider
                                                          registry:self];
  return [super application:application didFinishLaunchingWithOptions:launchOptions];
}

@end

Informacje o tym, które dodatkowe funkcje są obsługiwane przez różne sieci, oraz jak je tworzyć, znajdziesz w dokumentacji iOS dotyczącej danej sieci.