এই নির্দেশিকাটি সেইসব পাবলিশারদের জন্য তৈরি করা হয়েছে যারা অ্যাপ ওপেন অ্যাড ইন্টিগ্রেট করেন।
অ্যাপ ওপেন অ্যাড হলো একটি বিশেষ বিজ্ঞাপন ফরম্যাট, যা অ্যাপ পাবলিশারদের তাদের অ্যাপ লোড স্ক্রিন থেকে অর্থ উপার্জনের উদ্দেশ্যে তৈরি করা হয়েছে। আপনার ব্যবহারকারীরা যেকোনো সময় অ্যাপ ওপেন অ্যাড বন্ধ করতে পারেন। ব্যবহারকারীরা যখন আপনার অ্যাপটিকে ফোরগ্রাউন্ডে নিয়ে আসেন, তখন অ্যাপ ওপেন অ্যাড দেখানো হতে পারে।
অ্যাপ খোলার বিজ্ঞাপনগুলিতে স্বয়ংক্রিয়ভাবে একটি ছোট ব্র্যান্ডিং এলাকা দেখানো হয়, যাতে ব্যবহারকারীরা বুঝতে পারে যে তারা আপনার অ্যাপে প্রবেশ করেছে। একটি অ্যাপ খোলার বিজ্ঞাপন দেখতে কেমন হয়, তার একটি উদাহরণ নিচে দেওয়া হলো:

