当前位置: 首页 > article >正文

AeestBundle打包总结

一、设置assetBundleName如果没有设置AssetBundleName会打包所有的Assets下的资源如果设置就只打包设置了名字的资源1、在unity编辑器界面手动设置输入所需的AssetBundle名称。请注意AssetBundle名称确实支持一种类型的文件夹结构这取决于您键入的内容。要添加子文件夹将文件夹名称以“/”分隔。例如:AssetBundle名称“environment / forest”将在environment子文件夹下创建一个名为forest的包2、遍历所有要打包的资源通过代码修改assetBundleName第一步先获取你要打包的资源的完整目录方法1先用Selection.objects返回场景中所有的对象然后用AssetDatabase.GetAssetPath(selected)获取对象完整目录方法2用AssetPostprocessor的OnPostprocessAllAssets方法方法3用IO流的DirectoryInfo.GetFileSystemInfos()和FileInfonfo获取完整目录这种方法要注意获取到的目录如果是”\”或者”//”要替换为“/”第二步用AssetImporterasset AssetImporter.GetAtPath(path);方法获取AssetImporter第三步用asset.assetBundleName “text”设置AssetBundleName有以下三种获取目录然后设置assetBundleName的方法方法1 //Selection.objects返回场景中所有的对象 Object[] selects Selection.objects; foreach (Object selected in selects) { //返回所有对象相对于工程目录的存储路径如Assets/_Scenes/Main.unity string path AssetDatabase.GetAssetPath(selected); //把一个目录的对象检索为AssetImporter AssetImporter asset AssetImporter.GetAtPath(path); asset.assetBundleName selected.name; //设置Bundle文件的名称 asset.assetBundleVariant unity3d;//设置Bundle文件的扩展名 asset.SaveAndReimport(); } AssetDatabase.Refresh(); 方法2 using UnityEngine; using System.Collections; using UnityEditor; //文件描述:自动设置Assetbundle名字为文件夹名_文件名.unity3d; public class AutoSetTextureUISprite : AssetPostprocessor { static void OnPostprocessAllAssets(string[] importedAssets, string[] deletedAssets, string[] movedAssets, string[] movedFromAssetPaths) { foreach (var str in importedAssets) { if (!str.EndsWith(.cs)) { AssetImporter importer AssetImporter.GetAtPath(str); importer.assetBundleName str; } } foreach (var str in deletedAssets) { if (!str.EndsWith(.cs)) { AssetImporter importer AssetImporter.GetAtPath(str); importer.assetBundleName str; } } for (var i 0; i movedAssets.Length; i) { //Debug.Log(Moved Asset: movedAssets[i] from: movedFromAssetPaths[i]); } } } 方法3 using UnityEngine; using System.Collections; using UnityEditor; using System.IO; /// summary /// 把Resource下的资源打包成.unity3d 到StreamingAssets目录下 /// /summary public class Builder : Editor { public static string sourcePath Application.dataPath /Resources; const string AssetBundlesOutputPath Assets/StreamingAssets; //[MenuItem(Tools/AssetBundle/Build)] public static void BuildAssetBundle() { ClearAssetBundlesName(); Pack(sourcePath); string outputPath Path.Combine(AssetBundlesOutputPath, Platform.GetPlatformFolder(EditorUserBuildSettings.activeBuildTarget)); if (!Directory.Exists(outputPath)) { Directory.CreateDirectory(outputPath); } //根据BuildSetting里面所激活的平台进行打包 BuildPipeline.BuildAssetBundles(outputPath, 0, EditorUserBuildSettings.activeBuildTarget); AssetDatabase.Refresh(); Debug.Log(打包完成); } /// summary /// 清除之前设置过的AssetBundleName避免产生不必要的资源也打包 /// 之前说过只要设置了AssetBundleName的都会进行打包不论在什么目录下 /// /summary static void ClearAssetBundlesName() { int length AssetDatabase.GetAllAssetBundleNames().Length; Debug.Log(length); string[] oldAssetBundleNames new string[length]; for (int i 0; i length; i) { oldAssetBundleNames[i] AssetDatabase.GetAllAssetBundleNames()[i]; } for (int j 0; j oldAssetBundleNames.Length; j) { AssetDatabase.RemoveAssetBundleName(oldAssetBundleNames[j], true); } length AssetDatabase.GetAllAssetBundleNames().Length; Debug.Log(length); } static void Pack(string source) { DirectoryInfo folder new DirectoryInfo(source); FileSystemInfo[] files folder.GetFileSystemInfos(); int length files.Length; for (int i 0; i length; i) { if (files[i] is DirectoryInfo) { Pack(files[i].FullName); } else { if (!files[i].Name.EndsWith(.meta)) { file(files[i].FullName); } } } } static void file(string source) { string _source Replace(source); string _assetPath Assets _source.Substring(Application.dataPath.Length); string _assetPath2 _source.Substring(Application.dataPath.Length 1); //Debug.Log (_assetPath); //在代码中给资源设置AssetBundleName AssetImporter assetImporter AssetImporter.GetAtPath(_assetPath); string assetName _assetPath2.Substring(_assetPath2.IndexOf(/) 1); assetName assetName.Replace(Path.GetExtension(assetName), .unity3d); //Debug.Log (assetName); assetImporter.assetBundleName assetName; } static string Replace(string s) { return s.Replace(\\, /); } } public class Platform { public static string GetPlatformFolder(BuildTarget target) { switch (target) { case BuildTarget.Android: return Android; case BuildTarget.iOS: return IOS; case BuildTarget.WebPlayer: return WebPlayer; case BuildTarget.StandaloneWindows: case BuildTarget.StandaloneWindows64: return Windows; case BuildTarget.StandaloneOSXIntel: case BuildTarget.StandaloneOSXIntel64: case BuildTarget.StandaloneOSXUniversal: return OSX; default: return null; } } }二、构建AssetBundle包1、在Assets中创建一个名为Editor的文件夹并将一个脚本放在文件夹中2、类要继承Editor引用命名空间using UnityEditor;3、创建菜单目录[MenuItem(Assets/Build AssetBundles)]4、调用打包方法用AssetBundleBuild类的方法BuildAssetBundles(string outputPath, BuildAssetBundleOptions assetBundleOptions, BuildTarget targetPlatform);或者​ BuildAssetBundles(string outputPath, AssetBundleBuild[] builds, BuildAssetBundleOptions assetBundleOptions, BuildTarget targetPlatform); ​参数说明outputPath:打包Bundle后存储的目录如Assets/AssetBundles这个文件夹不会自动创建如果它不存在的话函数将会失败Directory.Exists(string path)判断目录是否存在Directory.CreateDirectory(string path)创建目录BuildAssetBundleOptionsBundle打包方式none没有任何特殊选项 UncompressedAssetBundle在构建Bundle时不要压缩数据等等BuildTarget构建平台如iphone,windows,android等AssetBundleBuild[]这个类与BuildAssetBundles一起使用。指定一个Bundle包的名称assetBundleName和它将包含的资源(如多张图片、音频等)的名称。被传递给函数的AssetBundleBuild[]元素数组被称为“构建映射”并作为指定编辑器包内容的替代方法。变量addressableNames返回所有的addressableName数组assetBundleNameAssetBundle的名字assetBundleVariantAssetBundle的扩展名如.unityAssetBundle指定属于一个addressableName名字的所有资源名字是一个数组也就是一个addressableName名字下包含的所有资源名字AssetBundleManifest包含所有创建Bundle包信息⑴公开方法GetAllAssetBundles返回所有的assetbundlenames是一个string[]数组GetAllAssetBundlesWithVariant返回所有使用给定扩展名的assetbundlenames是一个string[]数组GetAllDependencies(stringassetBundleName);获取所有与指定AssetBundle包存在依赖关系的AssetBundless。也就是给一个assetBundleName获取所有与他有关系的assetBundleName返回一个string[]数组GetDirectDependencies(stringassetBundleName)获取所有与指定AssetBundle包存在直接联系的AssetBundless。也就是给一个assetBundleName获取所有与他有直接关系的assetBundleName返回一个string[]数组第一个方法 // 创建一个Windows AssetBundle包 using UnityEngine; using UnityEditor; using System.IO; public class BuildAssetBundlesExample : MonoBehaviour { //创建编辑器菜单目录 [MenuItem(Example/Build Asset Bundles)] static void BuildABs() { //将这些资源包放在一个名为ABs的目录下 string assetBundleDirectory Assets/ABs; //如果目录不存在就创建一个目录 if (!Directory.Exists(assetBundleDirectory)) { Directory.CreateDirectory(assetBundleDirectory); } BuildPipeline.BuildAssetBundles(assetBundleDirectory, BuildAssetBundleOptions.None, BuildTarget.StandaloneWindows); } } 第二个方法 using UnityEngine; using UnityEditor; using System.IO; public class BuildAssetBundlesBuildMapExample : MonoBehaviour { [MenuItem(Example/Build Asset Bundles Using BuildMap)] static void BuildMapABs() { // 创建映射数组 AssetBundleBuild[] buildMap new AssetBundleBuild[2]; //修改assetBundleName第一个 buildMap[0].assetBundleName enemybundle; //assetBundleName enemybundle下的所有资源名称数组 string[] enemyAssets new string[2]; enemyAssets[0] Assets/Textures/char_enemy_alienShip.jpg; enemyAssets[1] Assets/Textures/char_enemy_alienShip-damaged.jpg; buildMap[0].assetNames enemyAssets; //修改assetBundleName第二个 buildMap[1].assetBundleName herobundle; //assetBundleName herobundle下的所有资源名称数组 string[] heroAssets new string[1]; heroAssets[0] char_hero_beanMan; buildMap[1].assetNames heroAssets; //创建Bundle包 //将这些资源包放在一个名为ABs的目录下 string assetBundleDirectory Assets/ABs; //如果目录不存在就创建一个目录 if (!Directory.Exists(assetBundleDirectory)) { Directory.CreateDirectory(assetBundleDirectory); } BuildPipeline.BuildAssetBundles(assetBundleDirectory, BuildAssetBundleOptions.None, BuildTarget.StandaloneWindows); } }三、上传AssetBundle到服务器四、把AssetBundle放到本地五、操作AssetBundle1、从磁盘目录加载AssetBundle包⑴AssetBundle放在本地public staticAssetBundle LoadFromFile(stringpath,uintcrc 0,ulongoffset 0);说明从path目录同步加载AssetBundle返回类型AssetBundleLoadFromFileAsync是异步加载参数path 读取AssetBundle的目录crc 校验用参数offset这个值指定从哪里开始读取AssetBundle通常为0⑵ AssetBundle放在网络引用usingUnityEngine.Networking;命名空间UnityWebRequest.GetAssetBundle()方法2、加载AssetBundle包之后加载包内资源注意加载要用协程否则你不知道是否加载完毕⑴加载一个资源AssetBundle类public ObjectLoadAsset(string name);从AssetBundle包中加载名字为name的资源返回objectpublic Object LoadAsset(string name, Type type);加载一个包内名字为name类型为type的资源public T LoadAsset(string name); //也是加载名字为name类型为T的资源⑵加载包内的多个资源AssetBundle类public Object[]LoadAllAssets(Type type);加载包内所有类型为type的资源public Object[]LoadAllAssets();加载包内的所有资源public T[]LoadAllAssets(); //也是加载类型为T的资源⑶备注上面的方法是同步加载还有异步加载方法LoadAllAssetsAsyncLoadAssetAsync3、从包内加载资源以后可以对这个对象进行各种操作了4、备注知识点⑴Path.Combine(string, string)连接两个字符串⑵Application访问应用程序运行时数据Application.streamingAssetsPath输出值得注意的是如果在PC上使用时需要在每个文件夹前加入斜杠如string uri file:/// Application.dataPath /AssetBundles/ assetBundleName;//示例 using UnityEngine; using System.Collections; using System.IO; public class LoadFromFileExample : MonoBehaviour { void Start() { //从文件夹里加载包 var myLoadedAssetBundle AssetBundle.LoadFromFile(Path.Combine(Application.streamingAssetsPath, myassetBundle)); if (myLoadedAssetBundle null) { Debug.Log(Failed to load AssetBundle!); return; } //从Bundle包中加载名字为MyObject的资源加载为GameObject var prefab myLoadedAssetBundle.LoadAssetGameObject(MyObject); //实例化 Instantiate(prefab); //卸载包中资源的内存 myLoadedAssetBundle.Unload(false); } }5、AssetBundle放在网络⑴创建一个UnityWebRequest通过HTTP GET下载一个Unity资产包引用usingUnityEngine.Networking;命名空间UnityWebRequest.GetAssetBundle()方法public static UnityWebRequestGetAssetBundle(string uri, uint crc);public static UnityWebRequestGetAssetBundle(string uri, uint version, uint crc);public static UnityWebRequestGetAssetBundle(string uri, Hash128 hash, uint crc);public static UnityWebRequestGetAssetBundle(string uri, CachedAssetBundle cachedAssetBundle, uint crc);返回值UnityWebRequest参数uriAssetsBundle包的网络地址可以是本地file:crc:0,如果不为0将会进行校验version一个整数版本号hash一个版本散列cachedAssetBundle用于将给定版本的AssetBundle下载到自定义缓存路径的结构⑵处理上一步的UnityWebRequest用DownloadHandlerAssetBundle.GetContent()方法public static AssetBundle GetContent(Networking.UnityWebRequest www);www就是上一步处理的UnityWebRequestAssetBundle返回值类型IEnumerator InstantiateObject() { string uri file:/// Application.dataPath /AssetBundles/ assetBundleName; UnityEngine.Networking.UnityWebRequest request UnityEngine.Networking.UnityWebRequest.GetAssetBundle(uri, 0); yield return request.Send(); AssetBundle bundle DownloadHandlerAssetBundle.GetContent(request); GameObject cube bundle.LoadAssetGameObject(Cube); GameObject sprite bundle.LoadAssetGameObject(Sprite); Instantiate(cube); Instantiate(sprite); }六、完整例子using System.Collections; using System.Collections.Generic; using UnityEngine; using System.IO; using UnityEngine.UI; using UnityEngine.Networking; public class NewBehaviourScript : MonoBehaviour { Image image1; Image Image2; void Start () { image1 GameObject.Find(Image (1)).GetComponentImage(); Image2 GameObject.Find(Image (2)).GetComponentImage(); StartCoroutine(InstantiateObject()); StartCoroutine(InstantiateObjects()); } //一个包有多个资源 IEnumerator InstantiateObjects() { //texture是一个文件夹里面放了多张图片 string uri file:/// Application.dataPath /AssetsBundles/texture; UnityWebRequest request UnityWebRequest.GetAssetBundle(uri, 0); yield return request.Send(); AssetBundle bundle DownloadHandlerAssetBundle.GetContent(request); Object[] obj bundle.LoadAllAssets(typeof(Sprite)); Sprite[] sprite new Sprite[obj.Length]; for (int i 0; i obj.Length; i) { sprite[i] obj[i] as Sprite; } this.gameObject.GetComponentImage().sprite sprite[0]; image1.sprite sprite[1]; //string path Application.dataPath /AssetsBundles/texture; //AssetBundle assetbundle AssetBundle.LoadFromFile(path, 0, 0); //yield return assetbundle; //if (assetbundle null) //{ // print(加载Bundle为空); //} //加载类型为sprite的图片否则一张图片会加载成两个 //Object[] obj assetbundle.LoadAllAssets(typeof(Sprite)); //Sprite[] sprite new Sprite[obj.Length]; //for (int i 0; i obj.Length; i) //{ // sprite[i] obj[i] as Sprite; //} //this.gameObject.GetComponentImage().sprite sprite[0]; //image1.sprite sprite[1]; } //一个包有一个资源 IEnumerator InstantiateObject() { //用UnityWebRequest读取 //string uri file:/// Application.dataPath /AssetsBundles/gress; //UnityWebRequest request UnityWebRequest.GetAssetBundle(uri, 0); //yield return request.Send(); //AssetBundle bundle DownloadHandlerAssetBundle.GetContent(request); //GameObject cube bundle.LoadAssetGameObject(gress); //Sprite sprite bundle.LoadAssetSprite(gress); //this.gameObject.GetComponentImage().sprite sprite; //用AssetBundle读取 string path Application.dataPath /AssetsBundles/gress; AssetBundle assetbundle AssetBundle.LoadFromFile(path, 0, 0); yield return assetbundle; if (assetbundle null) { print(加载Bundle为空); } Sprite sprite assetbundle.LoadAssetSprite(gress); Image2.sprite sprite; } // Update is called once per frame void Update () { } }七、AssetBundle Manager管理工具AssetBundle Manager是一个由Unity制作的工具它可以使AssetBundle更加高效。下载并导入AssetBundle Manager包不仅增加了加载和使用AssetBundle的新API而且还添加了一些编辑器功能来简化工作流。这个功能可以在Assets菜单选项下找到。

