我有一个使用 xib 定义的 AdBannerView 的应用程序。如果该应用程序在 iPhone(4 或 5)上运行,一切都会按预期运行,显示广告,隐藏/显示横幅等。
但是,如果应用程序在 iPad 上运行,它会在反复接收广告失败后崩溃。检查调用堆栈显示重复调用 bannerView:didFailToReceiveAdWithError:
在 iPad 上运行时观察分配显示内存持续增长直到崩溃。
弄乱网络连接似乎并没有改变它可以在 iPhone 上运行但不能在 iPad 上运行的事实。
我读了this所以问题是,它不是在 xib 中使用 AdBannerView,而是动态创建它,然后在广告加载失败时适本地释放它。
编辑:
我将项目文件中的设备设置从 iPhone 更改为通用。该应用程序现在不会崩溃,但当然所有 View 现在都“困惑”了。因此,一种修复方法是在整个应用中实现 iPad 习惯用法。
我的问题是 -
发生了什么事?不完全是!我很困惑为什么设备之间会有不同的行为。
我应该考虑以编程方式创建 AdBannerView 吗? 那种失败主义的感觉。
如何解决此问题?
这是代码
#pragma mark ADBannerViewDelegate
- (void)bannerViewDidLoadAd:(ADBannerView *)banner
{
[self showBanner];
}
- (void)bannerView:(ADBannerView *)banner didFailToReceiveAdWithError:(NSError *)error
{
[self hideBanner];
}
- (void)bannerViewActionDidFinish:(ADBannerView *)banner
{
[self hideBanner];
}
#pragma mark ADBanner helpers
- (void)hideBanner
{
CGRect hiddenFrame = self.bannerDisplayFrame;
hiddenFrame.origin.y = self.view.frame.size.height;
[UIView animateWithDuration:0.3f
animations:^{
[self.adBannerView setFrame:hiddenFrame];
}
completion:^(BOOL finished)
{
if (finished)
{
[self.adBannerView setAlpha:0.0f];
}
}];
}
- (void)showBanner
{
[self.adBannerView setAlpha:1.0f];
[UIView animateWithDuration:0.3f
animations:^{
[self.adBannerView setFrame:self.bannerDisplayFrame];
}
completion:^(BOOL finished)
{
if (finished)
{
[NSTimer scheduledTimerWithTimeInterval:60.0f target:self selector:@selector(hideBanner) userInfo:nil repeats:NO];
}
}];
}
最佳答案
看起来您每次都在创建新的 iAD 横幅 View ,建议的方法是在整个应用程序中使用共享的 View 。这可能是您的应用程序内存持续增长的原因,如果您多次请求广告,您肯定会收到苹果服务器的警告。有关详细信息,请查看 Apple 文档中的此处 iAD Best Practices
这就是我实现共享 adbannerview 的方式,它可能会有所帮助。
AppDelegate.h
@property (nonatomic, strong) ADBannerView *adBanner;
AppDelegate.m
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
...
adBanner = [[ADBannerView alloc] initWithFrame:CGRectZero];
adBanner.delegate = self;
adBanner.backgroundColor = [UIColor clearColor];
adBanner.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight | UIViewAutoresizingFlexibleTopMargin;
...
}
prefix.pch 或更好的头文件包含在 prefix.pch 中
#define SharedAdBannerView ((AppDelegate *)[[UIApplication sharedApplication] delegate]).adBanner
我已经实现了一个 uiviewcontroller
类别来处理 iAD
@implementation UIViewController (SupportIAD)
-(void)bannerViewDidLoadAd:(ADBannerView *)banner
{
SharedAdBannerView.hidden = FALSE;
}
-(void) bannerView:(ADBannerView *)banner didFailToReceiveAdWithError:(NSError *)error
{
SharedAdBannerView.hidden = TRUE;
}
//This method adds shared adbannerview to the current view and sets its location to bottom of screen
//Should work on all devices
-(void) addADBannerViewToBottom
{
SharedAdBannerView.delegate = self;
//Position banner just below the screen
SharedAdBannerView.frame = CGRectMake(0, self.view.bounds.size.height, 0, 0);
//Height will be automatically set, raise the view by its own height
SharedAdBannerView.frame = CGRectOffset(SharedAdBannerView.frame, 0, -SharedAdBannerView.frame.size.height);
[self.view addSubview:SharedAdBannerView];
}
-(void) removeADBannerView
{
SharedAdBannerView.delegate = nil;
[SharedAdBannerView removeFromSuperview];
}
@end
现在在每个要显示 iAD 的 View Controller 中,导入类别并在 viewDidLoad 中:
- (void)viewDidLoad
{
...
[self removeADBannerView];
[self addADBannerViewToBottom];
...
}
关于ios - 在大量调用 bannerView :didFailToReceiveAdWithError: 后,在 iPad 上使用 iAds 会崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16471240/