মোটামুটিভাবে, অ্যাপ খোলার বিজ্ঞাপন চালু করার জন্য প্রয়োজনীয় ধাপগুলো নিচে দেওয়া হলো:
- এমন একটি ম্যানেজার ক্লাস তৈরি করুন যা বিজ্ঞাপনটি প্রদর্শনের প্রয়োজনের আগেই লোড করে।
- অ্যাপ ফোরগ্রাউন্ডিং ইভেন্টের সময় বিজ্ঞাপনটি দেখান।
- প্রেজেন্টেশন কলব্যাকগুলো পরিচালনা করুন।
পূর্বশর্ত
- Google Mobile Ads SDK সেট আপ করুন ।
- আপনার ডিভাইসটিকে টেস্ট ডিভাইস হিসেবে কীভাবে কনফিগার করতে হয় তা জেনে নিন।
সর্বদা টেস্ট অ্যাড দিয়ে পরীক্ষা করুন
আপনার অ্যাপ তৈরি ও পরীক্ষা করার সময়, লাইভ বা প্রোডাকশন অ্যাডের পরিবর্তে টেস্ট অ্যাড ব্যবহার করুন। এটি করতে ব্যর্থ হলে আপনার অ্যাকাউন্ট সাসপেন্ড হতে পারে।
টেস্ট অ্যাড লোড করার সবচেয়ে সহজ উপায় হলো অ্যাপ ওপেন অ্যাডের জন্য আমাদের নির্দিষ্ট টেস্ট অ্যাড ইউনিট আইডি ব্যবহার করা:
/21775744923/example/app-open
প্রতিটি অনুরোধের জন্য পরীক্ষামূলক বিজ্ঞাপন দেখানোর জন্য এটি বিশেষভাবে কনফিগার করা হয়েছে, এবং কোডিং, টেস্টিং ও ডিবাগিং করার সময় আপনি আপনার নিজের অ্যাপে এটি নির্দ্বিধায় ব্যবহার করতে পারেন। শুধু আপনার অ্যাপটি প্রকাশ করার আগে নিশ্চিত হয়ে নেবেন যে আপনি এটিকে আপনার নিজের অ্যাড ইউনিট আইডি দিয়ে প্রতিস্থাপন করেছেন।
Google Mobile Ads SDK টেস্ট অ্যাডগুলো কীভাবে কাজ করে সে সম্পর্কে আরও তথ্যের জন্য, টেস্ট অ্যাডস দেখুন।
একটি ম্যানেজার ক্লাস বাস্তবায়ন করুন
আপনার বিজ্ঞাপনটি দ্রুত দেখানো উচিত, তাই এটি দেখানোর প্রয়োজন হওয়ার আগেই লোড করে রাখা ভালো। এর ফলে, ব্যবহারকারী আপনার অ্যাপে প্রবেশ করার সাথে সাথেই বিজ্ঞাপনটি দেখানোর জন্য প্রস্তুত থাকবে। বিজ্ঞাপন দেখানোর প্রয়োজন হওয়ার আগেই বিজ্ঞাপনের অনুরোধগুলো পাঠানোর জন্য একটি ম্যানেজার ক্লাস প্রয়োগ করুন।
AppOpenAdManager নামে একটি নতুন সিঙ্গেলটন ক্লাস তৈরি করুন:
সুইফট
class AppOpenAdManager: NSObject {
/// The app open ad.
var appOpenAd: AppOpenAd?
/// Maintains a reference to the delegate.
weak var appOpenAdManagerDelegate: AppOpenAdManagerDelegate?
/// Keeps track of if an app open ad is loading.
var isLoadingAd = false
/// Keeps track of if an app open ad is showing.
var isShowingAd = false
/// Keeps track of the time when an app open ad was loaded to discard expired ad.
var loadTime: Date?
/// For more interval details, see https://support.google.com/admanager/answer/9351867
let timeoutInterval: TimeInterval = 4 * 3_600
static let shared = AppOpenAdManager()
উদ্দেশ্য-সি
@interface AppOpenAdManager ()
/// The app open ad.
@property(nonatomic, strong, nullable) GADAppOpenAd *appOpenAd;
/// Keeps track of if an app open ad is loading.
@property(nonatomic, assign) BOOL isLoadingAd;
/// Keeps track of if an app open ad is showing.
@property(nonatomic, assign) BOOL isShowingAd;
/// Keeps track of the time when an app open ad was loaded to discard expired ad.
@property(nonatomic, strong, nullable) NSDate *loadTime;
@end
/// For more interval details, see https://support.google.com/admanager/answer/9351867
static const NSInteger kTimeoutInterval = 4;
@implementation AppOpenAdManager
+ (nonnull AppOpenAdManager *)sharedInstance {
static AppOpenAdManager *instance = nil;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
instance = [[AppOpenAdManager alloc] init];
});
return instance;
}
এবং এর AppOpenAdManagerDelegate প্রোটোকলটি বাস্তবায়ন করুন:
সুইফট
protocol AppOpenAdManagerDelegate: AnyObject {
/// Method to be invoked when an app open ad life cycle is complete (i.e. dismissed or fails to
/// show).
func appOpenAdManagerAdDidComplete(_ appOpenAdManager: AppOpenAdManager)
}
উদ্দেশ্য-সি
@protocol AppOpenAdManagerDelegate <NSObject>
/// Method to be invoked when an app open ad life cycle is complete (i.e. dismissed or fails to
/// show).
- (void)adDidComplete;
@end
একটি বিজ্ঞাপন লোড করুন
পরবর্তী ধাপ হলো একটি অ্যাপ খোলার বিজ্ঞাপন লোড করা:
সুইফট
func loadAd() async {
// Do not load ad if there is an unused ad or one is already loading.
if isLoadingAd || isAdAvailable() {
return
}
isLoadingAd = true
do {
appOpenAd = try await AppOpenAd.load(
with: "/21775744923/example/app-open", request: AdManagerRequest())
appOpenAd?.fullScreenContentDelegate = self
loadTime = Date()
} catch {
print("App open ad failed to load with error: \(error.localizedDescription)")
appOpenAd = nil
loadTime = nil
}
isLoadingAd = false
}
উদ্দেশ্য-সি
- (void)loadAd {
// Do not load ad if there is an unused ad or one is already loading.
if ([self isAdAvailable] || self.isLoadingAd) {
return;
}
self.isLoadingAd = YES;
[GADAppOpenAd loadWithAdUnitID:@"/21775744923/example/app-open"
request:[GADRequest request]
completionHandler:^(GADAppOpenAd * _Nullable appOpenAd, NSError * _Nullable error) {
self.isLoadingAd = NO;
if (error) {
NSLog(@"App open ad failed to load with error: %@", error);
self.appOpenAd = nil;
self.loadTime = nil;
return;
}
self.appOpenAd = appOpenAd;
self.appOpenAd.fullScreenContentDelegate = self;
self.loadTime = [NSDate date];
}];
}
একটি বিজ্ঞাপন দেখান
পরবর্তী ধাপ হলো একটি অ্যাপ খোলার বিজ্ঞাপন দেখানো। যদি কোনো বিজ্ঞাপন উপলব্ধ না থাকে, তাহলে একটি নতুন বিজ্ঞাপন লোড করার চেষ্টা করুন।
সুইফট
func showAdIfAvailable() {
// If the app open ad is already showing, do not show the ad again.
if isShowingAd {
return print("App open ad is already showing.")
}
// If the app open ad is not available yet but is supposed to show, load
// a new ad.
if !isAdAvailable() {
print("App open ad is not ready yet.")
// The app open ad is considered to be complete in this example.
appOpenAdManagerDelegate?.appOpenAdManagerAdDidComplete(self)
// Load a new ad.
return
}
if let appOpenAd {
print("App open ad will be displayed.")
appOpenAd.present(from: nil)
isShowingAd = true
}
}
উদ্দেশ্য-সি
- (void)showAdIfAvailable {
// If the app open ad is already showing, do not show the ad again.
if (self.isShowingAd) {
NSLog(@"App open ad is already showing.");
return;
}
// If the app open ad is not available yet but is supposed to show, load
// a new ad.
if (![self isAdAvailable]) {
NSLog(@"App open ad is not ready yet.");
// The app open ad is considered to be complete in this example.
[self adDidComplete];
// Load a new ad.
return;
}
[self.appOpenAd presentFromRootViewController:nil];
self.isShowingAd = YES;
}
অ্যাপ ফোরগ্রাউন্ডিং ইভেন্টের সময় বিজ্ঞাপনটি দেখান
অ্যাপ্লিকেশনটি সক্রিয় হলে, কোনো বিজ্ঞাপন উপলব্ধ থাকলে তা দেখানোর জন্য অথবা নতুন কোনো বিজ্ঞাপন লোড করার জন্য showAdIfAvailable() ফাংশনটি কল করুন।
সুইফট
func applicationDidBecomeActive(_ application: UIApplication) {
// Show the app open ad when the app is foregrounded.
AppOpenAdManager.shared.showAdIfAvailable()
}
উদ্দেশ্য-সি
- (void) applicationDidBecomeActive:(UIApplication *)application {
// Show the app open ad when the app is foregrounded.
[AppOpenAdManager.sharedInstance showAdIfAvailable];
}
প্রেজেন্টেশন কলব্যাকগুলি পরিচালনা করুন
প্রেজেন্টেশন ইভেন্টের নোটিফিকেশন পেতে, আপনাকে অবশ্যই ফেরত আসা অ্যাডের fullScreenContentDelegate প্রপার্টিতে GADFullScreenContentDelegate কে অ্যাসাইন করতে হবে:
সুইফট
appOpenAd?.fullScreenContentDelegate = self
উদ্দেশ্য-সি
self.appOpenAd.fullScreenContentDelegate = self;
বিশেষ করে, প্রথম বিজ্ঞাপনটি দেখানো শেষ হলেই আপনি পরবর্তী অ্যাপ খোলার বিজ্ঞাপনটির জন্য অনুরোধ করতে চাইবেন। নিম্নলিখিত কোডটি দেখায় কিভাবে আপনার AppOpenAdManager ফাইলে প্রোটোকলটি প্রয়োগ করতে হয়:
সুইফট
func adDidRecordImpression(_ ad: FullScreenPresentingAd) {
print("App open ad recorded an impression.")
}
func adDidRecordClick(_ ad: FullScreenPresentingAd) {
print("App open ad recorded a click.")
}
func adWillDismissFullScreenContent(_ ad: FullScreenPresentingAd) {
print("App open ad will be dismissed.")
}
func adWillPresentFullScreenContent(_ ad: FullScreenPresentingAd) {
print("App open ad will be presented.")
}
func adDidDismissFullScreenContent(_ ad: FullScreenPresentingAd) {
print("App open ad was dismissed.")
appOpenAd = nil
isShowingAd = false
appOpenAdManagerDelegate?.appOpenAdManagerAdDidComplete(self)
Task {
await loadAd()
}
}
func ad(
_ ad: FullScreenPresentingAd,
didFailToPresentFullScreenContentWithError error: Error
) {
print("App open ad failed to present with error: \(error.localizedDescription)")
appOpenAd = nil
isShowingAd = false
appOpenAdManagerDelegate?.appOpenAdManagerAdDidComplete(self)
Task {
await loadAd()
}
}
উদ্দেশ্য-সি
- (void)adDidRecordImpression:(nonnull id<GADFullScreenPresentingAd>)ad {
NSLog(@"App open ad recorded an impression.");
}
- (void)adDidRecordClick:(nonnull id<GADFullScreenPresentingAd>)ad {
NSLog(@"App open ad recorded a click.");
}
- (void)adWillPresentFullScreenContent:(nonnull id<GADFullScreenPresentingAd>)ad {
NSLog(@"App open ad will be presented.");
}
- (void)adWillDismissFullScreenContent:(nonnull id<GADFullScreenPresentingAd>)ad {
NSLog(@"App open ad will be dismissed.");
}
- (void)adDidDismissFullScreenContent:(nonnull id<GADFullScreenPresentingAd>)ad {
NSLog(@"App open ad was dismissed.");
self.appOpenAd = nil;
self.isShowingAd = NO;
[self adDidComplete];
[self loadAd];
}
- (void)ad:(nonnull id<GADFullScreenPresentingAd>)ad
didFailToPresentFullScreenContentWithError:(nonnull NSError *)error {
NSLog(@"App open ad failed to present with error: %@", error.localizedDescription);
self.appOpenAd = nil;
self.isShowingAd = NO;
[self adDidComplete];
[self loadAd];
}
বিজ্ঞাপনের মেয়াদ শেষ হওয়ার বিষয়টি বিবেচনা করুন
মেয়াদোত্তীর্ণ বিজ্ঞাপন যাতে দেখানো না হয়, তা নিশ্চিত করতে আপনি অ্যাপ ডেলিগেটে এমন একটি মেথড যোগ করতে পারেন যা আপনার বিজ্ঞাপন রেফারেন্স লোড হওয়ার পর থেকে অতিবাহিত সময় পরীক্ষা করবে।
আপনার AppOpenAdManager এ loadTime নামে একটি Date প্রপার্টি যোগ করুন এবং আপনার বিজ্ঞাপন লোড হওয়ার সময়টি সেট করুন। এরপর আপনি এমন একটি মেথড যোগ করতে পারেন যা আপনার বিজ্ঞাপন লোড হওয়ার পর একটি নির্দিষ্ট সংখ্যক ঘণ্টার কম সময় অতিবাহিত হলে true রিটার্ন করবে। বিজ্ঞাপন দেখানোর চেষ্টা করার আগে আপনার বিজ্ঞাপন রেফারেন্সের বৈধতা যাচাই করে নিন।
সুইফট
private func wasLoadTimeLessThanNHoursAgo(timeoutInterval: TimeInterval) -> Bool {
// Check if ad was loaded more than n hours ago.
if let loadTime = loadTime {
return Date().timeIntervalSince(loadTime) < timeoutInterval
}
return false
}
private func isAdAvailable() -> Bool {
// Check if ad exists and can be shown.
return appOpenAd != nil && wasLoadTimeLessThanNHoursAgo(timeoutInterval: timeoutInterval)
}
উদ্দেশ্য-সি
- (BOOL)wasLoadTimeLessThanNHoursAgo:(int)n {
// Check if ad was loaded more than n hours ago.
NSDate *now = [NSDate date];
NSTimeInterval timeIntervalBetweenNowAndLoadTime = [now timeIntervalSinceDate:self.loadTime];
double secondsPerHour = 3600.0;
double intervalInHours = timeIntervalBetweenNowAndLoadTime / secondsPerHour;
return intervalInHours < n;
}
- (BOOL)isAdAvailable {
// Check if ad exists and can be shown.
return self.appOpenAd && [self wasLoadTimeLessThanNHoursAgo:kTimeoutInterval];
}
কোল্ড স্টার্ট এবং লোডিং স্ক্রিন
ডকুমেন্টেশন অনুযায়ী, আপনি কেবল তখনই অ্যাপ খোলার বিজ্ঞাপন দেখান, যখন ব্যবহারকারীরা আপনার অ্যাপটিকে মেমরিতে সাসপেন্ড থাকা অবস্থায় ফোরগ্রাউন্ডে নিয়ে আসে। "কোল্ড স্টার্ট" ঘটে যখন আপনার অ্যাপটি চালু করা হয়, কিন্তু সেটি আগে মেমরিতে সাসপেন্ড করা ছিল না।
কোল্ড স্টার্টের একটি উদাহরণ হলো যখন কোনো ব্যবহারকারী প্রথমবারের মতো আপনার অ্যাপটি খোলেন। কোল্ড স্টার্টের ক্ষেত্রে, আগে থেকে লোড করা কোনো অ্যাপ ওপেন অ্যাড থাকে না যা সাথে সাথেই দেখানোর জন্য প্রস্তুত থাকে। আপনি যখন কোনো অ্যাডের জন্য অনুরোধ করেন এবং তার উত্তর পান, এই দুইয়ের মধ্যবর্তী বিলম্ব এমন একটি পরিস্থিতি তৈরি করতে পারে যেখানে ব্যবহারকারীরা অপ্রাসঙ্গিক কোনো অ্যাড দেখে অবাক হওয়ার আগে অল্প সময়ের জন্য আপনার অ্যাপটি ব্যবহার করতে পারেন। এটি পরিহার করা উচিত, কারণ এটি একটি খারাপ ব্যবহারকারী অভিজ্ঞতা।
কোল্ড স্টার্টের সময় অ্যাপ ওপেন অ্যাড ব্যবহার করার সবচেয়ে ভালো উপায় হলো, আপনার গেম বা অ্যাপের অ্যাসেটগুলো লোড করার জন্য একটি লোডিং স্ক্রিন ব্যবহার করা এবং শুধুমাত্র লোডিং স্ক্রিন থেকেই বিজ্ঞাপনটি দেখানো। যদি আপনার অ্যাপ লোড হওয়া সম্পন্ন করে এবং ব্যবহারকারীকে অ্যাপের মূল কন্টেন্টে পাঠিয়ে দেয়, তাহলে বিজ্ঞাপনটি দেখাবেন না।
সর্বোত্তম অনুশীলন
আপনার অ্যাপের লোডিং স্ক্রিন থেকে অর্থ উপার্জনের জন্য গুগল অ্যাপ ওপেন অ্যাড তৈরি করেছে, কিন্তু কিছু সেরা অনুশীলন মনে রাখা জরুরি, যাতে আপনার ব্যবহারকারীরা অ্যাপটি ব্যবহার করে আনন্দ পান। নিশ্চিত করুন:
- আপনার ব্যবহারকারীরা অ্যাপটি কয়েকবার ব্যবহার করার পরেই কেবল প্রথমবার খোলার বিজ্ঞাপনটি দেখান।
- এমন সময়ে অ্যাপ খোলার বিজ্ঞাপন দেখান, যখন আপনার ব্যবহারকারীরা সাধারণত অ্যাপটি লোড হওয়ার জন্য অপেক্ষা করে থাকেন।
- অ্যাপ খোলার বিজ্ঞাপনের নিচে যদি কোনো লোডিং স্ক্রিন থাকে এবং বিজ্ঞাপনটি বন্ধ হওয়ার আগেই আপনার লোডিং স্ক্রিনটি লোড হয়ে যায়, তাহলে আপনি
adDidDismissFullScreenContentমেথড ব্যবহার করে লোডিং স্ক্রিনটি বন্ধ করে দিতে পারেন।
গিটহাবে সম্পূর্ণ উদাহরণ
পরবর্তী পদক্ষেপ
ব্যবহারকারীর গোপনীয়তা সম্পর্কে আরও জানুন।