相关文章:

AeestBundle打包总结

一、设置assetBundleName 如果没有设置AssetBundleName,会打包所有的Assets下的资源,如果设置,就只打包设置了名字的资源 1、在unity编辑器界面手动设置 输入所需的AssetBundle名称。请注意,AssetBundle名称确实支持一种类型的文…...

基于深度学习的航空遥感点云分类:解锁三维城市模型构建新可能

DL00279-基于深度学习的航空遥感点云分类完整代码python 由于其在能源评估、可视性分析、紧急响应、三维地籍、城市规划、变化检测、导航等各种应用中的有用性,近几十年来,三维城市模型变得越来越重要。 点云是生成逼真城市模型的主要数据来源之一。 除了…...

【教程】2026年OpenClaw(Clawdbot)腾讯云零门槛3分钟搭建指南

【教程】2026年OpenClaw(Clawdbot)腾讯云零门槛3分钟搭建指南。OpenClaw(前身为Clawdbot/Moltbot)作为开源、本地优先的AI助理框架,凭借724小时在线响应、多任务自动化执行、跨平台协同等核心能力,成为个人…...

5090 本地模型怎么选:在 openclaw / Agent 场景下,Nemotron 和 Qwen 该怎么取舍?

5090 本地模型怎么选:在 openclaw / Agent 场景下,Nemotron 和 Qwen 该怎么取舍? 导语 如果你手上已经有一张 5090,接下来真正的问题通常不是“还能不能跑本地模型”,而是: 到底该跑哪个模型,才…...

