Flutter集成Unity

前言:

最近做项目时需要用到Flutter来做跨平台开发,但是项目中又用到了虚拟场景,这样一来就涉及到了Unity,那么总结下来便是用AndroidStudio来创建Flutter项目,将Unity项目嵌入到Flutter项目中,本篇文章就给大家分享一下Flutter集成Unity的详细过程,下一篇再给大家分享 Flutter与Unity之间的通信;

效果演示

Flutter集成Unity效果图

软件环境:

AndroidStudio创建Flutter项目   

Unity3D创建Unity项目

还需准备一个插件: Flutter-Unity widget

整合Flutter和Unity的关键组件:Flutter-Unity widget

Flutter在构建跨平台移动应用方面越来越受欢迎,Unity非常适用于构建增强现实(AR)和虚拟现实(VR);

Flutter-Unity widget是整合Flutter与Unity的一个很关键的组件,它允许开发者在Flutter Widget内嵌入Unity应用;

Flutter-Unity widget插件的重要能力之一便是能够提供Flutter和Unity之间的双向通信;

一. Flutter项目

1. 准备一个Flutter项目

打开你的Android Studio,在AS中创建一个Flutter项目,取名为FlutterDemo,如下图所示:

 再点击Next,为Flutter项目取名,选择Flutter项目的存储位置,选择Android的开发语言,点击Finish便可以等待项目完成

 

2. 为Flutter项目添加ndk

3. 为Flutter项目添加依赖

4. Flutter项目中建立一个存放Unity项目的文件夹

点击New——> Directory,然后为文件夹取名

这个文件夹的作用时存放待会创建的Unity项目

到此为止,Flutter项目这边的工作告一段落了;然后,我们需要去创建一个Unity项目,创建Unity项目的存放路径就是Flutter项目刚刚建立的文件夹;

二. Unity项目

1. 准备一个Unity项目

注意一下Unity的存放路径不要搞错啊,Unity项目的名字可以随意的

2. 查看Unity的NDK

这个ndk就是上文Flutter项目中需要的ndk路径

3. 修改Unity的打包设置

切换平台,添加场景

 选择打包方式和打包设置

4. 将Flutter-Unity Widget插件包导入到Unity项目中

Flutter-Unity widget下载地址在文章前面提供了,大家可以去下载,小编这里就带大家使用第一个包吧

点击Import,等待Flutter-Unity Widget包导入即可 

选择升级过时API,等待修改完成即可

5. 修改Build脚本

打开刚刚导入的Package包中的Build脚本,并对其进行修改

在Build脚本中的DoBuildAndroid方法中进行修改

在Build脚本中的BuildIOS方法中修改代码 ,修改完成后,记得保存,Unity的脚本修改都不会自动保存的

6. 打包Export Android项目

点击Flutter后,再点击Export Android ,然后等待进度条加载完成即可,因为我们的Unity项目是建立在Flutter项目的一个文件夹中的,所以打包出来的unitylibrary会自动加载到Flutter项目中 ;

到此为止,Unity项目的配置就完成了

三. 将Unity项目嵌入Android项目

1. 检查刚刚Unity项目的Export Android是否成功了

2. 配置Android

将android / app / build.gradle中的minSdkVersion  ,tartgetSdkVersion 跟 android / unityLibrary / build.gradle的一致

comileSdkVersion改为33 ,这是因为Flutter-Unity Widget需要这么高的版本才能支持

3. gardle.properties 添加配置信息

4. AndroidManifest.xml中添加权限

 在android / app / src / main / AndroidManifest.xml中添加权限,如下图所示

5. 修改main.dart文件

接下来我们为Unity编写入口程序

直接给大家上代吧,把如下代码赋值到大家的main.dart文件中

import 'package:flutter/material.dart';
import 'package:flutter_unity_widget/flutter_unity_widget.dart';


void main() {
  runApp(MaterialApp(
      home: UnityDemoScreen()
  ));
}

class UnityDemoScreen extends StatefulWidget {

  UnityDemoScreen() : super();

  @override
  _UnityDemoScreenState createState() => _UnityDemoScreenState();
}

class _UnityDemoScreenState extends State<UnityDemoScreen>{
  static final GlobalKey<ScaffoldState> _scaffoldKey =
  GlobalKey<ScaffoldState>();
  late UnityWidgetController _unityWidgetController;

  Widget build(BuildContext context) {

    return Scaffold(
      key: _scaffoldKey,
      body: SafeArea(
        bottom: false,
        child: WillPopScope(
          onWillPop: () async{
            // Pop the category page if Android back button is pressed.
            return true;
          },
          child: Container(
            color: Colors.blue,
            child: UnityWidget(
              onUnityCreated: onUnityCreated,
            ),
          ),
        ),
      ),
    );
  }

  // Callback that connects the created controller to the unity controller
  void onUnityCreated(controller) {
    this._unityWidgetController = controller;
  }
}

四. 效果演示

到此为止,Flutter集成Unity便已经完成了,接下来给大家看一下效果视频

Flutter集成Unity

要是有疑问大家可以加我微信详聊 yf1553653788,下一篇再给大家分享 Flutter与Unity之间的通信;

  • 211
    点赞
  • 238
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 159
    评论
Flutter是一种跨平台移动应用开发框架,可以用来创建高质量的Android和iOS应用程序。它使用Dart语言编写,提供了丰富的UI组件和强大的渲染引擎,可以快速构建出现代化的应用界面。 AR(增强现实)是一种技术,通过在真实世界中叠加虚拟信息,将虚拟和真实的世界进行有效整合,使用户可以与现实环境进行交互。AR技术可以在移动设备上实现,使用户可以通过手机或平板电脑参与到虚拟场景中。 Unity是一种用于创建游戏和虚拟现实应用程序的跨平台开发环境,支持多种平台如Windows、Android、iOS等。Unity提供了强大的3D渲染引擎和可视化开发工具,使开发者可以轻松地创建出色的游戏和虚拟现实应用。 Flutter与AR和Unity是两个不同的技术,分别用于移动应用开发和游戏开发。如果要将它们结合使用,可以通过在Flutter应用中集成Unity引擎来实现。 例如,可以使用Flutter创建一个具有界面和用户交互功能的应用程序,然后在其中集成Unity引擎,以实现更复杂和沉浸式的游戏或虚拟现实体验。这样,开发者可以充分利用Flutter的跨平台开发能力和AR/VR开发的强大功能,同时为用户提供优秀的用户界面和丰富的交互体验。 总结起来,虽然Flutter、AR和Unity是不同的技术,但结合它们可以实现更丰富和多样化的移动应用开发。Flutter可以提供强大的UI和跨平台开发能力,AR和Unity可以为应用程序添加沉浸式的增强现实和虚拟现实功能。将它们结合使用,可以创造出更具创新性和丰富性的移动应用体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 159
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

认真的小尹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值