no message
|  | @ -0,0 +1,3 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: fa22f34439f14c8cbaa5fae4c4dc402b | ||||||
|  | timeCreated: 1742203865 | ||||||
|  | @ -0,0 +1,3 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: f322db129aac4ea1aa9919e8c8f92a08 | ||||||
|  | timeCreated: 1756693458 | ||||||
|  | @ -0,0 +1,3 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 8af1d23b4bce430aa8bfb3e1b6b3b291 | ||||||
|  | timeCreated: 1756693481 | ||||||
| After Width: | Height: | Size: 280 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 22d4b822110d1bd43932b2b737f61dce | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 9.4 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 63a7e60d370bb1c48a1138e45315d8aa | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 9.4 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 9cb4efb8034485741852541144c5a7a0 | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 12 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 9934c44d94c1030438702e646cc1a5b1 | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 11 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 9cfb6b46fea6c7845999842064fef0dd | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 21 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: a0fa3d13d2c47b64c8a10c49839f888c | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 22 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: 10def9eb660635b468ed7fc2277a4e6f | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
| After Width: | Height: | Size: 89 KiB | 
|  | @ -0,0 +1,7 @@ | ||||||
|  | fileFormatVersion: 2 | ||||||
|  | guid: f2d7efc9e85a47e98bae42a19e1d52a3 | ||||||
|  | DefaultImporter: | ||||||
|  |   externalObjects: {} | ||||||
|  |   userData:  | ||||||
|  |   assetBundleName:  | ||||||
|  |   assetBundleVariant:  | ||||||
|  | @ -1,5 +1,7 @@ | ||||||
| using System; | using System; | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
|  | using System.Security.Cryptography; | ||||||
|  | using System.Text; | ||||||
| using UnityEngine; | using UnityEngine; | ||||||
| 
 | 
 | ||||||