HunterPie配置深度解析:现代游戏覆盖层技术实战指南

HunterPie配置深度解析:现代游戏覆盖层技术实战指南 【免费下载链接】HunterPie-legacy A complete, modern and clean overlay with Discord Rich Presence integration for Monster Hunter: World. 项目地址: https://gitcode.com/gh_mirrors/hu/HunterPie-lega…...

Triton 九齿系列(三)《九齿二重:渐悟》

目录 九齿环境配置与基础概念 1. NineToothed Puzzles 2. 九齿张量基础 九齿核心三要素深入解析 1. 要素一:排布 2. 要素二:应用 3. 要素三:张量 总结 本文主要演示九齿如何简化并行编程。 九齿环境配置与基础概念 1. NineToothed …...

FANUC机器人位置变量PR[i]实战:从基础赋值到坐标系转换(含LPOS/JPOS案例)

FANUC机器人位置变量PR[i]实战:从基础赋值到坐标系转换(含LPOS/JPOS案例) 工业机器人编程中,位置变量的灵活运用直接决定了程序的效率和可维护性。作为发那科机器人系统的核心功能之一,位置寄存器(PR[i])不仅是存储坐标…...

详解 Vue.js 中的 $emit 与 $on:自定义事件的发布订阅模式

详解 Vue.js 中的 $emit 与 $on:自定义事件的发布订阅模式 在 Vue.js 的组件通信中,$emit 和 $on 是实现自定义事件发布订阅模式的核心方法。这种模式允许组件之间通过事件进行灵活的通信,特别适用于父子组件或非父子关系的组件间通信。本文将…...

