修复上报的空指针

This commit is contained in:
luojian 2025-09-03 16:56:30 +08:00
parent 1a695a590e
commit d6bafaca55
2 changed files with 30 additions and 9 deletions

View File

@ -54,8 +54,11 @@ namespace WZ
}; };
bannerAds.OnBannerAdLoadFailed += ((msg) => bannerAds.OnBannerAdLoadFailed += ((msg) =>
{
if (!_retryCounters.TryAdd(adUnitId, 0))
{ {
_retryCounters[adUnitId]++; _retryCounters[adUnitId]++;
}
double retryDelay = Math.Pow(2, Math.Min(6, _retryCounters[adUnitId])); double retryDelay = Math.Pow(2, Math.Min(6, _retryCounters[adUnitId]));
LoggerUtils.Debug($"[Admob] banner -[Load]: {adUnitId} failed, error message = {msg}"); LoggerUtils.Debug($"[Admob] banner -[Load]: {adUnitId} failed, error message = {msg}");

View File

@ -49,17 +49,32 @@ namespace WZ
{ {
_retryCounters[adUnitId]++; _retryCounters[adUnitId]++;
} }
var adSource = "";
if (ad != null)
{
adSource = ad.GetResponseInfo().GetLoadedAdapterResponseInfo().AdSourceName;
}
var reason = "";
if (error != null)
{
reason = error.GetMessage();
}
AdsActionEvents.TrackAdFailToLoad(PlatformType.Admob, AdsActionEvents.TrackAdFailToLoad(PlatformType.Admob,
ad.GetResponseInfo().GetLoadedAdapterResponseInfo().AdSourceName, adSource,
adUnitId, adUnitId,
AdsType.Native, AdsType.Native,
Time.realtimeSinceStartup - _adStartLoadTimes[adUnitId],error.GetMessage()); Time.realtimeSinceStartup - _adStartLoadTimes[adUnitId], reason);
var retryDelay = Math.Pow(2, Math.Min(6, _retryCounters[adUnitId])); var retryDelay = Math.Pow(2, Math.Min(6, _retryCounters[adUnitId]));
TimerUtils.Instance.DelayExecute((float)retryDelay, () => { LoadAd(adUnitId); }); TimerUtils.Instance.DelayExecute((float)retryDelay, () => { LoadAd(adUnitId); });
LoggerUtils.Debug("[Admob] Native ad failed to load an ad with error : " + error + " \n retryDelay :" + retryDelay); LoggerUtils.Debug("[Admob] Native ad failed to load an ad with error : " + error + " \n retryDelay :" + retryDelay);
return; return;
} }
AdsActionEvents.TrackAdLoaded(PlatformType.Admob, AdsActionEvents.TrackAdLoaded(PlatformType.Admob,
ad.GetResponseInfo().GetLoadedAdapterResponseInfo().AdSourceName, ad.GetResponseInfo().GetLoadedAdapterResponseInfo().AdSourceName,
adUnitId, adUnitId,
@ -97,14 +112,16 @@ namespace WZ
ad.OnAdFullScreenContentOpened += () => { LoggerUtils.Debug("[Admob] Native ad full screen content opened."); }; ad.OnAdFullScreenContentOpened += () => { LoggerUtils.Debug("[Admob] Native ad full screen content opened."); };
ad.OnAdFullScreenContentClosed += () => { ad.OnAdFullScreenContentClosed += () =>
{
AdsActionEvents.TrackAdClicked(PlatformType.Admob, AdsActionEvents.TrackAdClicked(PlatformType.Admob,
ad.GetResponseInfo().GetLoadedAdapterResponseInfo().AdSourceName, ad.GetResponseInfo().GetLoadedAdapterResponseInfo().AdSourceName,
adUnitId, adUnitId,
AdsType.Native, AdsType.Native,
"", "",
AdmobUtils.GetNativeEcpm(ad)); AdmobUtils.GetNativeEcpm(ad));
LoggerUtils.Debug("[Admob] Native ad full screen content closed."); }; LoggerUtils.Debug("[Admob] Native ad full screen content closed.");
};
}); });
} }
@ -156,6 +173,7 @@ namespace WZ
{ {
return _adStartLoadTimes.TryGetValue(adUnitId, out var time) ? time : 0; return _adStartLoadTimes.TryGetValue(adUnitId, out var time) ? time : 0;
} }
// 检查特定广告位是否可用 // 检查特定广告位是否可用
public bool IsAdAvailable(string adUnitId) public bool IsAdAvailable(string adUnitId)
{ {