পূর্বশর্ত
কাস্টম ইভেন্ট সেটআপ সম্পূর্ণ করুন।
একটি নেটিভ বিজ্ঞাপনের অনুরোধ করুন
যখন ওয়াটারফল মেডিয়েশন চেইনে কাস্টম ইভেন্ট লাইন আইটেমটি পৌঁছানো হয়, তখন কাস্টম ইভেন্ট তৈরি করার সময় আপনার দেওয়া ক্লাসের নামে loadNativeAd() পদ্ধতিটি কল করা হয়। এই ক্ষেত্রে, সেই পদ্ধতিটি SampleCustomEvent এ থাকে, যা পরে SampleNativeCustomEventLoader এ loadNativeAd() পদ্ধতিটিকে কল করে।
একটি নেটিভ বিজ্ঞাপনের অনুরোধ করতে, loadNativeAd() বাস্তবায়নের জন্য Adapter প্রসারিত করে এমন একটি ক্লাস তৈরি বা পরিবর্তন করুন। যদি Adapter প্রসারিত করে এমন একটি ক্লাস ইতিমধ্যেই বিদ্যমান থাকে, তাহলে সেখানে loadNativeAd() বাস্তবায়ন করুন। এছাড়াও, UnifiedNativeAdMapper বাস্তবায়নের জন্য একটি নতুন ক্লাস তৈরি করুন।
আমাদের কাস্টম ইভেন্ট উদাহরণে , SampleCustomEvent Adapter ক্লাসটি প্রসারিত করে এবং তারপর SampleNativeCustomEventLoader এ ডেলিগেট করে।
জাভা
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.Adapter; import com.google.android.gms.ads.mediation.MediationAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdLoadCallback; import com.google.android.gms.ads.mediation.MediationNativeAdCallback; ... public class SampleCustomEvent extends Adapter { private SampleNativeCustomEventLoader nativeLoader; @Override public void loadNativeAd( @NonNull MediationNativeAdConfiguration adConfiguration, @NonNull MediationAdLoadCallback<UnifiedNativeAdMapper, MediationNativeAdCallback> callback) { nativeLoader = new SampleNativeCustomEventLoader(adConfiguration, callback); nativeLoader.loadAd(); } }
SampleNativeCustomEventLoader নিম্নলিখিত কাজগুলির জন্য দায়ী:
নেটিভ বিজ্ঞাপন লোড হচ্ছে।
UnifiedNativeAdMapperক্লাস বাস্তবায়ন করা হচ্ছে।GMA নেক্সট জেন SDK-তে বিজ্ঞাপন ইভেন্ট কলব্যাক গ্রহণ এবং রিপোর্ট করা।
AdMob UI-তে সংজ্ঞায়িত ঐচ্ছিক প্যারামিটারটি বিজ্ঞাপন কনফিগারেশনে অন্তর্ভুক্ত থাকে। প্যারামিটারটি adConfiguration.getServerParameters().getString(MediationConfiguration.CUSTOM_EVENT_SERVER_PARAMETER_FIELD) এর মাধ্যমে অ্যাক্সেস করা যেতে পারে। এই প্যারামিটারটি সাধারণত একটি বিজ্ঞাপন ইউনিট শনাক্তকারী যা একটি বিজ্ঞাপন নেটওয়ার্ক SDK-এর একটি বিজ্ঞাপন অবজেক্ট ইনস্ট্যান্টিয়েট করার সময় প্রয়োজন হয়।
জাভা
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.Adapter; import com.google.android.gms.ads.mediation.MediationNativeAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdLoadCallback; import com.google.android.gms.ads.mediation.MediationNativeAdCallback; ... public class SampleNativeCustomEventLoader extends SampleNativeAdListener { /** Configuration for requesting the native ad from the third-party network. */ private final MediationNativeAdConfiguration mediationNativeAdConfiguration; /** Callback that fires on loading success or failure. */ private final MediationAdLoadCallback<UnifiedNativeAdMapper, MediationNativeAdCallback> mediationAdLoadCallback; /** Callback for native ad events. */ private MediationNativeAdCallback nativeAdCallback; /** Constructor */ public SampleNativeCustomEventLoader( @NonNull MediationNativeAdConfiguration mediationNativeAdConfiguration, @NonNull MediationAdLoadCallback<MediationNativeAd, MediationNativeAdCallback> mediationAdLoadCallback) { this.mediationNativeAdConfiguration = mediationNativeAdConfiguration; this.mediationAdLoadCallback = mediationAdLoadCallback; } /** Loads the native ad from the third-party ad network. */ public void loadAd() { // Create one of the Sample SDK's ad loaders to request ads. Log.i("NativeCustomEvent", "Begin loading native ad."); SampleNativeAdLoader loader = new SampleNativeAdLoader(mediationNativeAdConfiguration.getContext()); // All custom events have a server parameter named "parameter" that returns // back the parameter entered into the UI when defining the custom event. String serverParameter = mediationNativeAdConfiguration .getServerParameters() .getString(MediationConfiguration .CUSTOM_EVENT_SERVER_PARAMETER_FIELD); Log.d("NativeCustomEvent", "Received server parameter."); loader.setAdUnit(serverParameter); // Create a native request to give to the SampleNativeAdLoader. SampleNativeAdRequest request = new SampleNativeAdRequest(); NativeAdOptions options = mediationNativeAdConfiguration.getNativeAdOptions(); if (options != null) { // If the NativeAdOptions' shouldReturnUrlsForImageAssets is true, the adapter should // send just the URLs for the images. request.setShouldDownloadImages(!options.shouldReturnUrlsForImageAssets()); request.setShouldDownloadMultipleImages(options.shouldRequestMultipleImages()); switch (options.getMediaAspectRatio()) { case NativeAdOptions.NATIVE_MEDIA_ASPECT_RATIO_LANDSCAPE: request.setPreferredImageOrientation(SampleNativeAdRequest.IMAGE_ORIENTATION_LANDSCAPE); break; case NativeAdOptions.NATIVE_MEDIA_ASPECT_RATIO_PORTRAIT: request.setPreferredImageOrientation(SampleNativeAdRequest.IMAGE_ORIENTATION_PORTRAIT); break; case NativeAdOptions.NATIVE_MEDIA_ASPECT_RATIO_SQUARE: case NativeAdOptions.NATIVE_MEDIA_ASPECT_RATIO_ANY: case NativeAdOptions.NATIVE_MEDIA_ASPECT_RATIO_UNKNOWN: default: request.setPreferredImageOrientation(SampleNativeAdRequest.IMAGE_ORIENTATION_ANY); } } loader.setNativeAdListener(this); // Begin a request. Log.i("NativeCustomEvent", "Start fetching native ad."); loader.fetchAd(request); } }
বিজ্ঞাপনটি সফলভাবে আনা হয়েছে নাকি কোনও ত্রুটির সম্মুখীন হয়েছে তার উপর নির্ভর করে, আপনি onSuccess() অথবা onFailure() কল করতে পারেন। MediationNativeAd প্রয়োগকারী ক্লাসের একটি উদাহরণ পাস করে onSuccess() কল করা হয়।
সাধারণত, এই পদ্ধতিগুলি আপনার অ্যাডাপ্টার দ্বারা প্রয়োগ করা তৃতীয়-পক্ষের SDK থেকে কলব্যাকের ভিতরে প্রয়োগ করা হয়। এই উদাহরণের জন্য, Sample SDK-তে প্রাসঙ্গিক কলব্যাক সহ একটি SampleAdListener রয়েছে:
জাভা
@Override public void onNativeAdFetched(SampleNativeAd ad) { SampleUnifiedNativeAdMapper mapper = new SampleUnifiedNativeAdMapper(ad); mediationNativeAdCallback = mediationAdLoadCallback.onSuccess(mapper); } @Override public void onAdFetchFailed(SampleErrorCode errorCode) { mediationAdLoadCallback.onFailure(SampleCustomEventError.createSampleSdkError(errorCode)); }
ম্যাপের নেটিভ বিজ্ঞাপনগুলি
বিভিন্ন SDK-এর নেটিভ বিজ্ঞাপনের জন্য নিজস্ব অনন্য ফর্ম্যাট রয়েছে। উদাহরণস্বরূপ, একটি "শিরোনাম" ক্ষেত্র ধারণকারী বস্তুগুলি ফেরত দিতে পারে, আবার অন্যটি "শিরোনাম" থাকতে পারে। এছাড়াও, ইম্প্রেশন ট্র্যাক করার এবং ক্লিক প্রক্রিয়া করার জন্য ব্যবহৃত পদ্ধতিগুলি এক SDK থেকে অন্য SDK-তে পরিবর্তিত হতে পারে।
UnifiedNativeAdMapper এই পার্থক্যগুলি মিটিয়ে ফেলার জন্য এবং GMA Next Gen SDK-এর প্রত্যাশিত ইন্টারফেসের সাথে মেলে এমন একটি মধ্যস্থতাকারী SDK-এর নেটিভ বিজ্ঞাপন অবজেক্টকে অভিযোজিত করার জন্য দায়ী। কাস্টম ইভেন্টগুলির এই ক্লাসটি প্রসারিত করা উচিত যাতে তাদের মধ্যস্থতাকারী SDK-এর জন্য নির্দিষ্ট নিজস্ব ম্যাপার তৈরি করা যায়। আমাদের উদাহরণ কাস্টম ইভেন্ট প্রকল্প থেকে একটি নমুনা বিজ্ঞাপন ম্যাপার এখানে দেওয়া হল:
জাভা
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.UnifiedNativeAdMapper; import com.google.android.gms.ads.nativead.NativeAd; ... public class SampleUnifiedNativeAdMapper extends UnifiedNativeAdMapper { private final SampleNativeAd sampleAd; public SampleUnifiedNativeAdMapper(SampleNativeAd ad) { sampleAd = ad; setHeadline(sampleAd.getHeadline()); setBody(sampleAd.getBody()); setCallToAction(sampleAd.getCallToAction()); setStarRating(sampleAd.getStarRating()); setStore(sampleAd.getStoreName()); setIcon( new SampleNativeMappedImage( ad.getIcon(), ad.getIconUri(), SampleCustomEvent.SAMPLE_SDK_IMAGE_SCALE)); setAdvertiser(ad.getAdvertiser()); List<NativeAd.Image> imagesList = new ArrayList<NativeAd.Image>(); imagesList.add(new SampleNativeMappedImage(ad.getImage(), ad.getImageUri(), SampleCustomEvent.SAMPLE_SDK_IMAGE_SCALE)); setImages(imagesList); if (sampleAd.getPrice() != null) { NumberFormat formatter = NumberFormat.getCurrencyInstance(); String priceString = formatter.format(sampleAd.getPrice()); setPrice(priceString); } Bundle extras = new Bundle(); extras.putString(SampleCustomEvent.DEGREE_OF_AWESOMENESS, ad.getDegreeOfAwesomeness()); this.setExtras(extras); setOverrideClickHandling(false); setOverrideImpressionRecording(false); setAdChoicesContent(sampleAd.getInformationIcon()); } @Override public void recordImpression() { sampleAd.recordImpression(); } @Override public void handleClick(View view) { sampleAd.handleClick(view); } // The Sample SDK doesn't do its own impression/click tracking, instead relies on its // publishers calling the recordImpression and handleClick methods on its native ad object. So // there's no need to pass a reference to the View being used to display the native ad. If // your mediated network does need a reference to the view, the following method can be used // to provide one. @Override public void trackViews(View containerView, Map<String, View> clickableAssetViews, Map<String, View> nonClickableAssetViews) { super.trackViews(containerView, clickableAssetViews, nonClickableAssetViews); // If your ad network SDK does its own impression tracking, here is where you can track the // top level native ad view and its individual asset views. } @Override public void untrackView(View view) { super.untrackView(view); // Here you would remove any trackers from the View added in trackView. } }
এখন আমরা কন্সট্রাকটর কোডটি ঘনিষ্ঠভাবে দেখব।
মধ্যস্থতাকারী নেটিভ বিজ্ঞাপন অবজেক্টের একটি রেফারেন্স ধরে রাখুন
কনস্ট্রাক্টর SampleNativeAd প্যারামিটার গ্রহণ করে, যা Sample SDK তার নেটিভ বিজ্ঞাপনের জন্য ব্যবহৃত নেটিভ বিজ্ঞাপন ক্লাস। ম্যাপারের মধ্যস্থতাকারী বিজ্ঞাপনের একটি রেফারেন্স প্রয়োজন যাতে এটি ক্লিক এবং ইম্প্রেশন ইভেন্টগুলি প্রেরণ করতে পারে। SampleNativeAd একটি স্থানীয় ভেরিয়েবল হিসাবে সংরক্ষণ করা হয়।
ম্যাপ করা সম্পদের বৈশিষ্ট্য সেট করুন
কনস্ট্রাক্টর UnifiedNativeAdMapper এ সম্পদ পূরণ করতে SampleNativeAd অবজেক্ট ব্যবহার করে।
এই স্নিপেটটি মধ্যস্থতাকারী বিজ্ঞাপনের মূল্যের তথ্য সংগ্রহ করে এবং ম্যাপারের মূল্য নির্ধারণ করতে এটি ব্যবহার করে:
জাভা
if (sampleAd.getPrice() != null) { NumberFormat formatter = NumberFormat.getCurrencyInstance(); String priceString = formatter.format(sampleAd.getPrice()); setPrice(priceString); }
এই উদাহরণে, মধ্যস্থতাকারী বিজ্ঞাপনটি দামকে double হিসাবে সঞ্চয় করে, যখন AdMob একই সম্পদের জন্য একটি String ব্যবহার করে। এই ধরণের রূপান্তর পরিচালনা করার জন্য ম্যাপার দায়ী।
মানচিত্রের চিত্র সম্পদ
double অথবা String এর মতো ডেটা টাইপ ম্যাপিংয়ের তুলনায় ছবির সম্পদ ম্যাপিং করা অনেক বেশি জটিল। ছবিগুলি স্বয়ংক্রিয়ভাবে ডাউনলোড হতে পারে অথবা URL মান হিসেবে ফেরত পাঠানো হতে পারে। তাদের পিক্সেল-থেকে-dpi স্কেলও পরিবর্তিত হতে পারে।
এই বিশদগুলি পরিচালনা করতে আপনাকে সাহায্য করার জন্য, GMA Next Gen SDK NativeAd.Image ক্লাস প্রদান করে। একটি মধ্যস্থতাকারী নেটিভ বিজ্ঞাপন ম্যাপ করার জন্য আপনাকে যেভাবে UnifiedNativeAdMapper এর একটি সাবক্লাস তৈরি করতে হয়, ঠিক একইভাবে ছবির সম্পদ ম্যাপ করার সময় আপনার NativeAd.Image এর একটি সাবক্লাস তৈরি করা উচিত।
কাস্টম ইভেন্টের SampleNativeMappedImage ক্লাসের একটি উদাহরণ এখানে দেওয়া হল:
জাভা
public class SampleNativeMappedImage extends NativeAd.Image { private Drawable drawable; private Uri imageUri; private double scale; public SampleNativeMappedImage(Drawable drawable, Uri imageUri, double scale) { this.drawable = drawable; this.imageUri = imageUri; this.scale = scale; } @Override public Drawable getDrawable() { return drawable; } @Override public Uri getUri() { return imageUri; } @Override public double getScale() { return scale; } }
SampleNativeAdMapper ম্যাপারের আইকন ইমেজ অ্যাসেট সেট করতে এই লাইনে তার ম্যাপ করা ইমেজ ক্লাস ব্যবহার করে:
জাভা
setIcon(new SampleNativeMappedImage(ad.getAppIcon(), ad.getAppIconUri(), SampleCustomEvent.SAMPLE_SDK_IMAGE_SCALE));
অতিরিক্ত বান্ডেলে ক্ষেত্র যোগ করুন
কিছু মধ্যস্থতাকৃত SDK AdMob নেটিভ বিজ্ঞাপন ফর্ম্যাটের বাইরেও অতিরিক্ত সম্পদ সরবরাহ করে। UnifiedNativeAdMapper ক্লাসে একটি setExtras() পদ্ধতি রয়েছে যা প্রকাশকদের কাছে এই সম্পদগুলি প্রেরণ করতে ব্যবহৃত হয়। SampleNativeAdMapper Sample SDK এর "অসাধারণতার ডিগ্রি" সম্পদের জন্য এটি ব্যবহার করে:
জাভা
Bundle extras = new Bundle(); extras.putString(SampleCustomEvent.DEGREE_OF_AWESOMENESS, ad.getDegreeOfAwesomeness()); this.setExtras(extras);
প্রকাশকরা NativeAd ক্লাসের getExtras() পদ্ধতি ব্যবহার করে ডেটা পুনরুদ্ধার করতে পারেন।
অ্যাডচয়েস
আপনার কাস্টম ইভেন্টটি UnifiedNativeAdMapper এ setAdChoicesContent() পদ্ধতি ব্যবহার করে একটি AdChoices আইকন প্রদানের জন্য দায়ী। এখানে SampleNativeAdMapper এর একটি স্নিপেট দেওয়া হল যেখানে দেখানো হয়েছে কিভাবে AdChoices আইকন প্রদান করতে হয়:
জাভা
public SampleNativeAdMapper(SampleNativeAd ad) { ... setAdChoicesContent(sampleAd.getInformationIcon()); }
ছাপ এবং ক্লিক ইভেন্ট
GMA নেক্সট জেন SDK এবং মিডিয়াটেড SDK উভয়কেই জানতে হবে কখন কোন ইম্প্রেশন বা ক্লিক হয়, কিন্তু এই ইভেন্টগুলি ট্র্যাক করার জন্য শুধুমাত্র একটি SDK-এর প্রয়োজন। মিডিয়াটেড SDK ইম্প্রেশন এবং ক্লিকগুলি ট্র্যাক করার জন্য নিজে থেকে সমর্থন করে কিনা তার উপর নির্ভর করে কাস্টম ইভেন্টগুলি দুটি ভিন্ন পদ্ধতি ব্যবহার করতে পারে।
GMA নেক্সট জেন SDK ব্যবহার করে ক্লিক এবং ইম্প্রেশন ট্র্যাক করুন
যদি মধ্যস্থতাকৃত SDK নিজস্ব ইম্প্রেশন এবং ক্লিক ট্র্যাকিং না করে কিন্তু ক্লিক এবং ইম্প্রেশন রেকর্ড করার পদ্ধতি প্রদান করে, তাহলে GMA Next Gen SDK এই ইভেন্টগুলি ট্র্যাক করতে পারে এবং অ্যাডাপ্টারকে অবহিত করতে পারে। UnifiedNativeAdMapper ক্লাসে দুটি পদ্ধতি রয়েছে: recordImpression() এবং handleClick() যা কাস্টম ইভেন্টগুলি মধ্যস্থতাকৃত নেটিভ বিজ্ঞাপন অবজেক্টে সংশ্লিষ্ট পদ্ধতি কল করার জন্য প্রয়োগ করতে পারে:
জাভা
@Override public void recordImpression() { sampleAd.recordImpression(); } @Override public void handleClick(View view) { sampleAd.handleClick(view); }
যেহেতু SampleNativeAdMapper Sample SDK-এর নেটিভ বিজ্ঞাপন অবজেক্টের একটি রেফারেন্স ধারণ করে, তাই এটি ক্লিক বা ইম্প্রেশন রিপোর্ট করার জন্য সেই অবজেক্টের উপর উপযুক্ত পদ্ধতিটি কল করতে পারে। মনে রাখবেন যে handleClick() পদ্ধতিটি একটি একক প্যারামিটার নেয়: ক্লিকটি প্রাপ্ত নেটিভ বিজ্ঞাপন অ্যাসেটের সাথে সম্পর্কিত View অবজেক্ট।
মধ্যস্থতাকারী SDK ব্যবহার করে ক্লিক এবং ইম্প্রেশন ট্র্যাক করুন
কিছু মধ্যস্থতাকারী SDK নিজেরাই ক্লিক এবং ইম্প্রেশন ট্র্যাক করতে পছন্দ করতে পারে। সেক্ষেত্রে, আপনার UnifiedNativeAdMapper এর কনস্ট্রাক্টরে নিম্নলিখিত দুটি কল করে ডিফল্ট ক্লিক এবং ইম্প্রেশন ট্র্যাকিংকে ওভাররাইড করা উচিত:
জাভা
setOverrideClickHandling(true); setOverrideImpressionRecording(true);
ক্লিক এবং ইম্প্রেশন ট্র্যাকিংকে ওভাররাইড করে এমন কাস্টম ইভেন্টগুলিকে onAdClicked() এবং onAdImpression() ইভেন্টগুলি Google মোবাইল বিজ্ঞাপন SDK-তে রিপোর্ট করতে হবে।
ইম্প্রেশন এবং ক্লিক ট্র্যাক করার জন্য, মিডিয়াটেড SDK-এর সম্ভবত ট্র্যাকিং সক্ষম করার জন্য ভিউগুলিতে অ্যাক্সেসের প্রয়োজন হবে। কাস্টম ইভেন্টটি trackViews() পদ্ধতিটিকে ওভাররাইড করবে এবং ট্র্যাক করার জন্য নেটিভ বিজ্ঞাপনের ভিউ মিডিয়াটেড SDK-তে পাস করার জন্য এটি ব্যবহার করবে। আমাদের কাস্টম ইভেন্ট উদাহরণ প্রকল্পের নমুনা SDK (যা থেকে এই গাইডের কোড স্নিপেট নেওয়া হয়েছে) এই পদ্ধতিটি ব্যবহার করে না; কিন্তু যদি এটি করে থাকে, তাহলে কাস্টম ইভেন্ট কোডটি দেখতে এরকম কিছু হবে:
জাভা
@Override public void trackViews(View containerView, Map<String, View> clickableAssetViews, Map<String, View> nonClickableAssetViews) { sampleAd.setNativeAdViewForTracking(containerView); }
যদি মধ্যস্থতাকারী SDK পৃথক সম্পদ ট্র্যাকিং সমর্থন করে, তাহলে এটি clickableAssetViews ভিতরে দেখতে পারে কোন ভিউগুলিকে ক্লিকযোগ্য করা উচিত। এই মানচিত্রটি NativeAdAssetNames এ একটি সম্পদের নাম দ্বারা কী করা হয়। UnifiedNativeAdMapper একটি সংশ্লিষ্ট untrackView() পদ্ধতি অফার করে যা কাস্টম ইভেন্টগুলি ভিউতে যেকোনো রেফারেন্স প্রকাশ করতে এবং নেটিভ বিজ্ঞাপন অবজেক্ট থেকে এটিকে বিচ্ছিন্ন করতে ওভাররাইড করতে পারে।
মধ্যস্থতা ইভেন্টগুলি GMA নেক্সট জেনারেশন SDK-তে ফরোয়ার্ড করুন
মেডিটেশন যে সকল কলব্যাক সমর্থন করে তা আপনি MediationNativeAdCallback ডক্সে খুঁজে পেতে পারেন।
আপনার কাস্টম ইভেন্টটি যতটা সম্ভব এই কলব্যাকগুলিকে ফরোয়ার্ড করা গুরুত্বপূর্ণ, যাতে আপনার অ্যাপটি GMA Next Gen SDK থেকে এই সমতুল্য ইভেন্টগুলি গ্রহণ করে। কলব্যাক ব্যবহারের একটি উদাহরণ এখানে দেওয়া হল:
এটি নেটিভ বিজ্ঞাপনের জন্য কাস্টম ইভেন্ট বাস্তবায়ন সম্পূর্ণ করে। সম্পূর্ণ উদাহরণটি GitHub- এ উপলব্ধ।