跨平台算命APP源码开发:UniApp框架与微信小程序双端部署的命理服务解决方案

在移动互联网时代,命理服务与数字技术的融合催生了新型服务形态——跨平台算命APP。借助前沿的人工智能大语言模型(如GPT、DeepSeek等),算命APP将古老智慧与现代科技深度融合,通过精准的八字(四柱命理&…...

GLM-4.6V-Flash-WEB商业案例:电商商品图像智能描述与分类

GLM-4.6V-Flash-WEB商业案例:电商商品图像智能描述与分类 在电商行业蓬勃发展的今天,商品图像处理已成为提升转化率的关键环节。传统电商平台依赖人工编写商品描述和分类,不仅效率低下,还难以应对海量商品上架的需求。GLM-4.6V-F…...

GUI 之后,SaaS 该如何为 Agent 重写自己

从 CLI-Anything 现象看 bsin-paas 四块系统的 Agent 化设计CLI-Anything 在 GitHub 上拿到 15000 颗星的速度,让很多人感到意外。它做的事情说起来并不复杂:给任意桌面软件自动生成一套命令行接口,让 AI Agent 能直接用 CLI 操控 GIMP、Blen…...

定制化组装锂电池设备:精准匹配需求的技术实践

在新能源产业快速发展的背景下,锂电池作为核心储能元件,其应用场景已从消费电子扩展至新能源汽车、工业储能、便携式医疗设备等领域。不同行业对锂电池的性能参数、尺寸规格、安全标准提出了差异化要求,传统标准化电池产品难以满足多元化需求…...

StructBERT中文句子相似度实测:200字符长句、中英混排处理效果展示

StructBERT中文句子相似度实测:200字符长句、中英混排处理效果展示 1. 工具概述与核心能力 StructBERT是由百度研发的预训练语言模型,在中文自然语言处理任务中表现出色。本次实测的StructBERT文本相似度计算工具基于该模型实现,专门用于评…...

告别云端延迟:用TensorFlow Lite Micro在STM32上跑通你的第一个AI模型(附完整代码)

在STM32上部署TensorFlow Lite Micro模型的实战指南 从零开始:为什么选择嵌入式AI? 想象一下,你正在开发一款智能门锁,需要实时识别特定手势来解锁。如果每次识别都要把数据传到云端处理,不仅会有明显的延迟&#xff0…...

传统问卷设计VS书匠策AI:科研问卷的“智变”之旅

在科研的浩瀚海洋中,问卷设计宛如一座灯塔,为研究者指引着收集数据、探索真相的方向。然而,传统问卷设计方式常常让研究者们陷入繁琐的流程与无尽的纠结之中,从构思问题到排版布局,每一步都充满挑战。而如今&#xff0…...

具身智能:从感知到行动的认知闭环构建

在传统人工智能的叙事中,智能常被简化为“输入—处理—输出”的黑箱模型:给定数据,模型推理,给出答案。然而,这种“离身”(disembodied)的智能观正面临根本性质疑。越来越多的研究者意识到&…...

粒子群算法(PSO)优化层次分析法(AHP)的综合评价模型

粒子群算法(PSO)优化层次分析法(AHP)的综合评价模型 1. 引言 层次分析法(AHP)是一种多准则决策方法,通过构建判断矩阵并计算特征向量得到各因素的权重。但传统AHP依赖专家打分,判断矩阵可能不满足一致性要求(CR>0.1),且当指标较多时人工调整困难。粒子群算法(…...

告别复杂配置!SGLang-v0.5.6 Docker镜像快速部署,小白也能轻松搭建LLM服务

告别复杂配置!SGLang-v0.5.6 Docker镜像快速部署,小白也能轻松搭建LLM服务 1. 为什么选择SGLang? SGLang(Structured Generation Language)是一个专门为大语言模型(LLM)设计的推理框架。它解决…...

直流电机特性仿真:调压、弱磁、串电阻启动的Matlab GUI界面设计

直流电机特性仿真(调压 弱磁 串电阻启动)。 Matlab GUI界面设计。直流电机的仿真实验总带着点工程美学,尤其是当参数实时变化曲线在屏幕上扭出妖娆轨迹的时候。今天咱们抛开教科书上那些复杂的微分方程,直接在Matlab里搭个能互动的…...

OpenClaw 最热门使用技能 TOP 10

📊 核心技能榜1️⃣ Tavily Search — 搜索神器能干嘛:结构化搜索,Token消耗仅为传统的1/3谁在用:查技术文档、热点新闻、AI论文下载量:开发者最爱2️⃣ Playwright — 网页自动化能干嘛:模拟浏览器操作&am…...

告别重复劳作!n8n:技术团队的工作流自动化神器

作为技术从业者,你是否也曾陷入这样的困境:每天花费数小时在重复的数据同步、API调用、消息通知上,明明是可以自动化的机械操作,却占用了本该用于核心开发、创新突破的时间?从IT运维的员工入职流程,到安全团…...

腾讯云澄清高额费用系历史调用,但普通用户如何分清安装免费和使用收费的界限?这是否存在误导用户的嫌疑?

## 腾讯云“高额费用”事件:免费安装与付费使用的边界在哪里? 最近腾讯云因为“高额费用”的事情被推到了风口浪尖。官方解释说是历史调用导致的,但很多普通用户还是一头雾水:明明当初安装的时候说是免费,怎么突然就冒…...

SpringBoot策略模式实战:利用Map注入优雅管理多实现类

1. 为什么需要策略模式与Map注入 最近在重构一个图形处理系统时,我遇到了一个典型的多实现类问题。系统需要处理矩形、圆形、正方形等多种图形,每种图形都有自己的绘制逻辑。最初的做法是为每种图形创建单独的Service接口和实现类,结果代码迅…...

高仿网易云项目的笔记记录-day1

创建项目阶段使用先创建react项目再配置Ts的方法比较多弊端不推荐,所以采用直接配置Ts(通过react脚手架后同时配置TypeScript的支撑)create-react-app yingsheng_ts_react_music --template typescript——template typescript——&#xff…...

Fun-ASR-MLT-Nano-2512多语种识别实战:韩语K-pop歌词逐句转写演示

Fun-ASR-MLT-Nano-2512多语种识别实战:韩语K-pop歌词逐句转写演示 1. 项目概述 Fun-ASR-MLT-Nano-2512 是阿里通义实验室推出的多语言语音识别大模型,支持31种语言的高精度识别。这个模型特别适合处理各种语音转写场景,从日常对话到专业内容…...

Qwen2.5-VL-7B-Instruct开源大模型:16GB显存GPU实现企业级多模态推理

Qwen2.5-VL-7B-Instruct开源大模型:16GB显存GPU实现企业级多模态推理 想找一个既能看懂图片,又能和你流畅对话的AI助手,但被动辄几十GB的显存要求劝退?今天要介绍的Qwen2.5-VL-7B-Instruct,可能就是你在寻找的答案。 …...

从Java到AI大模型:一名传统开发者的转型之路

在技术浪潮翻涌的今天,人工智能大模型开发已成为最炙手可热的领域。作为一名Java开发者,我经常被问到:我们这些传统后端开发者,能否搭上这班AI快车?我的答案是:不仅能,而且我们有独特优势。 为什…...

使用Dify搭建工作流,实现自动化商品采集分析

最近用Dify做了一个工作流应用,可以实现自动化采集亚马逊商品信息,包括名称、价格、折扣、评分、评论等关键字段,然后使用DeepSeek对商品竞争力、价格、用户口碑进行分析,为跨境卖家提供一份完整的分析报告。 整个工作流搭建用到了…...

Compose 调用层参数设计规范(基于默认值复用原则)

Compose 调用层参数设计规范(基于默认值复用原则) 一、核心设计思想如果一个属性在大多数情况下都不变,就不应该在每个页面都去设置它。调用层(Page/Screen)职责:仅填充业务内容,不配置UI细节。…...

yz-bijini-cosplay创意应用:除了角色设计,它还能帮你做什么?

yz-bijini-cosplay创意应用:除了角色设计,它还能帮你做什么? 1. 项目概述:专为Cosplay优化的AI创作系统 yz-bijini-cosplay是一款基于通义千问Z-Image技术架构的AI图像生成系统,专门针对Cosplay创作场景进行了深度优…...