| namespace EFSDK | namespace EFSDK | ||||||
|  | @ -10,8 +12,9 @@ namespace EFSDK | ||||||
|     public class EFSdk |     public class EFSdk | ||||||
|     { |     { | ||||||
|         private static EFSdk _mEfSdk; |         private static EFSdk _mEfSdk; | ||||||
|         private static string mappingInfo = @"{""items"":[{""key"":""_sdk_float_balloon.png"",""value"":""aoa38ay.png""}]}"; |  | ||||||
| 
 | 
 | ||||||
|  |         // 保持变量名不变 | ||||||
|  |         private static string mappingInfo = ""; | ||||||
| 
 | 
 | ||||||
|         public static EFSdk get() |         public static EFSdk get() | ||||||
|         { |         { | ||||||
|  | @ -28,18 +31,81 @@ namespace EFSDK | ||||||
| 
 | 
 | ||||||
|         public EFSdk() |         public EFSdk() | ||||||
|         { |         { | ||||||
|  |             Debug.Log($"GetNewSDKClass():{GetNewSDKClass()}"); | ||||||
|  |              | ||||||
|             // java interface class |             // java interface class | ||||||
|             using (AndroidJavaClass jc = new AndroidJavaClass("com.earn.push._SDK")) |             using (AndroidJavaClass jc = new AndroidJavaClass(GetNewSDKClass())) | ||||||
|             { |             { | ||||||
|                 jo = jc.GetStatic<AndroidJavaObject>("INSTANCE"); |                 jo = jc.GetStatic<AndroidJavaObject>("INSTANCE"); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         private static string oriSDKPName = "com.earn.push"; | ||||||
|  |         private static string oriSDK = "_SDK"; | ||||||
|  | 
 | ||||||
|  |         private static string GetNewSDKClass() | ||||||
|  |         { | ||||||
|  |             return GetSDKPackage()  + GenerateAndroidName(oriSDK); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private static string GetSDKPackage() | ||||||
|  |         { | ||||||
|  |             string[] parts = oriSDKPName.Split('.'); | ||||||
|  |             string[] parts2 = new string[parts.Length]; | ||||||
|  |             for (int i = 0; i < parts.Length; i++) | ||||||
|  |             { | ||||||
|  |                 parts2[i] = GenerateAndroidName(parts[i]); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             string newPName = ""; | ||||||
|  |             for (int i = 0; i < parts2.Length; i++) | ||||||
|  |             { | ||||||
|  |                 newPName+=parts2[i]+"."; | ||||||
|  |             } | ||||||
|  |             return newPName; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private static string GenerateAndroidName(string oriString) | ||||||
|  |         { | ||||||
|  |             string md5Str = GetFirstEightWithUnderscore(GetMD5Hash(Application.identifier + oriString)); | ||||||
|  |             return md5Str; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public static string GetMD5Hash(string input) | ||||||
|  |         { | ||||||
|  |             using (var md5 = MD5.Create()) | ||||||
|  |             { | ||||||
|  |                 var inputBytes = Encoding.ASCII.GetBytes(input); | ||||||
|  |                 var hashBytes = md5.ComputeHash(inputBytes); | ||||||
|  | 
 | ||||||
|  |                 var builder = new StringBuilder(); | ||||||
|  |                 foreach (var t in hashBytes) | ||||||
|  |                 { | ||||||
|  |                     builder.Append(t.ToString("x2")); // Convert byte to hexadecimal string | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 return builder.ToString(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         static string GetFirstEightWithUnderscore(string str) | ||||||
|  |         { | ||||||
|  |             if (string.IsNullOrEmpty(str)) return str; | ||||||
|  |             string sub = str.Length <= 8 ? str : str.Substring(0, 8); | ||||||
|  |             if (char.IsDigit(sub[0])) | ||||||
|  |             { | ||||||
|  |                 sub = "a" + sub; | ||||||
|  |             } | ||||||
|  |             return sub; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         private T SDKCall<T>(string _method, params object[] _param) |         private T SDKCall<T>(string _method, params object[] _param) | ||||||
|         { |         { | ||||||
|             try |             try | ||||||
|             { |             { | ||||||
|                 return jo.Call<T>(_method, _param); |                 string newMethod = GenerateAndroidName(_method); | ||||||
|  |                 Debug.Log($"SDKCall<T> newMethod:{newMethod}"); | ||||||
|  |                 return jo.Call<T>(newMethod, _param); | ||||||
|             } |             } | ||||||
|             catch (Exception e) |             catch (Exception e) | ||||||
|             { |             { | ||||||
|  | @ -53,7 +119,9 @@ namespace EFSDK | ||||||
|         { |         { | ||||||
|             try |             try | ||||||
|             { |             { | ||||||
|                 jo.Call(_method, _param); |                 string newMethod = GenerateAndroidName(_method); | ||||||
|  |                 Debug.Log($"SDKCall newMethod:{newMethod}"); | ||||||
|  |                 jo.Call(newMethod, _param); | ||||||
|             } |             } | ||||||
|             catch (Exception e) |             catch (Exception e) | ||||||
|             { |             { | ||||||
|  | @ -63,11 +131,8 @@ namespace EFSDK | ||||||
| 
 | 
 | ||||||
|         public enum ActionType |         public enum ActionType | ||||||
|         { |         { | ||||||
|             COIN_CLICK, //点击金币 |             SDK_INIT_Succ, //GAM页面加载成功 | ||||||
|             BALLOON_CLICK, //点击气球 |             H5_Load_Succ, //H5页面加载成功 | ||||||
|             COIN_SHOW, //金币展示出来了 |  | ||||||
|             BOX_SHOW, //气球/宝箱展示出来了 |  | ||||||
|             GAM_LOAD_SUCC, //GAM页面加载成功 |  | ||||||
|             ON_RESUME, //游戏可见时回调, |             ON_RESUME, //游戏可见时回调, | ||||||
|             // CAN_GOBACK, //游戏可见时回调, |             // CAN_GOBACK, //游戏可见时回调, | ||||||
|         } |         } | ||||||
|  | @ -111,8 +176,8 @@ namespace EFSDK | ||||||
| 
 | 
 | ||||||
|         private void SDKInit() |         private void SDKInit() | ||||||
|         { |         { | ||||||
|             // SDKCall("init"); |             SDKCall("initSDK", mappingInfo); | ||||||
|             ActionCallback?.Invoke(ActionType.GAM_LOAD_SUCC, string.Empty); |             ActionCallback?.Invoke(ActionType.SDK_INIT_Succ, string.Empty); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|  | @ -170,77 +235,6 @@ namespace EFSDK | ||||||
|             SDKCall("goHome"); |             SDKCall("goHome"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |  | ||||||
|         /// 是否手动控制漂浮道具显示/隐藏 |  | ||||||
|         /// SDK内默认当H5页面加载完成后自动显示漂浮道具 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <param name="autoShow">true: 自动显示/隐藏道具    false: 游戏主动控制道具显示/隐藏</param> |  | ||||||
|         /// <returns></returns> |  | ||||||
|         public void AutoShowFloat(bool autoShow) |  | ||||||
|         { |  | ||||||
|             SDKCall("autoShowFloat", autoShow); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |  | ||||||
|         /// 飘金币 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <param name="id"></param> |  | ||||||
|         /// <returns></returns> |  | ||||||
|         public void ShowFloatCoin(int id) |  | ||||||
|         { |  | ||||||
|             SDKCall("showFloatCoin", id); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |  | ||||||
|         /// 飘金币 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <param name="id"></param> |  | ||||||
|         /// <param name="res">悬浮金币按钮的图片资源,传字符串 0 或 1    0:金币图  1:红点宝箱图 </param> |  | ||||||
|         /// <returns></returns> |  | ||||||
|         public void ShowFloatCoin(int id, String res) |  | ||||||
|         { |  | ||||||
|             SDKCall("showFloatCoin", id, res); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |  | ||||||
|         /// 设置悬浮金币按钮的图片资源 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <param name="res">传字符串 0 或 1    0:金币图  1:红点宝箱图</param> |  | ||||||
|         public void SetFloatCoinRes(String res) |  | ||||||
|         { |  | ||||||
|             SDKCall("setFloatCoinRes", res); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |  | ||||||
|         /// 隐藏金币 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <returns></returns> |  | ||||||
|         public void HideFloatCoin() |  | ||||||
|         { |  | ||||||
|             SDKCall("hideFloatCoin"); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |  | ||||||
|         /// 飘气球 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <param name="startId"></param> |  | ||||||
|         /// <param name="endId"></param> |  | ||||||
|         /// <param name="fly_first_time"></param> |  | ||||||
|         /// <param name="fly_gap_time"></param> |  | ||||||
|         /// <returns></returns> |  | ||||||
|         public void ShowBalloon(int startId, int endId, int fly_first_time, int fly_gap_time) |  | ||||||
|         { |  | ||||||
|             SDKCall("showBalloon", startId, endId, fly_first_time, fly_gap_time); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |  | ||||||
|         /// 隐藏气球 |  | ||||||
|         /// </summary> |  | ||||||
|         /// <returns></returns> |  | ||||||
|         public void HideBalloon() |  | ||||||
|         { |  | ||||||
|             SDKCall("hideBalloon"); |  | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         ///  |         ///  | ||||||
|  | @ -340,14 +334,6 @@ namespace EFSDK | ||||||
|             SDKCall("setGameName", gameName); |             SDKCall("setGameName", gameName); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // /// <summary> |  | ||||||
|         // /// 设置推送 消息通知 的文案 |  | ||||||
|         // /// </summary> |  | ||||||
|         // /// <param name="message"></param> |  | ||||||
|         // public void SetCommPushMessage(string message) |  | ||||||
|         // { |  | ||||||
|         //     SDKCall("setCommPushMessage", message); |  | ||||||
|         // } |  | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// 设置当前游戏语言是否是 西班牙语 |         /// 设置当前游戏语言是否是 西班牙语 | ||||||
|  |  | ||||||
|  | @ -6,11 +6,7 @@ namespace EFSDK | ||||||
| 
 | 
 | ||||||
|     public class EFSdkAndroid : MonoBehaviour |     public class EFSdkAndroid : MonoBehaviour | ||||||
|     { |     { | ||||||
|         private string COIN_CLICK = "coin_click"; |         private string H5_Load_Succ = "Gam_Load_Succ"; | ||||||
|         private string BALLOON_CLICK = "balloon_click"; |  | ||||||
|         private string Coin_Show = "Coin_Show"; |  | ||||||
|         private string Box_Show = "Box_Show"; |  | ||||||
|         private string Gam_Load_Succ = "Gam_Load_Succ"; |  | ||||||
|         private string On_Resume = "onResume"; |         private string On_Resume = "onResume"; | ||||||
|         private string Can_Goback = "canGoback"; |         private string Can_Goback = "canGoback"; | ||||||
| 
 | 
 | ||||||
|  | @ -28,34 +24,11 @@ namespace EFSDK | ||||||
|                     EFSdk.get().mCanGobackAction?.Invoke(bool.Parse(message.Split('#')[1])); |                     EFSdk.get().mCanGobackAction?.Invoke(bool.Parse(message.Split('#')[1])); | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 if (BALLOON_CLICK.Equals(message)) |                 if (message.Contains(H5_Load_Succ)) | ||||||
|                 { |  | ||||||
|                     //点击气球 |  | ||||||
|                     EFSdk.get().ActionCallback?.Invoke(EFSdk.ActionType.BALLOON_CLICK, message); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (Coin_Show.Equals(message)) |  | ||||||
|                 { |  | ||||||
|                     //金币展示出来了 |  | ||||||
|                     EFSdk.get().ActionCallback?.Invoke(EFSdk.ActionType.COIN_SHOW, message); |  | ||||||
|                 } |  | ||||||
|                 if (COIN_CLICK.Equals(message)) |  | ||||||
|                 { |  | ||||||
|                     //金币点击 |  | ||||||
|                     EFSdk.get().ActionCallback?.Invoke(EFSdk.ActionType.COIN_CLICK, message); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (Box_Show.Equals(message)) |  | ||||||
|                 { |  | ||||||
|                     //宝箱展示出来了 |  | ||||||
|                     EFSdk.get().ActionCallback?.Invoke(EFSdk.ActionType.BOX_SHOW, message); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (message.Contains(Gam_Load_Succ)) |  | ||||||
|                 { |                 { | ||||||
|                     //GAM页面加载成功 Gam_Load_Succ@id |                     //GAM页面加载成功 Gam_Load_Succ@id | ||||||
|                     string[] parts = message.Split('@'); |                     string[] parts = message.Split('@'); | ||||||
|                     EFSdk.get().ActionCallback?.Invoke(EFSdk.ActionType.GAM_LOAD_SUCC, parts[1]); |                     EFSdk.get().ActionCallback?.Invoke(EFSdk.ActionType.H5_Load_Succ, parts[1]); | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 if (message.StartsWith("reqNotifyPermission#")) |                 if (message.StartsWith("reqNotifyPermission#")) | ||||||
|  |  | ||||||
|  | @ -2,13 +2,15 @@ | ||||||
| using UnityEditor; | using UnityEditor; | ||||||
| using System.IO; | using System.IO; | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
|  | using System.Security.Cryptography; | ||||||
|  | using System.Text; | ||||||
| using IOCompression = System.IO.Compression; | using IOCompression = System.IO.Compression; | ||||||
| 
 | 
 | ||||||
| namespace EFSDK | namespace EFSDK | ||||||
| { | { | ||||||
|     public class AndroidResAarBuilder |     public class AndroidResAarBuilder | ||||||
|     { |     { | ||||||
|         private static readonly string ResDir = "Assets/StreamingAssets/Android/res"; |         private static readonly string ResDir = "Assets/EFSDK/Android"; | ||||||
|         private static readonly string OutputDir = "Assets/Plugins/Android"; |         private static readonly string OutputDir = "Assets/Plugins/Android"; | ||||||
|         private static readonly string TempDir = "Temp/AndroidResAar"; |         private static readonly string TempDir = "Temp/AndroidResAar"; | ||||||
|         private static readonly string EFSdk_FILE = "Assets/EFSDK/EFSdk.cs"; |         private static readonly string EFSdk_FILE = "Assets/EFSDK/EFSdk.cs"; | ||||||
|  | @ -30,10 +32,10 @@ namespace EFSDK | ||||||
|             CopyAndRenameFiles(ResDir, TempDir, out Dictionary<string, string> mapping); |             CopyAndRenameFiles(ResDir, TempDir, out Dictionary<string, string> mapping); | ||||||
|             string manifestPath = Path.Combine(TempDir, "AndroidManifest.xml"); |             string manifestPath = Path.Combine(TempDir, "AndroidManifest.xml"); | ||||||
|             File.WriteAllText(manifestPath, |             File.WriteAllText(manifestPath, | ||||||
|                 @"<manifest xmlns:android=""http://schemas.android.com/apk/res/android""
 |                 @$"<manifest xmlns:android=""http://schemas.android.com/apk/res/android""
 | ||||||
|                             package=""com.unity.reswrapper""> |     package=""com.{GetFirstEightWithUnderscore(GetMD5Hash(Application.identifier + "res"))}""> | ||||||
|     <application/> |     <application/> | ||||||
|                         </manifest>");
 | </manifest>");
 | ||||||
| 
 | 
 | ||||||
|             // 打包 AAR |             // 打包 AAR | ||||||
|             string aarPath = Path.Combine(OutputDir, "efsdk_res.aar"); |             string aarPath = Path.Combine(OutputDir, "efsdk_res.aar"); | ||||||
|  | @ -53,7 +55,7 @@ namespace EFSDK | ||||||
| 
 | 
 | ||||||
|             string mappingJson = GenerateMappingJson(mapping); |             string mappingJson = GenerateMappingJson(mapping); | ||||||
|             // 更新 mappingInfo |             // 更新 mappingInfo | ||||||
|             UpdateMappingInEFSdk_LineByLine(mappingJson); |             // UpdateMappingInEFSdk_LineByLine(mappingJson); | ||||||
|             // 映射文件 |             // 映射文件 | ||||||
|             string mappingPath = Path.Combine(TempDir, "res_mapping.json"); |             string mappingPath = Path.Combine(TempDir, "res_mapping.json"); | ||||||
|             File.WriteAllText(mappingPath, mappingJson); |             File.WriteAllText(mappingPath, mappingJson); | ||||||
|  | @ -66,30 +68,40 @@ namespace EFSDK | ||||||
|         private static void CopyAndRenameFiles(string srcDir, string dstDir, out Dictionary<string, string> mapping) |         private static void CopyAndRenameFiles(string srcDir, string dstDir, out Dictionary<string, string> mapping) | ||||||
|         { |         { | ||||||
|             mapping = new Dictionary<string, string>(); |             mapping = new Dictionary<string, string>(); | ||||||
|  | 
 | ||||||
|             foreach (var filePath in Directory.GetFiles(srcDir, "*", SearchOption.AllDirectories)) |             foreach (var filePath in Directory.GetFiles(srcDir, "*", SearchOption.AllDirectories)) | ||||||
|             { |             { | ||||||
|                 if (filePath.EndsWith(".meta")) continue; |                 if (filePath.EndsWith(".meta")) continue; | ||||||
| 
 | 
 | ||||||
|  |                 // 相对于源目录的路径 | ||||||
|                 string relativePath = filePath.Substring(srcDir.Length + 1).Replace("\\", "/"); |                 string relativePath = filePath.Substring(srcDir.Length + 1).Replace("\\", "/"); | ||||||
|                 string newName = GenerateRandomAndroidName(Path.GetExtension(filePath)); |  | ||||||
|                 mapping[Path.GetFileName(filePath)] = newName; |  | ||||||
| 
 | 
 | ||||||
|                 string dstPath = Path.Combine(dstDir, newName); |                 // 获取文件夹路径 | ||||||
|  |                 string relativeDir = Path.GetDirectoryName(relativePath).Replace("\\", "/"); | ||||||
|  | 
 | ||||||
|  |                 // 生成随机文件名 | ||||||
|  |                 string newName = GenerateRandomAndroidName(filePath); | ||||||
|  | 
 | ||||||
|  |                 // 保存映射关系 (相对路径 + 原始文件名 -> 随机名) | ||||||
|  |                 string key = Path.GetFileNameWithoutExtension(relativePath); // 可以保留目录信息 | ||||||
|  |                 string value = string.IsNullOrEmpty(relativeDir) ? newName : $"{relativeDir}/{newName}"; | ||||||
|  |                 string fileNameWithoutExt = Path.GetFileNameWithoutExtension(value); | ||||||
|  |                 mapping[key] = fileNameWithoutExt; | ||||||
|  | 
 | ||||||
|  |                 // 目标路径 | ||||||
|  |                 string dstPath = Path.Combine(dstDir, value.Replace("/", Path.DirectorySeparatorChar.ToString())); | ||||||
|  | 
 | ||||||
|  |                 // 确保目录存在 | ||||||
|                 string dstFolder = Path.GetDirectoryName(dstPath); |                 string dstFolder = Path.GetDirectoryName(dstPath); | ||||||
|                 if (!Directory.Exists(dstFolder)) Directory.CreateDirectory(dstFolder); |                 if (!Directory.Exists(dstFolder)) Directory.CreateDirectory(dstFolder); | ||||||
| 
 | 
 | ||||||
|  |                 // 复制文件 | ||||||
|                 File.Copy(filePath, dstPath); |                 File.Copy(filePath, dstPath); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             foreach (var dir in Directory.GetDirectories(srcDir, "*", SearchOption.AllDirectories)) |             Debug.Log("✅ Files copied and renamed (directory structure preserved)"); | ||||||
|             { |  | ||||||
|                 string relativeDir = dir.Substring(srcDir.Length + 1); |  | ||||||
|                 string dstSubDir = Path.Combine(dstDir, relativeDir); |  | ||||||
|                 if (!Directory.Exists(dstSubDir)) Directory.CreateDirectory(dstSubDir); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|             Debug.Log("✅ Files copied and renamed"); |  | ||||||
|         } |  | ||||||
|         private static string GenerateMappingJson(Dictionary<string, string> mapping) |         private static string GenerateMappingJson(Dictionary<string, string> mapping) | ||||||
|         { |         { | ||||||
|             var items = new List<MappingItem>(); |             var items = new List<MappingItem>(); | ||||||
|  | @ -97,28 +109,59 @@ namespace EFSDK | ||||||
|             { |             { | ||||||
|                 items.Add(new MappingItem { key = kv.Key, value = kv.Value }); |                 items.Add(new MappingItem { key = kv.Key, value = kv.Value }); | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|             MappingListWrapper wrapper = new MappingListWrapper { items = items }; |             MappingListWrapper wrapper = new MappingListWrapper { items = items }; | ||||||
|             return JsonUtility.ToJson(wrapper, false); |             return JsonUtility.ToJson(wrapper, false); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         [System.Serializable] |         [System.Serializable] | ||||||
|         private class MappingItem { public string key; public string value; } |         private class MappingItem | ||||||
| 
 |  | ||||||
|         [System.Serializable] |  | ||||||
|         private class MappingListWrapper { public List<MappingItem> items; } |  | ||||||
|         private static string GenerateRandomAndroidName(string ext) |  | ||||||
|         { |         { | ||||||
|             int len = UnityEngine.Random.Range(6, 12); |             public string key; | ||||||
|             string chars = "abcdefghijklmnopqrstuvwxyz0123456789"; |             public string value; | ||||||
|             string name = ""; |  | ||||||
|             for (int i = 0; i < len; i++) |  | ||||||
|             { |  | ||||||
|                 name += chars[UnityEngine.Random.Range(0, chars.Length)]; |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|             if (!char.IsLetter(name[0])) name = "a" + name.Substring(1); |         [System.Serializable] | ||||||
|  |         private class MappingListWrapper | ||||||
|  |         { | ||||||
|  |             public List<MappingItem> items; | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|             return name + ext; |         private static string GenerateRandomAndroidName(string filePath) | ||||||
|  |         { | ||||||
|  |             string ext = Path.GetExtension(filePath); | ||||||
|  |             string oriFileName = Path.GetFileNameWithoutExtension(filePath); | ||||||
|  |             string md5Str = GetFirstEightWithUnderscore(GetMD5Hash(Application.identifier + oriFileName + oriFileName)); | ||||||
|  |             return md5Str + ext; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         static string GetFirstEightWithUnderscore(string str) | ||||||
|  |         { | ||||||
|  |             if (string.IsNullOrEmpty(str)) return str; | ||||||
|  |             string sub = str.Length <= 8 ? str : str.Substring(0, 8); | ||||||
|  |             if (char.IsDigit(sub[0])) | ||||||
|  |             { | ||||||
|  |                 sub = "a" + sub; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return sub; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public static string GetMD5Hash(string input) | ||||||
|  |         { | ||||||
|  |             using (var md5 = MD5.Create()) | ||||||
|  |             { | ||||||
|  |                 var inputBytes = Encoding.ASCII.GetBytes(input); | ||||||
|  |                 var hashBytes = md5.ComputeHash(inputBytes); | ||||||
|  | 
 | ||||||
|  |                 var builder = new StringBuilder(); | ||||||
|  |                 foreach (var t in hashBytes) | ||||||
|  |                 { | ||||||
|  |                     builder.Append(t.ToString("x2")); // Convert byte to hexadecimal string | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 return builder.ToString(); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private static void UpdateMappingInEFSdk_LineByLine(string mappingJson) |         private static void UpdateMappingInEFSdk_LineByLine(string mappingJson) | ||||||
|  | @ -148,7 +191,8 @@ namespace EFSDK | ||||||
|                 { |                 { | ||||||
|                     if (lines[i].Contains("private static EFSdk _mEfSdk")) |                     if (lines[i].Contains("private static EFSdk _mEfSdk")) | ||||||
|                     { |                     { | ||||||
|                         lines[i] += $"\n        private static string mappingInfo = @\"{mappingJson.Replace("\"", "\"\"")}\";"; |                         lines[i] += | ||||||
|  |                             $"\n        private static string mappingInfo = @\"{mappingJson.Replace("\"", "\"\"")}\";"; | ||||||
|                         updated = true; |                         updated = true; | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.IO; | using System.IO; | ||||||
|  | using EFSDK; | ||||||
| using Unity.Plastic.Newtonsoft.Json.Linq; | using Unity.Plastic.Newtonsoft.Json.Linq; | ||||||
| using UnityEditor.Android; | using UnityEditor.Android; | ||||||
| using UnityEngine; | using UnityEngine; | ||||||
|  | @ -18,12 +19,13 @@ public class DynamicApplicationClass : IPostGenerateGradleAndroidProject | ||||||
| 
 | 
 | ||||||
|     public void OnPostGenerateGradleAndroidProject(string path) |     public void OnPostGenerateGradleAndroidProject(string path) | ||||||
|     { |     { | ||||||
|  |         AndroidResAarBuilder.BuildAAR(); | ||||||
|         var androidManifest = new SDKTool.AndroidManifest(SDKTool.GetManifestPath(path)); |         var androidManifest = new SDKTool.AndroidManifest(SDKTool.GetManifestPath(path)); | ||||||
|         androidManifest.SetStartingActivityAttribute("hardwareAccelerated", "true"); |         androidManifest.SetStartingActivityAttribute("hardwareAccelerated", "true"); | ||||||
|         androidManifest.Save(); |         androidManifest.Save(); | ||||||
|         SetGradleConstraints(path); |         SetGradleConstraints(path); | ||||||
|         FixedAddressValueTypeAttribute(path); |         FixedAddressValueTypeAttribute(path); | ||||||
|         ParseConfigFile(path); |         // ParseConfigFile(path); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private static void SetGradleConstraints(string path) |     private static void SetGradleConstraints(string path) | ||||||
|  | @ -42,7 +44,8 @@ public class DynamicApplicationClass : IPostGenerateGradleAndroidProject | ||||||
|             if (line.Trim().Contains("com.earn.money:sdk")) |             if (line.Trim().Contains("com.earn.money:sdk")) | ||||||
|             { |             { | ||||||
|                 Debug.Log("找到com.earn.money:sdk"); |                 Debug.Log("找到com.earn.money:sdk"); | ||||||
|                 buildGradleOutLines.Add($"        implementation ('com.earn.money:sdk:{SDKTool.GetSDKVersion()}')"); |                  | ||||||
|  |                 buildGradleOutLines.Add($"        implementation ('com.earn.money:{Application.identifier}:{SDKTool.GetSDKVersion()}')"); | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|  |  | ||||||
|  | @ -57,11 +57,11 @@ public class SDKTool | ||||||
|     public static string GetSDKVersion() |     public static string GetSDKVersion() | ||||||
|     { |     { | ||||||
|         var xmlText = |         var xmlText = | ||||||
|             SDKEditorNetworkTool.GetText("https://repo.dgtverse.cn/repository/tk_my/com/earn/money/sdk/maven-metadata.xml"); |             SDKEditorNetworkTool.GetText($"https://repo.dgtverse.cn/repository/tk_my/com/earn/money/{Application.identifier}/maven-metadata.xml"); | ||||||
|         if (string.IsNullOrEmpty(xmlText)) |         if (string.IsNullOrEmpty(xmlText)) | ||||||
|         { |         { | ||||||
|             throw new RuntimeBinderException( |             throw new RuntimeBinderException( | ||||||
|                 "获取版本号失败 , 接口请求返回为空,或请求不到. https://repo.dgtverse.cn/repository/tk_my/com/earn/money/sdk/maven-metadata.xml"); |                 $"获取版本号失败 , 接口请求返回为空,或请求不到. https://repo.dgtverse.cn/repository/tk_my/com/earn/money/{Application.identifier}/maven-metadata.xml"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         try |         try | ||||||
|  |  | ||||||
|  | @ -128,6 +128,15 @@ namespace WZ | ||||||
|                 }else if (_configs[i].Key.ToLower() == KEY_Admob_NativeId.ToLower()) |                 }else if (_configs[i].Key.ToLower() == KEY_Admob_NativeId.ToLower()) | ||||||
|                 { |                 { | ||||||
|                     StaticValue.AdmobNativeId = valueTemp; |                     StaticValue.AdmobNativeId = valueTemp; | ||||||
|  |                 }else if (_configs[i].Key.ToLower() == KEY_Admob_SMALL_NativeId.ToLower()) | ||||||
|  |                 { | ||||||
|  |                     StaticValue.AdmobSmallNativeId = valueTemp; | ||||||
|  |                 }else if (_configs[i].Key.ToLower() == KEY_Admob_MINDDLE_NativeId.ToLower()) | ||||||
|  |                 { | ||||||
|  |                     StaticValue.AdmobMinddleNativeId = valueTemp; | ||||||
|  |                 }else if (_configs[i].Key.ToLower() == KEY_Admob_FULL_NativeId.ToLower()) | ||||||
|  |                 { | ||||||
|  |                     StaticValue.AdmobFullNativeId = valueTemp; | ||||||
|                 }else if (_configs[i].Key.ToLower() == KEY_Admob_RewardId.ToLower()) |                 }else if (_configs[i].Key.ToLower() == KEY_Admob_RewardId.ToLower()) | ||||||
|                 { |                 { | ||||||
|                     StaticValue.AdmobRewardId = valueTemp; |                     StaticValue.AdmobRewardId = valueTemp; | ||||||
|  | @ -290,6 +299,9 @@ namespace WZ | ||||||
|         public const string KEY_Admob_NormalBannerId = "Admob_Banner_ID2"; |         public const string KEY_Admob_NormalBannerId = "Admob_Banner_ID2"; | ||||||
|         public const string KEY_Admob_SplashId = "Admob_APPOPEN_ID"; |         public const string KEY_Admob_SplashId = "Admob_APPOPEN_ID"; | ||||||
|         public const string KEY_Admob_NativeId = "Admob_NATIVE_ID"; |         public const string KEY_Admob_NativeId = "Admob_NATIVE_ID"; | ||||||
|  |         public const string KEY_Admob_SMALL_NativeId = "ADMOB_SMALL_NATIVE_ID"; | ||||||
|  |         public const string KEY_Admob_MINDDLE_NativeId = "ADMOB_MIDDLE_NATIVE_ID"; | ||||||
|  |         public const string KEY_Admob_FULL_NativeId = "Admob_FULL_NATIVE_ID"; | ||||||
|         public const string KEY_Admob_RewardId = "Admob_RV_ID"; |         public const string KEY_Admob_RewardId = "Admob_RV_ID"; | ||||||
|         public const string KEY_Admob_InterId = "Admob_IV_ID"; |         public const string KEY_Admob_InterId = "Admob_IV_ID"; | ||||||
|         public const string KEY_PRIVACY_URL = "tka_url_privacy"; |         public const string KEY_PRIVACY_URL = "tka_url_privacy"; | ||||||
|  |  | ||||||
|  | @ -1,4 +1,5 @@ | ||||||
| using System; | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
| 
 | 
 | ||||||
| namespace WZ | namespace WZ | ||||||
| { | { | ||||||
|  | @ -19,7 +20,10 @@ namespace WZ | ||||||
| 
 | 
 | ||||||
|     public static class IvRulesConst |     public static class IvRulesConst | ||||||
|     { |     { | ||||||
|         public static int CurrentOverLevel = 0; //每跳过几次触发 |         //每跳过几次触发 | ||||||
|         public static long CurrentInterval = 0; //广告最小时间间隔 |         public static Dictionary<string, int> OverLevels = new Dictionary<string, int>(); | ||||||
|  | 
 | ||||||
|  |         //广告最小时间间隔 | ||||||
|  |         public static Dictionary<string, long> Intervals = new Dictionary<string, long>(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -14,6 +14,9 @@ namespace WZ | ||||||
|         public static string AdmobSplashId = ""; |         public static string AdmobSplashId = ""; | ||||||
| 
 | 
 | ||||||
|         public static string AdmobNativeId = ""; |         public static string AdmobNativeId = ""; | ||||||
|  |         public static string AdmobSmallNativeId = ""; | ||||||
|  |         public static string AdmobMinddleNativeId = ""; | ||||||
|  |         public static string AdmobFullNativeId = ""; | ||||||
| 
 | 
 | ||||||
|         public static string AdmobRewardId = ""; |         public static string AdmobRewardId = ""; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -49,7 +49,6 @@ namespace WZ | ||||||
|                 LoggerUtils.Debug("[Admob] init success"); |                 LoggerUtils.Debug("[Admob] init success"); | ||||||
|             });     |             });     | ||||||
|              |              | ||||||
|             _nativeAdUnits.Add("ca-app-pub-3940256099942544/2247696110"); |  | ||||||
|             if (_nativeAdUnits.Count > 0) |             if (_nativeAdUnits.Count > 0) | ||||||
|             { |             { | ||||||
|                 LoadNative(); |                 LoadNative(); | ||||||
|  |  | ||||||
|  | @ -39,7 +39,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) => | ||||||
|             { |             { | ||||||
|                 LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} loaded {ad} error {error}"); |                 LoggerUtils.Debug($"[Admob] Native Ad unit {adUnitId} load end. {ad} error {error}"); | ||||||
|                 if (error != null || ad == null) |                 if (error != null || ad == null) | ||||||
|                 { |                 { | ||||||
|                     if (!_retryCounters.TryAdd(adUnitId, 0)) |                     if (!_retryCounters.TryAdd(adUnitId, 0)) | ||||||
|  | @ -55,9 +55,10 @@ namespace WZ | ||||||
| 
 | 
 | ||||||
|                 _retryCounters[adUnitId] = 0; |                 _retryCounters[adUnitId] = 0; | ||||||
| 
 | 
 | ||||||
|                 LoggerUtils.Debug("Admob Native ad loaded with response : " + ad.GetResponseInfo().ToString()); |                 var nativeEcpm = AdmobUtils.GetNativeEcpm(ad); | ||||||
|                 _nativeAds[adUnitId] = ad; |                 _nativeAds[adUnitId] = ad; | ||||||
|                 _adRevenueCache[adUnitId] = AdmobUtils.GetNativeEcpm(ad); |                 _adRevenueCache[adUnitId] = nativeEcpm; | ||||||
|  |                 LoggerUtils.Debug($"Admob Native ad loaded with nativeEcpm = {nativeEcpm} response : " + ad.GetResponseInfo().ToString()); | ||||||
|                 AdsKeyEvents.Instance.LogAdFPUEvents(AdsType.Native); |                 AdsKeyEvents.Instance.LogAdFPUEvents(AdsType.Native); | ||||||
| 
 | 
 | ||||||
|                 ad.OnAdPaid += (AdValue adValue) => |                 ad.OnAdPaid += (AdValue adValue) => | ||||||
|  | @ -187,9 +188,10 @@ namespace WZ | ||||||
|         { |         { | ||||||
|             if (adUnitId == null || string.IsNullOrEmpty(adUnitId)) |             if (adUnitId == null || string.IsNullOrEmpty(adUnitId)) | ||||||
|             { |             { | ||||||
|                 foreach (var ad in _nativeAds.Values) |                 foreach (var nativeOverlayAd in _nativeAds) | ||||||
|                 { |                 { | ||||||
|                     ad.Hide(); |                     nativeOverlayAd.Value.Hide(); | ||||||
|  |                     LoadAd(nativeOverlayAd.Key); | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 return; |                 return; | ||||||
|  | @ -198,6 +200,7 @@ namespace WZ | ||||||
|             if (_nativeAds.TryGetValue(adUnitId, out var tempAd)) |             if (_nativeAds.TryGetValue(adUnitId, out var tempAd)) | ||||||
|             { |             { | ||||||
|                 tempAd.Hide(); |                 tempAd.Hide(); | ||||||
|  |                 LoadAd(adUnitId); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -54,7 +54,7 @@ namespace WZ | ||||||
| 
 | 
 | ||||||
|         public static double GetNativeEcpm(NativeOverlayAd ad) |         public static double GetNativeEcpm(NativeOverlayAd ad) | ||||||
|         { |         { | ||||||
|             return 0.0; |             return GetEcpm(ad, "nativeOverlayAd", "nativeAd", NaStack); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private static double GetEcpm(object o, string cShapeFieldName, string javaFieldName, string[] stack) |         private static double GetEcpm(object o, string cShapeFieldName, string javaFieldName, string[] stack) | ||||||
|  | @ -76,6 +76,7 @@ namespace WZ | ||||||
|         private static readonly string[] SpStack = { "zzb", "zzi", "zze", "zze", "zzae" }; |         private static readonly string[] SpStack = { "zzb", "zzi", "zze", "zze", "zzae" }; | ||||||
|         private static readonly string[] IvStack = { "zzc", "zzj", "zzf", "zzd", "zzae" }; |         private static readonly string[] IvStack = { "zzc", "zzj", "zzf", "zzd", "zzae" }; | ||||||
|         private static readonly string[] RvStack = { "zzb", "zzi", "zze", "zze", "zzae" }; |         private static readonly string[] RvStack = { "zzb", "zzi", "zze", "zze", "zzae" }; | ||||||
|  |         private static readonly string[] NaStack = { "zza", "zzb", "zzf", "zzD", "zzb", "zzae" }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|  |  | ||||||
|  | @ -245,6 +245,8 @@ namespace WZ | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         #region IvRules | ||||||
|  | 
 | ||||||
|         public bool IvRulesShow(IvType ivadType) |         public bool IvRulesShow(IvType ivadType) | ||||||
|         { |         { | ||||||
|             //1.获取远程配置 |             //1.获取远程配置 | ||||||
|  | @ -274,37 +276,52 @@ namespace WZ | ||||||
|             } |             } | ||||||
|             //4.判断skip(次安装跳过几次触发不展示广告) |             //4.判断skip(次安装跳过几次触发不展示广告) | ||||||
|             int skipLevel = ivRulesData.skipLevel; |             int skipLevel = ivRulesData.skipLevel; | ||||||
|             int currentSkipLevel = PlayerPrefsUtils.GetPlayerPrefsInt(IvRulesKey.KEY_SKIPLEVEL, 0); |             int currentSkipLevel = PlayerPrefsUtils.GetPlayerPrefsInt($"{IvRulesKey.KEY_SKIPLEVEL}_{ivadType.ToString()}", 0); | ||||||
|             if (currentSkipLevel < skipLevel) |             if (currentSkipLevel < skipLevel) | ||||||
|             { |             { | ||||||
|                 LoggerUtils.Debug($"[SDK] skipLevel limit"); |                 LoggerUtils.Debug($"[SDK] {ivadType} skipLevel limit"); | ||||||
|                 PlayerPrefsUtils.SavePlayerPrefsInt(IvRulesKey.KEY_SKIPLEVEL, currentSkipLevel + 1); |                 PlayerPrefsUtils.SavePlayerPrefsInt($"{IvRulesKey.KEY_SKIPLEVEL}_{ivadType.ToString()}", currentSkipLevel + 1); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             //5.判断overLevel(没跳过几次触发) |             //5.判断overLevel(每跳过几次触发) | ||||||
|             int overLevel = ivRulesData.overLevel; |             int overLevel = ivRulesData.overLevel; | ||||||
|             int currentOverLevel = IvRulesConst.CurrentOverLevel; |             int currentOverLevel = IvRulesConst.OverLevels.ContainsKey(ivadType.ToString()) ?  IvRulesConst.OverLevels[ivadType.ToString()] : 0; | ||||||
|             if (currentOverLevel < overLevel) |             if (currentOverLevel < overLevel) | ||||||
|             { |             { | ||||||
|                 LoggerUtils.Debug($"[SDK] overLevel limit"); |                 LoggerUtils.Debug($"[SDK] {ivadType} overLevel limit"); | ||||||
|                 IvRulesConst.CurrentOverLevel++; |                 IvRulesConst.OverLevels[ivadType.ToString()] = currentOverLevel + 1; | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             //6.判断interval(广告时间间隔) |             //6.判断interval(广告时间间隔) | ||||||
|             int interval = ivRulesData.interval; |             int interval = ivRulesData.interval; | ||||||
|             long currentInterval = IvRulesConst.CurrentInterval; |             long currentInterval = IvRulesConst.Intervals.ContainsKey(ivadType.ToString()) ? IvRulesConst.Intervals[ivadType.ToString()] : 0; | ||||||
|             long localTimestamp = TimeUtils.GetLocalTimestamp(); |             long localTimestamp = TimeUtils.GetLocalTimestamp(); | ||||||
| 
 | 
 | ||||||
|             if (localTimestamp < currentInterval + (interval * 1000L)) |             if (localTimestamp < currentInterval + (interval * 1000L)) | ||||||
|             { |             { | ||||||
|                 LoggerUtils.Debug($"[SDK] interval limit"); |                 LoggerUtils.Debug($"[SDK] {ivadType} interval limit"); | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         /// <summary> | ||||||
|  |         /// 看激励广告之后调用 | ||||||
|  |         /// </summary> | ||||||
|  |         public void ClearIvRules() | ||||||
|  |         { | ||||||
|  |             var localTimestamp = TimeUtils.GetLocalTimestamp(); | ||||||
|  |             foreach (var key in IvRulesConst.Intervals.Keys.ToList()) | ||||||
|  |             { | ||||||
|  |                 IvRulesConst.Intervals[key] = localTimestamp; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         #endregion | ||||||
|  |        | ||||||
|  |          | ||||||
|         #region 检查并刷新过期竞价 |         #region 检查并刷新过期竞价 | ||||||
|         private void CheckAndRefreshExpiredBids(AdsType _adsType) |         private void CheckAndRefreshExpiredBids(AdsType _adsType) | ||||||
|         { |         { | ||||||
|  |  | ||||||
|  | @ -50,7 +50,7 @@ namespace WZ | ||||||
|                 { |                 { | ||||||
|                     AdsType.Banner => new List<string> { StaticValue.AdmobNormalBannerId }, |                     AdsType.Banner => new List<string> { StaticValue.AdmobNormalBannerId }, | ||||||
|                     AdsType.Rewarded => new List<string> { StaticValue.AdmobRewardId }, |                     AdsType.Rewarded => new List<string> { StaticValue.AdmobRewardId }, | ||||||
|                     AdsType.Native => new List<string> { StaticValue.AdmobNativeId }, |                     AdsType.Native => new List<string> { StaticValue.AdmobNativeId, StaticValue.AdmobMinddleNativeId, StaticValue.AdmobSmallNativeId, StaticValue.AdmobFullNativeId }, | ||||||
|                     AdsType.Splash => new List<string> { StaticValue.AdmobSplashId }, |                     AdsType.Splash => new List<string> { StaticValue.AdmobSplashId }, | ||||||
|                     AdsType.Interstitial => new List<string> { StaticValue.AdmobInterId }, |                     AdsType.Interstitial => new List<string> { StaticValue.AdmobInterId }, | ||||||
|                     _ => new List<string>() |                     _ => new List<string>() | ||||||
|  |  | ||||||
|  | @ -11,8 +11,9 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
| {     | {     | ||||||
|     //包名 |     //包名 | ||||||
|     public const string PackageName = "com.rush.cash.earn.fast.real.money.game"; |     public const string PackageName = "com.rush.cash.earn.fast.real.money.game"; | ||||||
|     public void Init(Action action) |     public void Init(Action action, bool showLog) | ||||||
|     { |     { | ||||||
|  |         LoggerUtils.Enabled = showLog; | ||||||
|         FileParse.Parse(); |         FileParse.Parse(); | ||||||
|         // AdConfigParser.Parse(); |         // AdConfigParser.Parse(); | ||||||
|         FireBaseSDKManager.Instance.Init(); |         FireBaseSDKManager.Instance.Init(); | ||||||
|  | @ -20,8 +21,10 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|         AdmobAdsManager.Instance.Initialize(); |         AdmobAdsManager.Instance.Initialize(); | ||||||
|         AdjustManager.Instance.Init(); |         AdjustManager.Instance.Init(); | ||||||
|         ShuShuMangage.Instance.Init(); |         ShuShuMangage.Instance.Init(); | ||||||
|         AdsSDKManager.Instance.InitSDK(action); |         AdsSDKManager.Instance.InitSDK(null); | ||||||
|         EFSdkManager.Instance.Init(); |         EFSdkManager.Instance.Init(); | ||||||
|  |          | ||||||
|  |         action?.Invoke(); | ||||||
|     } |     } | ||||||
|      |      | ||||||
| 
 | 
 | ||||||
|  | @ -36,17 +39,58 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
| 
 | 
 | ||||||
|     #region ad |     #region ad | ||||||
| 
 | 
 | ||||||
|  |     /// <summary> | ||||||
|  |     /// 是否已缓存激励广告 | ||||||
|  |     /// </summary> | ||||||
|  |     /// <returns></returns> | ||||||
|  |     public bool IsRewardedAdReady() | ||||||
|  |     { | ||||||
|  |         return AdsSDKManager.Instance.IsRewardAdReady();; | ||||||
|  |     }  | ||||||
|  |      | ||||||
|  |     /// <summary> | ||||||
|  |     /// 展示激励广告 | ||||||
|  |     /// </summary> | ||||||
|  |     /// <param name="position"></param> | ||||||
|  |     /// <param name="callback"></param> | ||||||
|     public void ShowRewardAd(string position, Action<bool,double> callback = null) |     public void ShowRewardAd(string position, Action<bool,double> callback = null) | ||||||
|  |     { | ||||||
|  |         bool isRewardAdReady = AdsSDKManager.Instance.IsRewardAdReady(); | ||||||
|  |         if (isRewardAdReady) | ||||||
|         { |         { | ||||||
|             AdsSDKManager.Instance.ShowRewardAd(position, (isReward, revenue) => |             AdsSDKManager.Instance.ShowRewardAd(position, (isReward, revenue) => | ||||||
|             { |             { | ||||||
|                 if (isReward) |                 if (isReward) | ||||||
|                 { |                 { | ||||||
|                 //callback?.Invoke(); |                     AdsSDKManager.Instance.ClearIvRules(); | ||||||
|                     callback?.Invoke(true, revenue); |                     callback?.Invoke(true, revenue); | ||||||
|                 } |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     callback?.Invoke(false, 0); | ||||||
|  |                 } | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             callback?.Invoke(false, 0); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /// <summary> | ||||||
|  |     /// 是否已缓存插屏 | ||||||
|  |     /// </summary> | ||||||
|  |     public bool IsInterstitialAdReady() | ||||||
|  |     { | ||||||
|  |         return AdsSDKManager.Instance.IsInterstitialReady(); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     /// <summary> | ||||||
|  |     /// 展示插屏广告 | ||||||
|  |     /// </summary> | ||||||
|  |     /// <param name="position"></param> | ||||||
|  |     /// <param name="ivadType"></param> | ||||||
|  |     /// <param name="callback"></param> | ||||||
|     public void ShowInterstitial(string position, IvType ivadType = IvType.IV1, Action<double> callback = null) |     public void ShowInterstitial(string position, IvType ivadType = IvType.IV1, Action<double> callback = null) | ||||||
|     { |     { | ||||||
|         //插屏展示逻辑 |         //插屏展示逻辑 | ||||||
|  | @ -60,24 +104,50 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|                 AdsSDKManager.Instance.ShowInterstitialAd(position, ivadType, (revenue) => |                 AdsSDKManager.Instance.ShowInterstitialAd(position, ivadType, (revenue) => | ||||||
|                 { |                 { | ||||||
|                     //展示完一个插屏之后调用 |                     //展示完一个插屏之后调用 | ||||||
|                     IvRulesConst.CurrentOverLevel = 0; |                     IvRulesConst.OverLevels[ivadType.ToString()] = 0; | ||||||
|                     IvRulesConst.CurrentInterval = TimeUtils.GetLocalTimestamp(); |                     IvRulesConst.Intervals[ivadType.ToString()] = TimeUtils.GetLocalTimestamp(); | ||||||
|  |                     callback?.Invoke(revenue); | ||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             {  |             {  | ||||||
|                 callback?.Invoke(0); |                 callback?.Invoke(-1); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             callback?.Invoke(0); |             callback?.Invoke(-1); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public bool IsRewardAdReady() |     public void ShowBanner() | ||||||
|     { |     { | ||||||
|         return AdsSDKManager.Instance.IsRewardAdReady();; |         AdsSDKManager.Instance.ShowBanner(); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     public void HideBanner() | ||||||
|  |     { | ||||||
|  |         AdsSDKManager.Instance.HideBanner(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public bool IsNativeFullReady() | ||||||
|  |     { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     public void ShowFullNative(string position, Action<bool, double> callback = null) | ||||||
|  |     { | ||||||
|  |          | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void ShowNative(RectTransform rectTransform, Camera camera = null, string position = "") | ||||||
|  |     { | ||||||
|  |          | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void HideNative() | ||||||
|  |     { | ||||||
|  |          | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     #endregion |     #endregion | ||||||
|  | @ -211,6 +281,11 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|         EFSdk.get().Refresh(); |         EFSdk.get().Refresh(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public void CanGoback(Action<bool> canGobackAction) | ||||||
|  |     { | ||||||
|  |          EFSdk.get().CanGoback(canGobackAction); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// 回上一页 |     /// 回上一页 | ||||||
|     /// </summary> |     /// </summary> | ||||||
|  | @ -230,89 +305,6 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     /// <summary> |  | ||||||
|     /// 是否手动控制漂浮道具显示/隐藏 |  | ||||||
|     /// SDK内默认当H5页面加载完成后自动显示漂浮道具 |  | ||||||
|     /// </summary> |  | ||||||
|     /// <param name="autoShow">true: 自动显示/隐藏道具    false: 游戏主动控制道具显示/隐藏</param> |  | ||||||
|     /// <returns></returns> |  | ||||||
|     public void AutoShowFloat(bool autoShow) |  | ||||||
|     { |  | ||||||
|         if (Application.isEditor) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         EFSdk.get().AutoShowFloat(false); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /// <summary> |  | ||||||
|     /// 新增接口飘金币 |  | ||||||
|     /// </summary> |  | ||||||
|     /// <param name="id"></param> |  | ||||||
|     /// <param name="res">悬浮金币按钮的图片资源,传字符串 0 或 1    0:金币图  1:红点宝箱图 </param> |  | ||||||
|     /// <returns></returns> |  | ||||||
|     public void ShowFloatCoin(String res) |  | ||||||
|     { |  | ||||||
|         if (Application.isEditor) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         var remoteConfig = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("coin_position", 3); |  | ||||||
|         if (remoteConfig <= 0) |  | ||||||
|         { |  | ||||||
|             remoteConfig = 3; |  | ||||||
|         } |  | ||||||
|         if (remoteConfig > 10) |  | ||||||
|         { |  | ||||||
|             remoteConfig = 3; |  | ||||||
|         } |  | ||||||
|         EFSdk.get().SetFloatCoinRes(res); |  | ||||||
|         EFSdk.get().ShowFloatCoin(remoteConfig); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /// <summary> |  | ||||||
|     /// 隐藏金币 |  | ||||||
|     /// </summary> |  | ||||||
|     /// <returns></returns> |  | ||||||
|     public void HideFloatCoin() |  | ||||||
|     { |  | ||||||
|         if (Application.isEditor) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         EFSdk.get().HideFloatCoin(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /// <param name="startId">宝箱动画起始位置</param> |  | ||||||
|     /// <param name="endId">宝箱动画移动结束位置</param> |  | ||||||
|     /// <param name="fly_first_time">首次delay时间</param> |  | ||||||
|     /// <param name="fly_gap_time">每次漂浮移动的时间间隔</param> |  | ||||||
|     /// <returns></returns> |  | ||||||
|     public void ShowBalloon(int startId, int endId, int fly_first_time, int fly_gap_time) |  | ||||||
|     { |  | ||||||
|         if (Application.isEditor) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         var startFlyIndex = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("start_fly", 40); |  | ||||||
|         var endFlyIndex = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("end_fly", 60); |  | ||||||
|         var flyFirstTime = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("fly_first_time", 3); |  | ||||||
|         var flyGapTime = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("fly_gap_time", 15); |  | ||||||
|         EFSdk.get().ShowBalloon(startFlyIndex, endFlyIndex, flyFirstTime, flyGapTime); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /// <summary> |  | ||||||
|     /// 隐藏气球 |  | ||||||
|     /// </summary> |  | ||||||
|     /// <returns></returns> |  | ||||||
|     public void HideBalloon() |  | ||||||
|     { |  | ||||||
|         if (Application.isEditor) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         EFSdk.get().HideBalloon(); |  | ||||||
|     } |  | ||||||
|      |      | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// 设置推送开关, SDK默认关闭通知 |     /// 设置推送开关, SDK默认关闭通知 | ||||||
|  | @ -384,13 +376,12 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|     /// 消息类通知弹出间隔,SDK默认设置为60秒(在线参数控制)-Key: messagenotif  Value:60 |     /// 消息类通知弹出间隔,SDK默认设置为60秒(在线参数控制)-Key: messagenotif  Value:60 | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     /// <param name="timeSeconds"></param> |     /// <param name="timeSeconds"></param> | ||||||
|     public void SetPushMessagenotif() |     public void SetPushMessagenotif(int timeSeconds) | ||||||
|     { |     { | ||||||
|         if (Application.isEditor) |         if (Application.isEditor) | ||||||
|         { |         { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         int timeSeconds = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("messagenotif", 60); |  | ||||||
|         EFSdk.get().SetPushMessagenotif(timeSeconds); |         EFSdk.get().SetPushMessagenotif(timeSeconds); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -398,13 +389,12 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|     /// 持续性通知在进入游戏时弹出的时间间隔,SDK默认设置为300秒(在线参数控制 )-Key:persistentnotif Value:300 |     /// 持续性通知在进入游戏时弹出的时间间隔,SDK默认设置为300秒(在线参数控制 )-Key:persistentnotif Value:300 | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     /// <param name="timeSeconds"></param> |     /// <param name="timeSeconds"></param> | ||||||
|     public void SetPushPersistentnotif() |     public void SetPushPersistentnotif(int timeSeconds) | ||||||
|     { |     { | ||||||
|         if (Application.isEditor) |         if (Application.isEditor) | ||||||
|         { |         { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         int timeSeconds = FireBaseRemoteConfigManager.Instance.GetRemoteConfigInt("persistentnotif", 300); |  | ||||||
|         EFSdk.get().SetPushPersistentnotif(timeSeconds); |         EFSdk.get().SetPushPersistentnotif(timeSeconds); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -418,31 +408,15 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|     /// 3 进入对应小游戏1界面 |     /// 3 进入对应小游戏1界面 | ||||||
|     /// 4 进入对应小游戏2界面 |     /// 4 进入对应小游戏2界面 | ||||||
|     /// </returns> |     /// </returns> | ||||||
|     public void GetJumpPage() |     public int GetJumpPage() | ||||||
|     { |     { | ||||||
|         if (Application.isEditor) |         if (Application.isEditor) | ||||||
|         { |         { | ||||||
|             return; |             return 0; | ||||||
|         } |         } | ||||||
|         int pageId = EFSdk.get().GetJumpPage(); |         int pageId = EFSdk.get().GetJumpPage(); | ||||||
|         switch (pageId) |         return pageId; | ||||||
|         { |          | ||||||
|             case 0: |  | ||||||
|                 // Nothing to do |  | ||||||
|                 break; |  | ||||||
|             case 1: |  | ||||||
|                 // 回到游戏主页 |  | ||||||
|                 break; |  | ||||||
|             case 2: |  | ||||||
|                 // 进入游戏的金币提现界面 |  | ||||||
|                 break; |  | ||||||
|             case 3: |  | ||||||
|                 // 进入对应小游戏1界面 |  | ||||||
|                 break; |  | ||||||
|             case 4: |  | ||||||
|                 // 进入对应小游戏2界面 |  | ||||||
|                 break; |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <summary> |     /// <summary> | ||||||
|  | @ -571,6 +545,14 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|         EFSdk.get().ShowToast(message); |         EFSdk.get().ShowToast(message); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /// <summary> | ||||||
|  |     /// 定时远程推送 | ||||||
|  |     /// </summary> | ||||||
|  |     public void AutoLocalPush(bool isOpen) | ||||||
|  |     { | ||||||
|  |          | ||||||
|  |     } | ||||||
|  |      | ||||||
|     #endregion |     #endregion | ||||||
| 
 | 
 | ||||||
|     /// <summary> |     /// <summary> | ||||||
|  | @ -581,4 +563,39 @@ public class AppSDKManager : D_MonoSingleton<AppSDKManager> | ||||||
|     { |     { | ||||||
|         return AdjustNetwork.Instance.InOrganic(); |         return AdjustNetwork.Instance.InOrganic(); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     public string GetGaid() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public string GetAndroidId() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public string GetAdid() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public string GetUserAgent() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public string GetSSAccountId() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public string GetSSDistinctId() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public string GetSSSuperProperties() | ||||||
|  |     { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -13,30 +13,11 @@ namespace WZ | ||||||
|          |          | ||||||
|         public void Init() |         public void Init() | ||||||
|         { |         { | ||||||
|             EFSdk.get().Init((actionType, str) => |             if (Application.isEditor) | ||||||
|             { |             { | ||||||
|                 if (EFSdk.ActionType.COIN_CLICK == actionType) |                 return; | ||||||
|                 { |  | ||||||
|                     //TOTO 游戏在此处理 点击金币弹广告的逻辑或其他 |  | ||||||
|             } |             } | ||||||
|                 if (EFSdk.ActionType.BALLOON_CLICK == actionType) |             EFSdk.get().Init((actionType, str) => { }); | ||||||
|                 { |  | ||||||
|                     //TOTO 游戏在此处理 点击宝箱弹广告的逻辑或其他 |  | ||||||
|                 } |  | ||||||
|                 if (EFSdk.ActionType.COIN_SHOW == actionType) |  | ||||||
|                 { |  | ||||||
| 
 |  | ||||||
|                 } |  | ||||||
|                 if (EFSdk.ActionType.BOX_SHOW == actionType) |  | ||||||
|                 { |  | ||||||
| 
 |  | ||||||
|                 } |  | ||||||
|                 if (EFSdk.ActionType.GAM_LOAD_SUCC == actionType) |  | ||||||
|                 { |  | ||||||
|                     // 标签id,标识哪个WebView加载成功了 |  | ||||||
|                     int id = int.Parse(str); |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
| 
 | 
 | ||||||
|             SetSDKEventCallback(); |             SetSDKEventCallback(); | ||||||
|             SetHdH5ImpressionCallback(); |             SetHdH5ImpressionCallback(); | ||||||
|  | @ -77,9 +58,7 @@ namespace WZ | ||||||
|                 PlayerPrefsUtils.SavePlayerPrefsInt(KEY_OKSPIN_SHOW_COUNT, count); |                 PlayerPrefsUtils.SavePlayerPrefsInt(KEY_OKSPIN_SHOW_COUNT, count); | ||||||
|                  |                  | ||||||
|                 //互动广告只有okSpin |                 //互动广告只有okSpin | ||||||
|                 string h5ad_okspinrev = FireBaseRemoteConfigManager.Instance.GetRemoteConfigString("H5ad_okspinrev", "0"); |                 float revenue = FireBaseRemoteConfigManager.Instance.GetRemoteConfigFloat("rev_okspin", 0); | ||||||
|                 double revenue = double.Parse(h5ad_okspinrev, System.Globalization.CultureInfo.InvariantCulture); |  | ||||||
|                 |  | ||||||
|                 |                 | ||||||
|                 //adjust |                 //adjust | ||||||
|                 AdjustTrackEvent.Instance.TrackAdEvent(revenue, "H5ad_game", url, url); |                 AdjustTrackEvent.Instance.TrackAdEvent(revenue, "H5ad_game", url, url); | ||||||
|  |  | ||||||
|  | @ -10,10 +10,10 @@ namespace WZ | ||||||
|     { |     { | ||||||
|         public void FetchRemoteConfig() |         public void FetchRemoteConfig() | ||||||
|         { |         { | ||||||
|             // Firebase.FirebaseApp.CheckAndFixDependenciesAsync().ContinueWith(task => |             Firebase.FirebaseApp.CheckAndFixDependenciesAsync().ContinueWith(task => | ||||||
|             // { |             { | ||||||
|             //     if (task.Result == Firebase.DependencyStatus.Available) |                 if (task.Result == Firebase.DependencyStatus.Available) | ||||||
|             //     { |                 { | ||||||
|                     Firebase.RemoteConfig.FirebaseRemoteConfig.DefaultInstance.FetchAsync(TimeSpan.Zero).ContinueWithOnMainThread(task => |                     Firebase.RemoteConfig.FirebaseRemoteConfig.DefaultInstance.FetchAsync(TimeSpan.Zero).ContinueWithOnMainThread(task => | ||||||
|                     { |                     { | ||||||
|                         FirebaseRemoteConfig.DefaultInstance.ActivateAsync().ContinueWithOnMainThread(task => |                         FirebaseRemoteConfig.DefaultInstance.ActivateAsync().ContinueWithOnMainThread(task => | ||||||
|  | @ -36,8 +36,8 @@ namespace WZ | ||||||
|                             // 检查Adjust归因                    |                             // 检查Adjust归因                    | ||||||
|                         }); |                         }); | ||||||
|                     }); |                     }); | ||||||
|                 // } |                 } | ||||||
|             // }); |             }); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private void GroupSet() |         private void GroupSet() | ||||||
|  |  | ||||||
|  | @ -11,6 +11,10 @@ namespace WZ | ||||||
|     { |     { | ||||||
|         public void Init() |         public void Init() | ||||||
|         { |         { | ||||||
|  |             if (Application.isEditor) | ||||||
|  |             { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|             InitSDK(); |             InitSDK(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9,17 +9,26 @@ public class Test : MonoBehaviour | ||||||
| { | { | ||||||
|     private List<string> _rewardedAdUnits = new List<string>(); |     private List<string> _rewardedAdUnits = new List<string>(); | ||||||
| 
 | 
 | ||||||
|  |     RectTransform small; | ||||||
|  |     RectTransform medium; | ||||||
|  | 
 | ||||||
|  |     private void Start() | ||||||
|  |     { | ||||||
|  |         small = gameObject.transform.Find("NativeAd-small").GetComponent<RectTransform>(); | ||||||
|  |         medium = gameObject.transform.Find("NativeAd-medium").GetComponent<RectTransform>(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public void OnShowAd() |     public void OnShowAd() | ||||||
|     { |     { | ||||||
|         AppSDKManager.Instance.Init(null); |         AppSDKManager.Instance.Init(null, true); | ||||||
|         // KwaiAdsManager.Instance.ShowRewardAd(); |         // KwaiAdsManager.Instance.ShowRewardAd(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void OnShowInterstitial() |     public void OnShowInterstitial() | ||||||
|     { |     { | ||||||
|         // KwaiAdsManager.Instance.OnInterstitialCallback(); |         // KwaiAdsManager.Instance.OnInterstitialCallback(); | ||||||
|         var small = gameObject.transform.Find("NativeAd-small").GetComponent<RectTransform>(); |         // var small = gameObject.transform.Find("NativeAd-small").GetComponent<RectTransform>(); | ||||||
|         var medium = gameObject.transform.Find("NativeAd-medium").GetComponent<RectTransform>(); |         // var medium = gameObject.transform.Find("NativeAd-medium").GetComponent<RectTransform>(); | ||||||
|         // var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle |         // var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle | ||||||
|         // { |         // { | ||||||
|         //     TemplateId = NativeTemplateId.Medium |         //     TemplateId = NativeTemplateId.Medium | ||||||
|  | @ -43,4 +52,105 @@ public class Test : MonoBehaviour | ||||||
|             Debug.LogWarning("luojian admob native ad start show fail,not ready."); |             Debug.LogWarning("luojian admob native ad start show fail,not ready."); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     public void Native1Show() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobSmallNativeId; | ||||||
|  |         var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle | ||||||
|  |         { | ||||||
|  |             TemplateId = NativeTemplateId.Small | ||||||
|  |         }, small); | ||||||
|  |         Debug.Log($"luojian admob native ad ({adUnitId}) start show {small} medium {medium} X:{nativeAdPosition.X} Y:{nativeAdPosition.Y} Height :{nativeAdPosition.Height} Width:{nativeAdPosition.Width} Screen.dpi = {3.5}"); | ||||||
|  |         if (AdsSDKManager.Instance.IsNativeAdReady(adUnitId)) | ||||||
|  |         { | ||||||
|  |             AdsSDKManager.Instance.ShowNativeAd("test", adUnitId, nativeAdPosition); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             Debug.LogWarning($"luojian admob native ad ({adUnitId}) start show fail,not ready."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Native1Hide() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobSmallNativeId; | ||||||
|  |         AdsSDKManager.Instance.RemoveNativeAd(adUnitId); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Native2Show() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobNativeId; | ||||||
|  |         var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle | ||||||
|  |         { | ||||||
|  |             TemplateId = NativeTemplateId.Small, | ||||||
|  |             MainBackgroundColor = Color.green | ||||||
|  |         }, small); | ||||||
|  |         Debug.Log($"luojian admob native ad ({adUnitId}) start show {small} medium {medium} X:{nativeAdPosition.X} Y:{nativeAdPosition.Y} Height :{nativeAdPosition.Height} Width:{nativeAdPosition.Width} Screen.dpi = {3.5}"); | ||||||
|  |         if (AdsSDKManager.Instance.IsNativeAdReady(adUnitId)) | ||||||
|  |         { | ||||||
|  |             AdsSDKManager.Instance.ShowNativeAd("test", adUnitId, nativeAdPosition); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             Debug.LogWarning($"luojian admob native ad ({adUnitId}) start show fail,not ready."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Native2Hide() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobNativeId; | ||||||
|  |         AdsSDKManager.Instance.RemoveNativeAd(adUnitId); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public void Native3Show() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobFullNativeId; | ||||||
|  |         var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle | ||||||
|  |         { | ||||||
|  |             TemplateId = NativeTemplateId.Medium, | ||||||
|  |             MainBackgroundColor = Color.yellow | ||||||
|  |         }, medium); | ||||||
|  |         Debug.Log($"luojian admob native ad ({adUnitId}) start show {small} medium {medium} X:{nativeAdPosition.X} Y:{nativeAdPosition.Y} Height :{nativeAdPosition.Height} Width:{nativeAdPosition.Width} Screen.dpi = {3.5}"); | ||||||
|  |         if (AdsSDKManager.Instance.IsNativeAdReady(adUnitId)) | ||||||
|  |         { | ||||||
|  |             AdsSDKManager.Instance.ShowNativeAd("test", adUnitId, nativeAdPosition); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             Debug.LogWarning($"luojian admob native ad ({adUnitId}) start show fail,not ready."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Native3Hide() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobFullNativeId; | ||||||
|  |         AdsSDKManager.Instance.RemoveNativeAd(adUnitId); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     public void Native4Show() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobMinddleNativeId; | ||||||
|  |         var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle | ||||||
|  |         { | ||||||
|  |             TemplateId = NativeTemplateId.Medium, | ||||||
|  |             MainBackgroundColor = Color.yellow | ||||||
|  |         }, medium); | ||||||
|  |         Debug.Log($"luojian admob native ad ({adUnitId}) start show {small} medium {medium} X:{nativeAdPosition.X} Y:{nativeAdPosition.Y} Height :{nativeAdPosition.Height} Width:{nativeAdPosition.Width} Screen.dpi = {3.5}"); | ||||||
|  |         if (AdsSDKManager.Instance.IsNativeAdReady(adUnitId)) | ||||||
|  |         { | ||||||
|  |             AdsSDKManager.Instance.ShowNativeAd("test", adUnitId, nativeAdPosition); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             Debug.LogWarning($"luojian admob native ad ({adUnitId}) start show fail,not ready."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void Native4Hide() | ||||||
|  |     { | ||||||
|  |         var adUnitId = StaticValue.AdmobMinddleNativeId; | ||||||
|  |         AdsSDKManager.Instance.RemoveNativeAd(adUnitId); | ||||||
|  |     } | ||||||
| } | } | ||||||