native 自动刷新。

This commit is contained in:
luojian 2025-09-15 23:12:13 +08:00
parent bf34a8c658
commit f19681ea71
1 changed files with 83 additions and 16 deletions

View File

@ -2,11 +2,24 @@ using System;
using System.Collections; using System.Collections;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using EFSDK;
using GoogleMobileAds.Api; using GoogleMobileAds.Api;
using UnityEngine; using UnityEngine;
namespace WZ namespace WZ
{ {
class ShowNativePosition
{
public NativeOverlayAd NativeOverlayAd;
public NativeAdPosition Position;
public ShowNativePosition(NativeOverlayAd nativeOverlayAd, NativeAdPosition position)
{
NativeOverlayAd = nativeOverlayAd;
Position = position;
}
}
public class AdmobNativeAdManager public class AdmobNativeAdManager
{ {
private Dictionary<string, NativeOverlayAd> _nativeAds = new Dictionary<string, NativeOverlayAd>(); private Dictionary<string, NativeOverlayAd> _nativeAds = new Dictionary<string, NativeOverlayAd>();
@ -14,7 +27,7 @@ namespace WZ
private Dictionary<string, int> _retryCounters = new Dictionary<string, int>(); private Dictionary<string, int> _retryCounters = new Dictionary<string, int>();
private Dictionary<string, float> _adStartLoadTimes = new Dictionary<string, float>(); private Dictionary<string, float> _adStartLoadTimes = new Dictionary<string, float>();
private Dictionary<string, NativeOverlayAd> showingNativeAds = new Dictionary<string, NativeOverlayAd>(); private Dictionary<string, ShowNativePosition> showingNativeAds = new();
public void InitializeAdUnits(List<string> adUnitIds) public void InitializeAdUnits(List<string> adUnitIds)
{ {
@ -37,9 +50,9 @@ namespace WZ
_adRevenueCache[adUnitId] = 0; _adRevenueCache[adUnitId] = 0;
} }
public void LoadAd(string adUnitId) public void LoadAd(string adUnitId, bool timingRefresh = false)
{ {
LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} load start"); LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} load start , timingRefresh {timingRefresh}");
//判断在线参数是否包含这个id //判断在线参数是否包含这个id
if (!AdmobAdsManager.Instance.FindAdsID(AdsType.Native, adUnitId)) if (!AdmobAdsManager.Instance.FindAdsID(AdsType.Native, adUnitId))
{ {
@ -49,7 +62,7 @@ namespace WZ
NativeOverlayAd.Load(adUnitId, new AdRequest(), new NativeAdOptions(), (NativeOverlayAd ad, LoadAdError error) => NativeOverlayAd.Load(adUnitId, new AdRequest(), new NativeAdOptions(), (NativeOverlayAd ad, LoadAdError error) =>
{ {
_adStartLoadTimes[adUnitId] = Time.realtimeSinceStartup; _adStartLoadTimes[adUnitId] = Time.realtimeSinceStartup;
LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} load end. {ad} error {error}"); LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} load end, timingRefresh {timingRefresh}. {ad} error {error}");
if (error != null || ad == null) if (error != null || ad == null)
{ {
if (!_retryCounters.TryAdd(adUnitId, 0)) if (!_retryCounters.TryAdd(adUnitId, 0))
@ -78,8 +91,8 @@ namespace WZ
reason); 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, timingRefresh); });
LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} ad failed to load an ad with error : " + error + " \n retryDelay :" + retryDelay); LoggerUtils.Error($"[Admob] Native Ad unit {adUnitId}, timingRefresh {timingRefresh} ad failed to load an ad with error : " + error + " \n retryDelay :" + retryDelay);
return; return;
} }
@ -95,10 +108,13 @@ namespace WZ
Time.realtimeSinceStartup - _adStartLoadTimes[adUnitId]); Time.realtimeSinceStartup - _adStartLoadTimes[adUnitId]);
_retryCounters[adUnitId] = 0; _retryCounters[adUnitId] = 0;
// 临时缓存上一次的native ad以便于刷新的时候显示了新的隐藏老的。
var tempAd = _nativeAds.GetValueOrDefault(adUnitId, null);
var nativeEcpm = AdmobUtils.GetNativeEcpm(ad); var nativeEcpm = AdmobUtils.GetNativeEcpm(ad);
_nativeAds[adUnitId] = ad; _nativeAds[adUnitId] = ad;
_adRevenueCache[adUnitId] = nativeEcpm; _adRevenueCache[adUnitId] = nativeEcpm;
LoggerUtils.Debug($"Admob Native ad loaded with nativeEcpm = {nativeEcpm} response : " + ad.GetResponseInfo().ToString()); LoggerUtils.Debug($"Admob Native ad loaded with, timingRefresh {timingRefresh} nativeEcpm = {nativeEcpm} response : " + ad.GetResponseInfo().ToString());
AdsKeyEvents.Instance.LogAdFPUEvents(AdsType.Native); AdsKeyEvents.Instance.LogAdFPUEvents(AdsType.Native);
ad.OnAdPaid += (AdValue adValue) => ad.OnAdPaid += (AdValue adValue) =>
@ -135,6 +151,19 @@ namespace WZ
AdmobUtils.GetNativeEcpm(ad)); AdmobUtils.GetNativeEcpm(ad));
LoggerUtils.Debug("[Admob] Native ad full screen content closed."); LoggerUtils.Debug("[Admob] Native ad full screen content closed.");
}; };
if (timingRefresh && tempAd != null)
{
if (showingNativeAds.TryGetValue(adUnitId, out var showing))
{
LoggerUtils.Warning("[Admob] Native ad timing refresh , show ad");
ShowAd(showing.Position, adUnitId, tempAd);
}
else
{
LoggerUtils.Warning($"[Admob] Native ad timing refresh , show fail , showing native ads not ad unit id , {adUnitId}");
}
}
}); });
} }
@ -152,7 +181,7 @@ namespace WZ
} }
// 显示特定广告位的广告 // 显示特定广告位的广告
public void ShowAd(NativeAdPosition position, string adUnitId) public void ShowAd(NativeAdPosition position, string adUnitId, NativeOverlayAd lastAd = null)
{ {
if (!AdmobAdsManager.Instance.FindAdsID(AdsType.Native, adUnitId)) if (!AdmobAdsManager.Instance.FindAdsID(AdsType.Native, adUnitId))
{ {
@ -182,11 +211,50 @@ namespace WZ
// and anchored to the bottom of the screne. // and anchored to the bottom of the screne.
ad.RenderTemplate(style, new AdSize(position.Width, position.Height), position.X, position.Y); ad.RenderTemplate(style, new AdSize(position.Width, position.Height), position.X, position.Y);
showingNativeAds[adUnitId] = ad; showingNativeAds[adUnitId] = new ShowNativePosition(ad, position);
ad.Show(); ad.Show();
lastAd?.Hide();
TimingRefresh(adUnitId);
} }
} }
private void TimingRefresh(string adUnitId)
{
var nativeReflashGap = int.Parse(FireBaseRemoteConfigManager.Instance.GetRemoteConfigString("Native_Reflash_Gap", "0"));
if (nativeReflashGap <= 0)
{
LoggerUtils.Debug($"[Admob] Native ad ({adUnitId}) timing refresh failed. nativeReflashGap = 0");
return;
}
if (adUnitId == StaticValue.AdmobFullNativeId)
{
LoggerUtils.Debug($"[Admob] Native ad ({adUnitId}) timing refresh finished. ad unit id is full native id.");
return;
}
if (!showingNativeAds.ContainsKey(adUnitId))
{
LoggerUtils.Debug($"[Admob] Native ad ({adUnitId}) timing refresh finished. ad unit is not show.");
return;
}
WLoom.QueueOnMainThread(o =>
{
var refreshAdUnitId = (string)o;
LoggerUtils.Debug($"[Admob] Native ad ({adUnitId}) timing refresh load start refreshAdUnitId : {refreshAdUnitId}.");
if (showingNativeAds.ContainsKey(refreshAdUnitId))
{
LoadAd(refreshAdUnitId, true);
}
else
{
LoggerUtils.Warning($"[Admob] Native ad ({adUnitId}) timing refresh finished. ad unit is not show. refreshAdUnitId : {refreshAdUnitId}.");
}
}, adUnitId, nativeReflashGap);
}
private float GetLoadedTime(string adUnitId) private float GetLoadedTime(string adUnitId)
{ {
@ -272,23 +340,22 @@ namespace WZ
// yield return new WaitForSeconds(0.2f); // yield return new WaitForSeconds(0.2f);
if (adUnitId == null || string.IsNullOrEmpty(adUnitId)) if (adUnitId == null || string.IsNullOrEmpty(adUnitId))
{ {
foreach (var showingNativeAd in showingNativeAds) foreach (var key in showingNativeAds.Keys.ToList())
{ {
LoggerUtils.Debug($"[Admob] Native ad removing NativeAd {adUnitId}"); LoggerUtils.Debug($"[Admob] Native ad removing NativeAd {adUnitId}");
showingNativeAd.Value.Hide(); showingNativeAds[key].NativeOverlayAd.Hide();
// 从字典中删除元素
LoadAd(showingNativeAd.Key); showingNativeAds.Remove(key);
LoadAd(key);
} }
showingNativeAds.Clear();
yield break; yield break;
} }
if (showingNativeAds.TryGetValue(adUnitId, out var tempAd)) if (showingNativeAds.TryGetValue(adUnitId, out var tempAd))
{ {
LoggerUtils.Debug($"[Admob] Native ad removing NativeAd {adUnitId}"); LoggerUtils.Debug($"[Admob] Native ad removing NativeAd {adUnitId}");
tempAd.Hide(); tempAd.NativeOverlayAd.Hide();
showingNativeAds.Remove(adUnitId); showingNativeAds.Remove(adUnitId);
LoadAd(adUnitId); LoadAd(adUnitId);
} }