unity和android相互调用

本文介绍了两种Unity中调用Android代码的方法。方法一使用LocalRef自动回收,但易触发LocalRef数量限制Bug。方法二手动管理LocalRef,虽代码复杂,但避免了溢出问题。建议参数和返回值使用Byte或Byte[]。

Unity调用Android代码

方法一:

//using让 Local Ref 回收
using(AndroidJavaClass javaClazz = new AndroidJavaClass("com.ddianle.Bitmap"))
{
    int res = javaClazz.CallStatic<int>("DrawText", 'a');//调用静态方法
}

public static int DrawText(char c)
{
     return 1;
}

Unity调用Java方法时,参数或者返回值最好是Byte或者Byte[]。
此方法的缺点是在Android平台容易造成Local Ref > 512的溢出Bug。(因为自己无法手动删除Local Ref)

方法二:

public static byte[] DrawText(String str, byte[] b)
{
        return null;
}

IntPtr clazzPtr = AndroidJNI.FindClass("com/ddianle/Bitmap");
IntPtr methodPtr = AndroidJNI.GetStaticMethodID(clazzPtr, "DrawText", "(Ljava.lang.String;[B)[B");
    
//Two param
IntPtr v1 = AndroidJNI.NewStringUTF("abc");
jvalue j1 = new jvalue();
j1.l = v1;
        
IntPtr v2 = AndroidJNI.ToByteArray(Encoding.Default.GetBytes("abc"));
jvalue j2 = new jvalue();
j1.l = v2;
IntPtr resPtr = AndroidJNI.CallStaticObjectMethod(clazzPtr, methodPtr, new jvalue[]{j1, j2 });//调用
byte[] b = AndroidJNI.FromByteArray(resPtr);
//...
        
//删除Local Ref。methodPtr不需要手动删除,因为它不是一个jobject对象。   
AndroidJNI.DeleteLocalRef(clazzPtr);
AndroidJNI.DeleteLocalRef(v1);
AndroidJNI.DeleteLocalRef(v2);
AndroidJNI.DeleteLocalRef(resPtr);

该方法可以手动的删除Local Ref,不过代码比较繁琐.

Android调用Unity代码

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值