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

鸿蒙应用开发UI基础第二十六节:轻量级UI元素@Builder与@LocalBuilder区别示例演示

【学习目标】理解 Builder 设计初衷明确与 Component 核心差异掌握 Builder 两种定义方式、参数传递按值/按引用规则掌握 Builder 高级场景嵌套、this指向实战用法掌握 BuilderParam UI 插槽原理与使用方法实现组件 UI 内容灵活定制掌握 LocalBuilder 用法、参数传递与限制理解其固定this、维持组件父子关系的核心特性能够清晰对比 Builder 与 LocalBuilder在实际开发中正确选型。一、Builder 核心认知1.1 什么是 BuilderBuilder用于封装一段UI结构仅负责UI渲染无独立实例、无状态、无生命周期不会加入组件树编译阶段会直接内联展开是组件内/全局复用UI片段的最优轻量方案。1.2 为什么需要 Builder我们已经掌握Component封装可复用UI适用于独立功能、带业务逻辑、带生命周期的页面/组件。但开发中存在大量纯UI结构、无状态、无业务、无生命周期的复用片段例如 列表内固定骨架图页面内重复UI区块。这类片段不需要独立实例、状态、生命周期使用Component会造成额外实例开销粒度过细。因此 ArkTS 提供最轻量UI复用方案Builder 自定义构建函数专注细粒度UI复用几乎无额外性能消耗。1.3 Builder 与 Component 核心区别特性BuilderComponent本质UI构建函数独立自定义组件实例无实例有独立组件实例状态支持不能声明State支持State、Prop等状态生命周期无生命周期拥有完整生命周期调用方式直接调用作为组件使用适用场景纯UI结构复用功能组件/页面/业务模块刷新范围随所属组件整体刷新无独立刷新可独立响应式刷新调用位置只能在build()内部使用任意生命周期与场景均可使用1.4 Builder 两种定义形式组件内 Builder仅当前组件内使用可直接访问组件成员变量与状态跟随组件刷新而刷新全局 Builder整个工程通用不依赖任何组件实例不能访问this所有数据必须通过参数传递。二、项目工程本节工程BuilderDemo基于 API 20所有案例页面完整对应如下BuilderDemo/ ├── AppScope/ ├── entry/ │ ├── src/main/ets │ │ ├── entryability/EntryAbility.ets │ │ ├── pages/ │ │ │ ├── Index.ets # 入口页面跳转 │ │ │ ├── InnerBuilderPage.ets # 组件内Builder │ │ │ ├── GlobalBuilderPage.ets # 全局Builder │ │ │ ├── BuilderParamPage.ets # BuilderParam UI插槽 │ │ │ ├── AdvancedBuilderPage.ets # 高级嵌套、this指向、Binding │ │ │ └── LocalBuilderPage.ets # LocalBuilder 专属案例三、Index.ets 入口页面importrouterfromohos.router;// 定义页面配置接口interfacePageConfig{title:string;url:string;}Entry Component struct Index{pageList:PageConfig[][{title:1. 组件内 Builder,url:pages/InnerBuilderPage},{title:2. 全局 Builder,url:pages/GlobalBuilderPage},{title:3. BuilderParam 插槽,url:pages/BuilderParamPage},{title:4. this指向问题,url:pages/AdvancedBuilderPage},{title:5. LocalBuilder,url:pages/LocalBuilderPage}];// 自定义Builder按钮封装BuilderbuilderButton(title:string,onClick:()void){Button(title).width(280).onClick(onClick);}build(){Column({space:20}){Text(Builder LocalBuilder 实战).fontSize(26).fontWeight(FontWeight.Bold);// ForEach 循环渲染按钮ForEach(this.pageList,(item:PageConfig){this.builderButton(item.title,(){router.pushUrl({url:item.url});});});}.width(100%).height(100%).justifyContent(FlexAlign.Center);}}四、组件内 Builder 示例演示4.1 规则说明组件内 Builder 直接访问 this 状态变量时会跟随组件整体刷新不受传参规则限制自动刷新Builder 默认按值传递参数传递基础类型、对象变量、多参数时外部状态更新不会触发 Builder 刷新Builder 实现响应式刷新的标准方式使用对象字面量形式传入参数可建立响应式关联状态更新自动刷新多层 Builder 嵌套时每一层都必须使用对象字面量传参才能保证全链路刷新禁止在 Builder 内部修改传入的参数对象会导致运行异常从 API version 20 开始可通过 UIUtils.makeBinding()、Binding / MutableBinding 实现 Builder 内状态变量刷新使用 UIUtils.makeBinding() 包装读状态回调支持 Builder 内 UI 自动刷新额外传入写状态回调可将 Builder 内部的参数修改同步到外部组件。4.2 说明Builder被用来展示组件不会参与动态UI刷新。组件中值的变化是通过使用装饰器的特性监听到值的改变触发的UI刷新而不是通过Builder的能力触发的。4.3 示例代码示例 1无参 Builder 直接访问 this → 自动刷新classUserInfo{name:stringage:number0}Entry Component struct InnerBuilderPage{State message:string组件内 Builder 实战State count:number0State user:UserInfo{name:Tom,age:25}BuilderbuildTitle(){Text(this.message).fontSize(24).fontWeight(FontWeight.Bold).fontColor(#333333)}build(){Column({space:15}){this.buildTitle()Button(更新标题).onClick((){this.message组件内 Builder 实战-更新})}.width(100%)}}示例 2按值传递 → 不刷新BuilderbuildButton(label:string){Text(基础类型传参 → 不刷新label)}// 调用this.buildButton(count${this.count})示例 3直接传递对象变量按值传递 → 不刷新BuilderbuildUserCardByObj(params:UserInfo){Text(姓名${params.name}年龄${params.age})}// 调用this.buildUserCardByObj(this.user)示例 4多参数传递按值传递 → 不刷新BuilderbuildUserCardByValue(name:string,age:number){Text(姓名${name}年龄${age})}// 调用this.buildUserCardByValue(this.user.name,this.user.age)示例 5对象字面量 → 按引用传递 → 刷新BuilderbuildUserCardByRef(params:UserInfo){Text(姓名${params.name}年龄${params.age})}// 调用this.buildUserCardByRef({name:this.user.name,age:this.user.age})示例 6嵌套 Builder 子组件刷新对比Component struct ChildComponent1{Prop info:UserInfonewUserInfo();build(){Row(){Text(ChildComponent1不刷新${this.info.name}${this.info.age}).fontSize(20).fontWeight(FontWeight.Bold)}}}Component struct ChildComponent2{Prop childName:string;Prop childAge:number0;build(){Row(){Text(ChildComponent2刷新${this.childName}${this.childAge}).fontSize(20).fontWeight(FontWeight.Bold)}}}BuilderparentBuilder(params:UserInfo){Text(parentBuilder刷新${params.name}${params.age}).fontSize(20).fontWeight(FontWeight.Bold)ChildComponent1({info:params})// 不刷新ChildComponent2({childName:params.name,childAge:params.age})// 刷新}示例 7错误示范Builder 内部修改参数BuildererrorModifyParam(params:UserInfo){Button(修改).onClick((){params.name错误修改// 运行异常})}示例 8API20 新特性 → Binding 绑定传参可修改可刷新BuilderModifyParam(params:BindingUserInfo){Text(姓名${params.value.name})Button(内部修改).onClick((){params.value.name新名字})}// 调用this.ModifyParam(UIUtils.makeBinding(()this.user,(user){this.useruser}))运行结果五、全局 Builder 实战5.1 核心功能定义全局通用UI片段多页面共享无组件依赖不绑定this所有数据必须通过参数传递。5.2 规则必须加function关键字跨页面使用需要加export5.3 示例代码interfaceGlobalInfo{globalContent:string callback?:()void}BuilderexportfunctionglobalButton(globalInfo:GlobalInfo){Button(globalInfo.globalContent).width(180).height(46).backgroundColor(#34C85E).margin(5).onClick(globalInfo?.callback)}BuilderexportfunctionglobalCard(title:string,content:string){Column(){Text(title).fontSize(20).fontWeight(FontWeight.Bold)Text(content).fontSize(16).margin({top:10})}.width(100%).padding(20).backgroundColor(#fff).borderRadius(12).margin(10)}Entry Component struct GlobalBuilderPage{State content:string全局复用跨页面统一样式State globalInfo:GlobalInfo{globalContent:全局按钮1}build(){Column({space:20}){globalCard(全局 Builder 实战,this.content)// 只能通过引用传递 一一传递对应参数 否则无法刷新。globalButton({globalContent:this.globalInfo.globalContent,callback:(){this.globalInfo.globalContent全局按钮点击更新}})}.width(100%).padding(20)}}5.4 运行结果六、BuilderParam UI插槽6.1 核心功能BuilderParam用于接收外部传入的Builder函数实现UI插槽slot能力让组件结构固定、内容可灵活定制。6.2 说明BuilderParam 是组件属性装饰器专门用于接收 Builder 函数类型的参数。使用场景父组件向子组件传递一段UI结构子组件只负责布局不关心具体内容。6.3 示例代码Component struct CardComponent{BuilderParam header?:()voidBuilderParam content?:()voidbuild(){Column(){if(this.header){this.header()}Divider().margin(10).color(Color.Red).strokeWidth(2)if(this.content){this.content()}}.width(100%).backgroundColor(#fff).padding(20).borderRadius(12)}}Entry Component struct BuilderParamPage{BuildercustomHeader(){Text(自定义头部).fontSize(22).fontWeight(FontWeight.Bold)}BuildercustomContent(){Text(这是插槽内容灵活传入任意UI)Button(插槽内按钮).width(150).margin(10)}build(){Column({space:20}){CardComponent({header:this.customHeader,content:this.customContent})}.padding(20)}}6.4 运行结果七、关于this 指向重点我们在使用 Builder BuilderParam 跨组件传递时会出现一个非常关键的问题this 指向会变导致UI刷新不符合预期。7.1 this 指向核心规则Builder 直接作为引用传递时this 由「调用它的组件」决定。箭头函数没有自己的 this会继承外层作用域的 this。在BuilderParam场景直接传递customBuilderParam: this.componentBuilder→ 函数在 Child 里执行this 指向 Child。箭头函数包裹customBuilderParam: () { this.componentBuilder() }→ 继承父组件 thisthis 指向 Parent。7.2 示例代码/** * 问题Builder BuilderParam this 指向问题 * 页面运行结果Parent Child Parent * 核心规则 * 1. 直接传递函数引用 → this 由【调用者】决定 * 2. 箭头函数包裹 → this 继承【定义时的组件】 */Component struct ChildComponent{label:stringChild;// 默认占位Builder无实际UIBuildercustomBuilder(){}BuildercustomChangeThisBuilder(){}// 接收外部传入的Builder函数BuilderParamcustomBuilderParam:()voidthis.customBuilder;BuilderParamcustomChangeThisBuilderParam:()voidthis.customChangeThisBuilder;build(){Row({space:15}){// 执行外部传入的构建函数this.customBuilderParam()this.customChangeThisBuilderParam()}}}Entry Component struct AdvancedBuilderPage{label:stringParent;// 普通 Builderthis 由【运行时调用者】决定不固定BuildercomponentBuilder(){Text(${this.label}).fontSize(26).fontWeight(FontWeight.Bold)}build(){Column({space:20}){Text(运行结果).fontSize(22)Row({space:15}){// 1️⃣ 父组件自己调用 → this 指向Parent → 显示 Parentthis.componentBuilder()ChildComponent({// 2️⃣ 直接传递函数引用函数在子组件内执行 → this 指向Child → 显示 ChildcustomBuilderParam:this.componentBuilder,// 3️⃣ 箭头函数包裹继承父组件this → this 固定指向Parent → 显示 ParentcustomChangeThisBuilderParam:(){this.componentBuilder()}})}}.width(100%).padding(30)}}7.3 运行结果最终页面显示Parent Child Parent7.4 一句话总结this 是函数执行时的上下文对象它的指向不是在函数定义时确定的而是在函数调用时才最终确定。普通函数谁调用this 就指向谁默认规则也是最容易错乱的场景箭头函数没有自己的 this继承外层作用域的 this永远不会错乱优先推荐八、LocalBuilder 装饰器Builder 在跨组件传递时this 会被改变这会导致严重问题UI 刷新不符合预期为了彻底解决这个问题ArkTS提供了LocalBuilder。LocalBuilder可以固定this指向当前8.1 设计目的LocalBuilder 拥有和局部 Builder完全一样的UI构建能力但可以固定 this 指向保证组件父子关系不变保证状态管理父子关系不变从根源解决 Builder 的上下文错乱问题。8.2 核心特性只能在组件内部定义不支持全局this永远指向声明它的组件不会被任何方式改变跨组件传递时组件归属固定不会被修改调用方式与 Builder 完全一致this.xxx()。8.3 LocalBuilder与Builder对比示例Component struct Child{label:stringChild;BuilderParam customBuilderParam?:()void;build(){if(this.customBuilderParam){this.customBuilderParam()}else{Text(BuilderParam undefined)}}}Entry Component struct LocalBuilderPage{label:stringParent;// Builderthis 指向调用方 → ChildBuildercomponentBuilder(){Text(this.label)}// LocalBuilderthis 永远指向 ParentLocalBuildercomponentLocalBuilder(){Text(this.label)}build(){Column({space:20}){// 显示 ChildChild({customBuilderParam:this.componentBuilder})// 显示 ParentChild({customBuilderParam:this.componentLocalBuilder})}}}8.4 限制条件只能在组件内声明不允许全局不能与其他任何装饰器一起使用不能修饰静态方法函数内部不允许修改参数作为参数传递时推荐直接传函数this.func或箭头函数() { this.func() }this指向都不会变.禁止直接传执行结果会导致布局错乱。8.5 参数传递规则与 Builder 一致按值传递基础类型、多参数、直接对象 →不刷新按引用传递单个对象字面量 →可刷新按回调传递API20 使用 UIUtils.makeBinding →可刷新可修改注意子组件调用父组件的 LocalBuilder 并传参时子组件状态变化不会触发LocalBuilder 刷新推荐LocalBuilder 内直接访问父组件自身状态。九、代码仓库工程名称BuilderDemo仓库地址https://gitee.com/HarmonyOS-UI-Basics/harmony-os-ui-basics.git十、下节预告下一节我们将深入学习鸿蒙UI样式复用三大核心方案掌握 Styles 通用样式复用实现多组件基础样式统一掌握 Extend 组件专属样式扩展支持参数与私有属性掌握 stateStyles 多态状态样式实现按压/禁用/选中自动切换清晰区分三者适用场景写出简洁、可维护、高性能样式代码

