native位置重写计算
This commit is contained in:
parent
8b51352e5a
commit
5851c170db
|
@ -214,8 +214,8 @@ namespace WZ
|
||||||
var tHeight = Mathf.Abs(tBottomRight.y - tTopLeft.y);
|
var tHeight = Mathf.Abs(tBottomRight.y - tTopLeft.y);
|
||||||
return new NativeAdPosition
|
return new NativeAdPosition
|
||||||
{
|
{
|
||||||
X = (int)tTopLeft.x,
|
X = PX2DP.PxToDp(tTopLeft.x),
|
||||||
Y = (int)(Screen.height - tTopLeft.y),
|
Y = PX2DP.PxToDp(Screen.height - tTopLeft.y),
|
||||||
Width = (int)tWidth,
|
Width = (int)tWidth,
|
||||||
Height = (int)tHeight,
|
Height = (int)tHeight,
|
||||||
NativeTemplateStyle = nativeTemplateStyle
|
NativeTemplateStyle = nativeTemplateStyle
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
using UnityEngine;
|
||||||
|
|
||||||
|
namespace WZ
|
||||||
|
{
|
||||||
|
public class PX2DP
|
||||||
|
{
|
||||||
|
#if UNITY_ANDROID && !UNITY_EDITOR
|
||||||
|
private static AndroidJavaClass _unityPlayerClass;
|
||||||
|
private static AndroidJavaObject _currentActivity;
|
||||||
|
private static AndroidJavaObject _resources;
|
||||||
|
private static AndroidJavaObject _displayMetrics;
|
||||||
|
|
||||||
|
// 初始化Android相关类引用
|
||||||
|
private static void Init()
|
||||||
|
{
|
||||||
|
if (_unityPlayerClass == null)
|
||||||
|
{
|
||||||
|
_unityPlayerClass = new AndroidJavaClass("com.unity3d.player.UnityPlayer");
|
||||||
|
_currentActivity = _unityPlayerClass.GetStatic<AndroidJavaObject>("currentActivity");
|
||||||
|
_resources = _currentActivity.Call<AndroidJavaObject>("getResources");
|
||||||
|
_displayMetrics = _resources.Call<AndroidJavaObject>("getDisplayMetrics");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Android平台dp转px
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="dp">需要转换的dp值</param>
|
||||||
|
/// <returns>转换后的px值</returns>
|
||||||
|
public static int DpToPx(float dp)
|
||||||
|
{
|
||||||
|
#if UNITY_ANDROID && !UNITY_EDITOR
|
||||||
|
Init();
|
||||||
|
float scale = _displayMetrics.Get<float>("density");
|
||||||
|
return (int)(dp * scale + 0.5f);
|
||||||
|
#else
|
||||||
|
// 非Android平台返回近似值
|
||||||
|
return Mathf.RoundToInt(dp * Screen.dpi / 160f);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Android平台px转dp
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="px">需要转换的px值</param>
|
||||||
|
/// <returns>转换后的dp值</returns>
|
||||||
|
public static int PxToDp(float px)
|
||||||
|
{
|
||||||
|
#if UNITY_ANDROID && !UNITY_EDITOR
|
||||||
|
Init();
|
||||||
|
float scale = _displayMetrics.Get<float>("density");
|
||||||
|
return (int)(px / scale + 0.5f);
|
||||||
|
#else
|
||||||
|
// 非Android平台返回近似值
|
||||||
|
return Mathf.RoundToInt(px * 160f / Screen.dpi);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
fileFormatVersion: 2
|
||||||
|
guid: 670d28df645a4752b53d6a5d9441c429
|
||||||
|
timeCreated: 1756780215
|
|
@ -29,7 +29,7 @@ public class Test : MonoBehaviour
|
||||||
{
|
{
|
||||||
TemplateId = NativeTemplateId.Small
|
TemplateId = NativeTemplateId.Small
|
||||||
}, small);
|
}, small);
|
||||||
Debug.Log($"luojian admob native ad start show {small} medium {medium} X:{nativeAdPosition.X} Y:{nativeAdPosition.Y} Height :{nativeAdPosition.Height} Width:{nativeAdPosition.Width}");
|
Debug.Log($"luojian admob native ad 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("ca-app-pub-3940256099942544/2247696110"))
|
if (AdsSDKManager.Instance.IsNativeAdReady("ca-app-pub-3940256099942544/2247696110"))
|
||||||
{
|
{
|
||||||
// var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle
|
// var nativeAdPosition = NativeAdPosition.Create(new NativeTemplateStyle
|
||||||
|
|
Loading…
Reference in New Issue