当前位置:   article > 正文

【Unity嵌入Android原生工程】_unity 嵌入android

unity 嵌入android


工作需要嵌入原生工程,并实现热更,记录一下
工具,Unity2023.3.14,Android Studio 2022.3.1 patch3
Unity嵌入Andorid原理就是把Unity导出的Andorid项目当成一个module导入原生工程里面,从而实现嵌入。
前面有不少教程,但是总有漏掉那么一两部,要么作者没写,要么没有明确标注,踩了两天坑,发了这个想对自己看的懂的教程,自己踩的坑,记录一下

本章学习,Unity模块嵌入Android## 标题

本章最主要学习Unity模块嵌入Android原生工程,大致就是分为四个步骤,Unity导出Android工程,Android studio创建android工程,Unity嵌入Android工程。Android原生代码跳转到Unity场景

Unity导出Android工程

  1. 新建Unity项目,创建一个Image放到创建里面,作为后面我们跳转的标识在这里插入图片描述
  2. 设置在这里插入图片描述
  3. 导出
    在这里插入图片描述

如此导出便完成了。

创建Android Studio工程

在这里插入图片描述
在这里插入图片描述

Unity嵌入到Andorid Studio

打开之前打包出来的Unity工程包,找到
在这里插入图片描述
复制里面的文件夹到
在这里插入图片描述
2. 打开Android studio
在这里插入图片描述
导入
在这里插入图片描述

导入之后报错,提示在这里插入图片描述
添加

unityStreamingAssets=.unity3d, google-services-desktop.json, google-services.json, GoogleService-Info.plist

到gradle.properties
在这里插入图片描述
发现继续报错,找到unityLibrary目录下的build.gradle文件,添加

namespace = "com.unity3d.player"
  • 1

在这里插入图片描述
点击
在这里插入图片描述
运行成功,这个时候Unity就嵌入到Android工程了
打开App目录下下的main/java MainActivity文件
在这里插入图片描述

Android原生代码跳转到Unity场景

打开app目录下的build.gradle文件
添加代码

implementation project(path: ':unityLibrary')
  • 1

在这里插入图片描述

打开app目录下的MainActivity文件
在这里插入图片描述

        setContentView(R.layout.maina)
        val b = findViewById(R.id.button2) as Button
        b.setOnClickListener {
            Toast.makeText(
                this@MainActivity,
                "点击了按钮",
                Toast.LENGTH_LONG
            ).show()
            val intent = Intent(
                this@MainActivity,
                UnityPlayerActivity::class.java
            )
            startActivity(intent)
        }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

复制到上图所示的地方去
会发现缺失,找不到UnityPlayerActivity,在文件头部添加

import android.content.Intent
import android.os.Bundle
import android.widget.Button
import android.widget.Toast
import com.unity3d.player.UnityPlayerActivity
  • 1
  • 2
  • 3
  • 4
  • 5

在这里插入图片描述

在res目录下找到layout文件夹,如果没有则自行创建文件夹,

在这里插入图片描述
取名为maina.xml
复制代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <Button
        android:id="@+id/button2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Button" />
</LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

最后会呈现如下效果
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/810476
推荐阅读
相关标签
  

闽ICP备14008679号