IMA SDK-এর বেশিরভাগ ব্যবহারে একবারে শুধুমাত্র একটি বিজ্ঞাপন অনুরোধ পরিচালনা করার প্রয়োজন হয়। তবে কিছু ব্যতিক্রমী ক্ষেত্রে, যেমন ব্যবহারকারী ভিডিও নির্বাচন করার আগে বিজ্ঞাপনের ডেটা প্রি-লোড করার জন্য, একই সাথে একাধিক অনুরোধ পাঠানোর প্রয়োজন হতে পারে। যেহেতু বিজ্ঞাপনের অনুরোধগুলো অ্যাসিঙ্ক্রোনাসভাবে করা হয়, তাই সঠিক কনটেক্সটের সাথে যথাযথ অ্যাড ম্যানেজার যুক্ত আছে কিনা তা নিশ্চিত করা একটি কঠিন কাজ বলে মনে হতে পারে।
একাধিক অ্যাড ম্যানেজারকে আলাদা করার প্রক্রিয়া সহজ করার জন্য, অ্যান্ড্রয়েডের জন্য IMA SDK পাবলিশারদের যেকোনো অ্যাড রিকোয়েস্টের UserRequestContext ফিল্ডে যেকোনো ভ্যালু বা অবজেক্ট পাস করার সুযোগ দেয়। এরপর AdsManagerLoadedEvent হ্যান্ডেলারে getUserRequestContext() মেথড ব্যবহার করে এই ভ্যালু বা অবজেক্টটি পুনরুদ্ধার করা যায়।
উদাহরণ
...
adsLoader = sdkFactory.createAdsLoader(context, imaSdkSettings, adDisplayContainer);
Map<String, String> userContextA = new HashMap<String, String>();
Map<String, String> userContextB = new HashMap<String, String>();
userContextA.put("id", "Request A");
userContextB.put("id", "Request B");
userContextA.put("element", "videoElementA");
userContextB.put("element", "videoElementB");
adRequestA.setUserRequestContext(userContextA);
adRequestB.setUserRequestContext(userContextB);
adsLoader.addAdsLoadedListener(
new AdsLoader.AdsLoadedListener() {
@Override
public void onAdsManagerLoaded(AdsManagerLoadedEvent adsManagerLoadedEvent) {
Map<String, String> context = adsManagerLoadedEvent.getUserRequestContext();
adsManager = adsManagerLoadedEvent.getAdsManager();
Log.i("ImaExample", "Successfully loaded ID: " + context.get("id"));
}
});
adsLoader.addAdErrorListener(
new AdErrorEvent.AdErrorListener() {
@Override
public void onAdError(AdErrorEvent adErrorEvent) {
Map<String, String> context = adErrorEvent.getUserRequestContext();
Log.i("ImaExample", "Error with AdRequest. ID: " + context.get("id"));
Log.i("ImaExample", "Ad Error: " + adErrorEvent.getError().getMessage());
}
});
adsLoader.requestAds(adRequestA);
adsLoader.requestAds(adRequestB);
...