相关文章:

鸿蒙应用开发UI基础第二十六节:轻量级UI元素@Builder与@LocalBuilder区别示例演示

【学习目标】 理解 Builder 设计初衷,明确与 Component 核心差异;掌握 Builder 两种定义方式、参数传递(按值/按引用)规则;掌握 Builder 高级场景(嵌套、this指向)实战用法;掌握 Bui…...

RMBG-2.0多场景应用:跨境电商主图制作、小红书封面抠图、PPT素材生成

RMBG-2.0多场景应用:跨境电商主图制作、小红书封面抠图、PPT素材生成 1. 项目概述 RMBG-2.0是基于BiRefNet架构开发的智能背景扣除工具,能够精准识别并移除图像背景,保留主体对象的完整细节。这个工具就像一双能够看穿伪装的"境界剥离…...

深入解读ExitCode:快速诊断Kubernetes Pod异常退出的实战指南

1. 从ExitCode入手:理解Pod异常退出的第一线索 当你在Kubernetes集群中发现某个Pod频繁重启,第一反应是什么?我通常会像老中医把脉一样,先查看ExitCode这个"脉搏信号"。记得去年我们线上有个关键服务突然崩溃&#xff0…...

09年408真题解析1~5题

选B。先入先出:队列。先入后出:栈。 选C。3层 d(出2)f(出4)2层 b(出1)c(出3)e(出5)1层 a(出6)g(出…...

蛋白质组学数据上传保姆级教程:从IProX注册到Aspera加速上传全流程

蛋白质组学数据高效上传实战指南:从IProX注册到Aspera极速传输 在生命科学研究中,蛋白质组学数据的规范上传已成为学术发表的必备环节。对于刚接触这一流程的研究者而言,如何高效完成从数据准备到平台上传的全过程,往往面临诸多实…...

Z-Image-GGUF模型推理优化:利用C语言进行底层性能调优

Z-Image-GGUF模型推理优化:利用C语言进行底层性能调优 最近在折腾一个基于GGUF格式的图像生成模型推理项目,发现直接用现成的推理框架虽然方便,但总感觉性能还有不少提升空间。尤其是在一些资源受限的边缘设备上,推理速度直接影响…...

7个步骤实现音频文件高效解码:全流程解决加密音乐格式兼容难题

7个步骤实现音频文件高效解码:全流程解决加密音乐格式兼容难题 【免费下载链接】qmcdump 一个简单的QQ音乐解码(qmcflac/qmc0/qmc3 转 flac/mp3),仅为个人学习参考用。 项目地址: https://gitcode.com/gh_mirrors/qm/qmcdump …...

AI 编译器系列(七)《(MLIR)AscendNPU IR 编译堆栈》

目录 AscendNPU IR 架构概述 Triton-Ascend AscendNPU IR MLIR 简介: 1. 定义: 2. 特点: AscendNPU IR 引入: AscendNPU IR 架构详解 整体架构: HFusion 方言关键 Pass 昇腾硬件架构: HFusion …...

AI 写代码越来越快,但谁来定义代码的架构标准?

AI Coding市场爆发背后的结构性缺失,以及 Oinone “AI负责速度,Oinone负责尺度”的解题思路2025年,AI Coding已经不是概念。全球超过70%的开发者已在日常工作中使用AI编码工具,GitHub Copilot、Cursor、Trae、Qoder等产品正以前所…...

优化SEO效果的长尾关键词运用与关键词调整策略分析

本文将围绕优化SEO效果的长尾关键词运用与关键词调整策略进行深入探讨。首先,长尾关键词在提高网站可见性和搜索引擎排名中扮演着关键角色,能够帮助目标用户找到相关内容。其次,通过分析长尾关键词的特点,可以发现其相较于短尾关键…...

AI提升SEO关键词策略的创新应用与实践指南

本文将全面探讨AI在SEO关键词策略中的应用,重点分析智能技术如何提升关键词挖掘和优化效率。AI工具的有效运用,不仅能快速识别趋势关键词,还能分析用户搜索行为,帮助企业更好地调整内容策略。接下来的章节将结合多个案例&#xff…...

foundationstereo模型的安装部署与运行

硬件:RTX5060(8GB显存) Intel(R) Core(TM) i7-14650HX 32GB内存nvidia环境:驱动 580.126.09 CUDA Version 12.81. 安装torch由于显卡架构 sm_120 原因,官方提供的包在后续编译第三方库时会有环境兼容问题,仍然采用nightly 支持…...

三电平半桥LLC谐振变换器:频率控制与移相角度下的仿真研究

三电平半桥LLC谐振变换器电路仿真 采用频率控制方式 引入一定的移相角度(比较小) 驱动信号采用CMPA CMPB方式产生 增计数模式(参照DSP PWM生成) 相比普通半桥LLC开关管电压应力小 输出电压闭环控制 输出特性好,几乎无超…...

给我搞个python虚拟环境

先搞个出来python -m venv myenv然后用:win下:myenv\Scripts\activatelinux:source myenv/bin/activate...

萤石开放平台 音视频| 如何使用Web端带宽检测工具?

带宽检测操作文档 为什么要进行带宽检测? 带宽检测是检测设备的上行带宽、下行带宽、丢包以及网络延迟情况,可以验证设备的实时带宽是否超出套餐额度,以及网络的速度、延迟性和稳定性。阅读本文带宽检测操作文档,您将学会如何运…...

红外与RGB相机标定实战:不用标定板也能搞定外参对齐(附Python采集脚本)

红外与RGB相机无标定板标定实战:环境特征点替代方案与Python实现 在工业检测、安防监控等需要多光谱数据融合的场景中,红外相机与RGB相机的联合标定一直是技术难点。传统标定板方案虽然成熟,但在实际工程部署中常常遇到距离限制、成本高昂和灵…...

LizzieYzy:面向围棋爱好者的AI辅助全攻略

LizzieYzy:面向围棋爱好者的AI辅助全攻略 【免费下载链接】lizzieyzy LizzieYzy - GUI for Game of Go 项目地址: https://gitcode.com/gh_mirrors/li/lizzieyzy LizzieYzy是一款专为围棋爱好者打造的AI辅助工具,它通过多引擎协作系统、智能棋局分…...

保姆级教程:在Ubuntu 22.04上为ARM板卡交叉编译hostapd 2.10(附openssl/libnl依赖处理)

深度实战:在Ubuntu 22.04上为ARM设备构建hostapd 2.10的完整指南 在嵌入式开发领域,为ARM架构设备交叉编译软件是开发者必须掌握的技能之一。当我们需要在树莓派、RK系列开发板等ARM设备上部署WiFi热点功能时,hostapd无疑是最可靠的选择。本…...

AI电影解说工具推荐:实测对比剪映手动流程,效率到底差多少?

做电影解说推荐用AI解说大师这类AI电影解说工具,实测从选片到成片全流程只要5分钟,而用剪映手动做完同样一条视频至少需要2-3小时。很多刚入行的朋友一上来就被"DeepSeek剪映"的教程种草了,觉得这套组合已经够用。确实够用&#xf…...

技术人的反算法人格:故意制造认知偏差保命

第一章 算法围城:测试工程师的认知危机1.1 算法暴政的三大特征黑箱化决策:推荐系统/AI模型的不可解释性(如深度学习模型的梯度消失问题)数据偏见固化:训练集偏差引发的连锁反应(Amazon招聘AI性别歧视事件复…...

Windows本地宝塔面板部署与内网穿透实战:从局域网到公网访问

1. 为什么要在Windows本地部署宝塔面板? 很多刚接触服务器管理的朋友都会有这样的疑问:为什么不在云服务器上直接安装宝塔面板,而是要在本地Windows电脑上折腾?这里面的门道还真不少。我自己刚开始用宝塔面板时也走过弯路&#xf…...

TurMass™ Link 无线覆盖组网方案详解

随着数字化转型的深入,智慧园区已不再局限于基础的物业管理,而是向着感知敏捷、决策智能、服务主动的深度融合方向演进。然而,面对园区内复杂的电磁环境、密集的设备接入以及广泛的覆盖需求,传统的通信技术往往面临穿透力弱、功耗…...

人味护盾:软件测试工程师在AI时代的价值重构与晋升路径

一、AI重构测试生态:危机中的转机2026年的测试领域正经历三重颠覆:工具层:AI测试脚本生成覆盖率突破80%(Gartner 2025报告)流程层:DevOps流水线实现需求→用例→执行的秒级闭环决策层:缺陷预测模…...

大多数人以为越努力越能做好,但其实拼命想“完美发挥”才是最快搞砸一件事的方法

你有没有过这种体验?私下准备得滚瓜烂熟,口若悬河,一到正式场合面对镜头或人群,大脑却突然一片空白,手脚都不听使唤。明明是最拿手的事,却在关键时刻彻底崩盘。 这不是你能力的问题,而是你打输了…...

新增智能问数执行详情与实时仪表板,SQLBot开源智能问数系统v1.7.0版本发布

2026年3月19日,SQLBot开源智能问数系统正式发布v1.7.0版本。 本次版本更新主要实现了智能问数执行监控、图表显示优化、实时数据展示等核心功能。在新增功能方面,SQLBot v1.7.0版本新增了智能问数执行详情、图表数据标签显示、MySQL SSL支持、数据表启停…...

FireRedASR-AED-L惊艳效果:同一模型对吴语、闽南语、客家话的跨方言识别对比

FireRedASR-AED-L惊艳效果:同一模型对吴语、闽南语、客家话的跨方言识别对比 1. 方言识别的重要性与挑战 方言识别是语音识别领域最具挑战性的任务之一。中国各地的方言在发音、语调、词汇上存在巨大差异,甚至同一方言区内也有不同口音。传统的语音识别…...

AD20铺铜避坑指南:解决‘unable to locate any suitable location netgnd’错误的3个关键步骤

AD20铺铜避坑实战:从报错到完美GND网络的完整解决方案 在PCB设计过程中,铺铜操作看似简单却暗藏玄机。特别是当AD20弹出"unable to locate any suitable location netgnd"这样的错误提示时,很多新手工程师往往会陷入困惑。这个错误…...

深入浅出:辐射骚扰RE

辐射骚扰测试(RE测试)是电磁兼容(EMC)测试的核心项目之一,它直接关系到你的产品是否会干扰周围的其他电子设备。一、什么是辐射骚扰测试?辐射骚扰测试,全称是辐射发射测试,英文为Rad…...

WebGL开发数字孪生项目

WebGL开发数字孪生项目已从单纯的“视觉还原”演进为“实时决策中心”。随着 WebGPU 在企业级浏览器中达到约70%的普及率,高性能数字孪生正处于从 WebGL 向 WebGPU 过渡的阶段,但 WebGL 凭借其成熟的生态(Three.js/Cesium)依然是当…...

Beyond Compare 5本地密钥生成解决方案:技术实践与授权验证指南

Beyond Compare 5本地密钥生成解决方案:技术实践与授权验证指南 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen Beyond Compare作为业界领先的文件比较工具,在试用期结束…...