Unity-WebGL加载AB包

一、前景回顾

上文写到PC、IOS、Android项目加载ab包资源,地址:

http://t.csdnimg.cn/P2fgTicon-default.png?t=N7T8http://t.csdnimg.cn/P2fgT

二、WebGL打包AB包

打包的步骤和上文中的操作相同,唯一的不同就是在Build页面里Build Target选择WebGL。

 

三、WebGL加载AB包 

(1)内置渲染管线

当项目使用内置渲染管线时,所有材质的Shader为Standard。

(2)通用渲染管线URP

1、当项目为URP时,首先需要在Package Manager里导入Universal RP,如图

2、Create—Rendering—URP Assets(with Universal Render)来创建URP配置文件,如图

3、在Edit—Project Settings—Graphics,修改为刚才创建的文件。这一步操作完成后,场景中的物体材质可能会变成了洋红色。此时项目已由内置着色器转换为URP着色器。

4、Edit—Render Pipeline—Universal Render Pipeline—Upgrade Project Materials to UniversalRP Materials更新材质。 也可以手动修改材质的Shader为Universal Render Pipeline/Lit。如图

5、在软件中运行项目,加载出来的材质是洋红色的(不用担心)。

6、导出项目在本地浏览器加载,加载出来的模型材质是正常的。

四、加载ab包脚本

WebGL使用UnityWebRequest加载依赖和ab包
   
    //主包
    private AssetBundle abMain = null;

    //依赖
    private AssetBundleManifest abMainfest = null;

    //缓存字典,防止多次加载
    private Dictionary<string, AssetBundle> abDic = new Dictionary<string, AssetBundle>();

    /// <summary>
    /// 平台对应的路径
    /// </summary>
    private string PathURL = Application.streamingAssetsPath + "/";

    /// <summary>
    /// 平台对应的主包名称
    /// </summary>
    private string MainABName = "WebGL";


    //UnityWebRequest加载依赖
    private IEnumerator LoadDependences(string abName)
    {
        //加载主包
        if (abMain == null)
        {
            UnityWebRequest abRequest = UnityWebRequestAssetBundle.GetAssetBundle(PathURL + MainABName);
            yield return abRequest.SendWebRequest();
            abMain = DownloadHandlerAssetBundle.GetContent(abRequest);
            //获取主包下的AssetBundleManifest资源文件(存有依赖信息)
            abMainfest = abMain.LoadAsset<AssetBundleManifest>("AssetBundleManifest");
        }
        //加载依赖
        AssetBundle ab = null;
        string[] dependences = abMainfest.GetAllDependencies(abName);
        if (dependences.Length > 0)
        {
            for (int i = 0; i < dependences.Length; i++)
            {
                if (!abDic.ContainsKey(dependences[i]))
                {
                    UnityWebRequest DepRequest = UnityWebRequestAssetBundle.GetAssetBundle(PathURL + dependences[i]);
                    yield return DepRequest.SendWebRequest();
                    ab = DownloadHandlerAssetBundle.GetContent(DepRequest);
                    abDic.Add(dependences[i], ab);
                }
            }
        }
    }

    //UnityWebRequest加载
    public void LoadByRequest<T>(string abName, string resName, UnityAction<T> callBack) where T : Object
    {
        StartCoroutine(ReallyLoadByRequest<T>(abName, resName, callBack));
    }
    private IEnumerator ReallyLoadByRequest<T>(string abName, string resName, UnityAction<T> callBack) where T : Object
    {
        yield return StartCoroutine(LoadDependences(abName));
        if (!abDic.ContainsKey(abName))
        {
            UnityWebRequest abRequest3 = UnityWebRequestAssetBundle.GetAssetBundle(PathURL + abName);
            yield return abRequest3.SendWebRequest();
            AssetBundle ab = DownloadHandlerAssetBundle.GetContent(abRequest3);
            abDic[abName] = ab;
        }
        T loadedResource = abDic[abName].LoadAsset<T>(resName);
        callBack(loadedResource as T);
    }

    //单个包卸载
    public void UnLoad(string abName)
    {
        if (abDic.ContainsKey(abName))
        {
            abDic[abName].Unload(false);
            //注意缓存需一并移除
            abDic.Remove(abName);
        }
    }
    //所有包卸载
    public void UnLoadAll()
    {
        AssetBundle.UnloadAllAssetBundles(true);
        //注意清空缓存
        abDic.Clear();
        abMain = null;
        abMainfest = null;
    }

测试
    
    public Transform[] bigRackPos;    
    public Transform[] smallRackPos;

    public void TestOne()
    {
        LoadByRequest<GameObject>("bigrack", "BigRack", (obj) =>
        {
            for (int i = 0; i < bigRackPos.Length; i++)
            {
                //实例化预设
                Instantiate(obj, bigRackPos[i].position, Quaternion.identity);
            }
        });
    }

    public void TestTwo()
    {
        LoadByRequest<GameObject>("smallrack", "SmallRack", (obj) =>
        {
            for (int i = 0; i < smallRackPos.Length; i++)
            {
                //实例化预设
                Instantiate(obj, smallRackPos[i].position, Quaternion.Euler(0, 90, 0));
            }
        });
    }

五、求解

在WebGL项目中加载ab包,不能同时加载加载多个ab包。
测试代码中,我写了两个方法来加载两个ab包,如果我把这两个方法写在Start方法里同时运行,就会报错并且第二个方法加载不出来。
    private void Start()
    {
        TestOne();
        TestTwo();
    }
错误显示
The AssetBundle 'G:/Unity Project/cgf/MyScene/NormalAssetBundle/Assets/StreamingAssets/WebGL' can't be loaded because another AssetBundle with the same files is already loaded.

代码有问题,路过的大佬帮忙纠正一下,好人一生平安。

  • 19
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue-Unity-WebGL 是一个具有极高可扩展性和灵活性的 Unity3D web 端开发框架,它将 Vue.js 与 Unity Web Player 和 WebGL 等技术相结合,为开发者提供了最佳的解决方案。 Vue-Unity-WebGL 框架具有很高的兼容性和易用性,开发者可以更加灵活地应用该框架来定制自己的项目。由于该框架具备了许多优秀的特性,如自适应布局、多平台支持等,使得开发者可以轻松地实现用户体验和开发效率的提升。此外,Vue-Unity-WebGL 框架不仅提供了可视化开发工具,还提供了完整的运行环境,为开发者提供了优秀的开发体验。 Vue-Unity-WebGL 框架的另一个重要特点是其大量的插件与扩展功能,这些插件和扩展可以为项目的开发和管理提供坚强的技术支持。比如,通过 vue-router 可以控制路由,Vue-Unity-WebGL 可以协作处理组件数据和 Unity3D 渲染等复杂的操作,而 Vuex 则可以使开发者方便地处理应用数据流和组件状态的管理。这些插件和扩展功能极大地提高了 Vue-Unity-WebGL 框架的可扩展性和灵活性,使得开发者可以更加容易地进行定制。 综上所述,Vue-Unity-WebGL 框架是一个快速、可靠且强大的解决方案,这使得开发者能够轻松地编写出高质量的 Unity3D web 应用程序。该框架具有大量的功能,实现可扩展性、灵活性、易用性和可维护性,比其他框架更具有竞争力。在未来的发展中,Vue-Unity-WebGL 框架将会被更多的开发者喜爱和应用,并在技术社区中拥有更广泛的影响力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值