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

避坑指南:uniapp中scroll-view滚动定位的那些坑(商品分类案例详解)

避坑指南uniapp中scroll-view滚动定位的那些坑商品分类案例详解最近在做一个电商类小程序产品经理拿着某头部电商App的原型过来指着那个经典的“左侧分类、右侧商品列表”的布局说“咱们也要这个效果点击分类右边商品列表要平滑滚动到对应区域滑动商品列表左边的分类选中状态也要跟着变。”听起来是个很常见的需求对吧用uniapp的scroll-view组件配合scroll-into-view属性理论上几行代码就能搞定。但真正动手做的时候你会发现从“能跑”到“好用”中间隔着一堆大大小小的坑。比如点击分类后右侧列表确实滚过去了但滚动动画生硬得像卡顿又或者滑动商品列表时左侧分类的选中状态疯狂跳动用户体验极差更别提在商品数据量稍大时页面滚动开始变得一卡一卡的。这些问题官方文档往往一笔带过却实实在在地影响着产品的核心体验。这篇文章我就结合一个完整的商品分类联动案例把我在多个项目中踩过的scroll-view滚动定位的坑以及对应的解决方案和优化思路毫无保留地分享给你。无论你是刚接触uniapp的新手还是正在被类似问题困扰的开发者相信都能从中找到答案。1. 基础联动从零搭建分类-商品滚动框架我们先从最基础的实现讲起。目标是构建一个双栏布局左侧是垂直滚动的分类列表右侧是垂直滚动的商品列表。点击左侧分类项右侧商品列表应滚动至对应分类的锚点位置反之滑动右侧商品列表左侧分类的选中状态需同步更新。1.1 布局结构与数据绑定首先我们搭建基础的Vue单文件组件结构。这里的关键在于两个scroll-view的配合。template view classcategory-container !-- 左侧分类栏 -- scroll-view scroll-y classleft-scroll :scroll-into-viewactiveLeftId scroll-with-animation view v-for(category, index) in categoryList :keycategory.id :class[category-item, { active: activeCategoryIndex index }] :idleft_${category.id} taphandleCategoryTap(category, index) text{{ category.name }}/text /view /scroll-view !-- 右侧商品栏 -- scroll-view scroll-y classright-scroll :scroll-into-viewactiveRightId scroll-with-animation scrollhandleRightScroll view v-forcategory in categoryList :keyright_${category.id} classproduct-section :idright_${category.id} view classsection-title text{{ category.name }}/text /view view classproduct-grid view v-forproduct in category.productList :keyproduct.id classproduct-card tapgoToProductDetail(product) image :srcproduct.image modeaspectFill classproduct-img / text classproduct-name{{ product.name }}/text text classproduct-price¥{{ product.price }}/text /view /view /view /scroll-view /view /template几个关键点解析scroll-y启用垂直滚动。:scroll-into-view绑定一个变量其值应为子元素的id。当这个变量变化时滚动视图会自动滚动到对应id的元素处。scroll-with-animation启用滚动动画让跳转不那么生硬。scroll监听滚动事件用于实现滑动时更新左侧选中状态。对应的脚本部分我们初始化数据和核心变量script export default { data() { return { categoryList: [], // 从后端获取的分类及商品数据 activeCategoryIndex: 0, // 当前激活的分类索引 activeRightId: , // 控制右侧滚动到的目标id activeLeftId: , // 控制左侧滚动到的目标id用于分类项很多时确保激活项在可视区内 }; }, onLoad() { this.fetchCategoryData(); }, methods: { async fetchCategoryData() { // 模拟API请求 const res await uni.request({ url: /api/categories-with-products }); this.categoryList res.data; // 初始化让右侧滚动到第一个分类 if (this.categoryList.length 0) { this.activeRightId right_${this.categoryList[0].id}; } }, // 点击分类的处理函数 handleCategoryTap(category, index) { this.activeCategoryIndex index; this.activeRightId right_${category.id}; // 如果左侧分类很多当前选中项可能不在可视区也需要滚动 this.activeLeftId left_${category.id}; }, // 右侧滚动监听 handleRightScroll(event) { // 这里需要计算当前滚动位置对应哪个分类后续详解 console.log(滚动事件详情:, event.detail); }, goToProductDetail(product) { uni.navigateTo({ url: /pages/product/detail?id${product.id} }); } } }; /script1.2 核心属性 scroll-into-view 的“潜规则”这是实现定位跳转的核心但有几个细节容易出错id命名不能以数字开头这是W3C HTML标准在uniapp中同样适用。id1或:idcategory.id如果id是数字会导致滚动失效。必须使用字符串前缀如上面的right_${category.id}。值必须精确匹配scroll-into-view绑定的变量值必须与某个子元素view的id属性完全一致包括前缀。大小写敏感。目标元素必须在渲染树中如果你在滚动后动态加载了更多商品分类新分类的DOM可能还未渲染完成就立即设置scroll-into-view会导致失效。需要确保在$nextTick或数据更新后的生命周期钩子中设置。注意scroll-into-view的滚动是瞬间完成的即使加了scroll-with-animation其动画曲线也相对固定。如果你对动画效果有更高要求如弹性动画可能需要更复杂的自定义滚动方案。2. 精准联动滑动右侧左侧分类状态同步更新点击分类让右边滚动这个相对简单。难点在于反向联动用户滑动右侧商品列表时如何准确、流畅地更新左侧分类的选中状态常见的坑是状态更新不及时或频繁跳动。2.1 利用 uni.createSelectorQuery 进行位置侦测我们不能依赖简单的滚动距离除以固定高度来计算因为每个分类区块的高度可能不同。正确的方法是使用uni.createSelectorQuery查询每个分类区块即.product-section相对于屏幕视口的位置。优化后的handleRightScroll方法handleRightScroll(event) { // 防抖处理避免滚动事件触发太频繁导致性能问题和状态抖动 if (this.scrollTimer) clearTimeout(this.scrollTimer); this.scrollTimer setTimeout(() { this.calculateActiveCategory(); }, 50); // 50ms的防抖间隔是一个平衡点 }, calculateActiveCategory() { const query uni.createSelectorQuery().in(this); // 查询所有分类区块的布局信息 query.selectAll(.product-section).boundingClientRect((rects) { if (!rects || rects.length 0) return; // 找到一个合适的“判断区域”通常是在屏幕顶部往下一定距离的位置 // 比如导航栏下方120rpx的位置这里我们以120px为例 const judgeAreaTop 120; // 可根据你的实际布局调整 let currentActiveIndex 0; // 遍历所有区块寻找第一个顶部位置小于判断线且底部位置大于0的区块 for (let i 0; i rects.length; i) { // rects[i].top 是元素顶部相对于视口顶部的距离 // 当元素顶部接近或刚进入视口上半部分时判定为当前活跃分类 if (rects[i].top judgeAreaTop rects[i].bottom 0) { currentActiveIndex i; break; } // 如果所有元素顶部都大于判断线比如滚动到了最底部则选中最后一个 if (i rects.length - 1 rects[i].top judgeAreaTop) { currentActiveIndex i; } } // 只有当索引真正发生变化时才更新状态避免不必要的渲染和左侧滚动 if (this.activeCategoryIndex ! currentActiveIndex) { this.activeCategoryIndex currentActiveIndex; // 同样如果需要让左侧滚动到对应激活项可以在这里设置 activeLeftId const currentCategory this.categoryList[currentActiveIndex]; if (currentCategory) { this.activeLeftId left_${currentCategory.id}; } } }).exec(); }为什么用boundingClientRect它返回元素在页面上的位置信息相对于视口在滚动过程中是动态变化的非常适合用来做“当前可视区域判断”。2.2 解决状态“抖动”与性能瓶颈直接在上述循环中频繁setData在Vue中是更新响应式数据会导致左侧分类高亮状态快速跳动尤其是在滚动速度较快时。我们的优化策略是防抖Debounce如上代码所示在scroll事件处理中设置一个定时器延迟执行计算逻辑。确保只在滚动停止或大幅放缓时才计算一次。差异更新通过if (this.activeCategoryIndex ! currentActiveIndex)判断只有分类真正改变时才更新数据减少不必要的视图层通信和渲染。节流Throttle替代方案对于需要更实时反馈的场景可以用节流但防抖在大多数情况下体验更好。策略原理适用场景在本案例中的建议防抖事件触发后等待一段时间若期间无新事件则执行一次。滚动停止后更新状态、搜索框输入。推荐。滚动停止后准确更新一次避免中间过程抖动。节流在一段时间内只执行一次函数。页面滚动时持续计算如 parallax 效果、窗口 resize。如果需要滚动过程中左侧分类就有“滑动感”反馈可考虑但需配合更精细的判断逻辑。3. 深度优化提升滚动流畅度与交互体验基础功能实现后我们往往会遇到性能问题当商品数据量很大比如一个分类下有上百个商品时页面渲染压力大滚动容易卡顿。此外交互细节也影响体验。3.1 列表性能优化规避长列表渲染陷阱scroll-view内直接渲染数百个view节点在低端机上很容易出现白屏、卡顿。解决方案是虚拟列表。虽然uniapp官方没有提供开箱即用的虚拟列表组件但我们可以借助社区方案或一些技巧来优化。方案一使用uvue组件App端如果你开发的是App并且可以使用uvue其原生的list或recycle-list组件性能远优于scroll-view是处理长列表的最佳选择。但这需要一定的学习成本和项目架构调整。方案二实现简单的“按需渲染”对于小程序和H5一个折中的方案是只渲染可视区域及附近的数据。我们可以利用scroll事件和boundingClientRect进行粗略计算。data() { return { categoryList: [], // 完整数据 visibleRange: { start: 0, end: 10 }, // 当前需要渲染的数据索引范围 }; }, methods: { handleRightScrollForLazyLoad(event) { const scrollTop event.detail.scrollTop; const windowHeight uni.getSystemInfoSync().windowHeight; // 估算每个分类区块的平均高度例如300px const estimatedSectionHeight 300; // 计算当前滚动位置大概对应的分类索引 const estimatedIndex Math.floor(scrollTop / estimatedSectionHeight); // 设置一个缓冲范围比如前后多渲染2个分类 const buffer 2; const start Math.max(0, estimatedIndex - buffer); const end Math.min(this.categoryList.length - 1, estimatedIndex buffer); if (start ! this.visibleRange.start || end ! this.visibleRange.end) { this.visibleRange { start, end }; } }, // 在模板中只渲染 visibleRange 范围内的分类 computed: { visibleCategoryList() { return this.categoryList.slice(this.visibleRange.start, this.visibleRange.end 1); } } }然后在模板中遍历visibleCategoryList。这只是一个简化思路实际应用需要考虑区块高度不固定、滚动惯性等问题但能显著减少初始渲染的节点数。3.2 交互细节打磨点击分类的视觉反馈点击左侧分类时除了右侧滚动可以给点击项添加一个轻微的缩放或背景色变化动画增强操作感。.category-item:active { transform: scale(0.98); transition: transform 0.1s ease; }滚动动画调优scroll-with-animation的动画时长和曲线是内置的。如果你觉得动画不够自然可以考虑放弃scroll-into-view使用uni.pageScrollTo仅H5和App或自己通过CSStransform和transition实现滚动从而完全控制动画效果。边界情况处理第一个和最后一个分类滚动到最顶部或最底部时确保左侧选中状态正确。快速滑动在handleRightScroll的防抖函数中如果用户滑动非常快可能来不及计算。可以适当减少防抖延迟并确保计算逻辑足够高效。数据为空或加载中显示占位图或加载状态避免空白页面。4. 进阶实践复杂场景与可复用组件封装在实际项目中需求可能更复杂。例如分类可能有二级或者商品列表是瀑布流布局。此外将这套逻辑封装成可复用组件能极大提升开发效率。4.1 应对复杂布局二级分类与瀑布流场景一二级分类左侧可能是一级分类点击后右侧展示该一级分类下的二级分类和商品。这时数据结构变复杂了但核心逻辑不变。你需要为二级分类的标题块也设置id并在点击一级分类时滚动到该一级分类下第一个二级分类的区块id。滑动侦测时则需要同时判断一级和二级分类的位置。场景二商品瀑布流布局如果商品不是按分类严格分块而是混合的瀑布流但依然需要根据商品所属分类来高亮左侧菜单。这就需要在每个商品元素上标记其分类信息然后在滚动侦测时遍历所有商品或抽样遍历找出位于屏幕顶部区域最多的商品所属的分类。4.2 封装成可复用组件将核心逻辑抽离成一个组件例如category-scroll-view通过Props传入分类和商品数据通过Events抛出分类切换、商品点击等事件。这样在任何需要类似联动布局的页面都可以直接引入。组件Props设计示例props: { // 分类数据格式约定 categories: { type: Array, default: () [] }, // 是否开启滚动动画 animated: { type: Boolean, default: true }, // 判断区域的顶部偏移量用于计算当前分类 judgeOffset: { type: Number, default: 120 } }组件内部将之前讨论的防抖逻辑、位置查询、状态管理封装好。外部父组件只需关注数据获取和业务逻辑如跳转商品详情。4.3 调试技巧与常见问题排查scroll-into-view无效检查id命名是否符合规则不以数字开头。检查绑定的值是否与子元素id完全一致。在uni.createSelectorQuery回调中打印rects确认目标元素是否存在且位置正确。尝试在$nextTick中设置scroll-into-view的值。滚动监听事件不触发或触发频率低确保scroll-view的高度是固定的且内容高度超过容器高度否则不会触发滚动。检查CSS样式确保没有overflow冲突。性能问题在开发者工具的Performance面板中录制滚动过程查看哪些函数耗时最长。减少滚动事件中的复杂计算善用防抖/节流。对于超长列表坚定不移地采用虚拟列表方案。最后记住一点移动端的滚动体验是“感受”出来的不仅仅是“功能”实现。多在不同真机特别是低端Android机上测试感受滚动的跟手度、动画的平滑度、状态的切换是否自然。这些细微之处往往才是区分一个合格功能和优秀体验的关键。我在一次项目上线后通过用户反馈才发现在某个旧款机型上因为滚动计算过于频繁导致了轻微的发热问题。后来通过加大防抖阈值和优化判断算法才解决。所以纸上得来终觉浅绝知此事要躬行。

相关文章:

避坑指南:uniapp中scroll-view滚动定位的那些坑(商品分类案例详解)

避坑指南:uniapp中scroll-view滚动定位的那些坑(商品分类案例详解) 最近在做一个电商类小程序,产品经理拿着某头部电商App的原型过来,指着那个经典的“左侧分类、右侧商品列表”的布局说:“咱们也要这个效果…...

Tkinter Canvas高阶技巧:用数学函数绘制动态五角星和自定义图形

Tkinter Canvas高阶技巧:用数学函数绘制动态五角星和自定义图形 很多开发者初次接触Tkinter的Canvas组件时,往往止步于绘制简单的线条、矩形和圆形。这些基础图形虽然实用,但总让人觉得少了些创造力和表现力。实际上,Canvas的真正…...

Ubuntu下用pcl_ros将ROS bag文件转成PCD点云的完整流程(附常见问题解决)

Ubuntu下用pcl_ros将ROS bag文件转成PCD点云的完整流程(附常见问题解决) 在机器人感知和三维视觉领域,ROS(Robot Operating System)的bag文件是记录传感器数据(尤其是激光雷达点云)的黄金标准。…...

手把手教你用GStreamer在RK3588上搭建低延迟RTSP流媒体服务

手把手教你用GStreamer在RK3588上搭建低延迟RTSP流媒体服务 在嵌入式视觉应用领域,无论是工业质检、无人机图传还是智能安防,将设备采集的视频流稳定、高效地分发给网络上的其他客户端,始终是一个核心需求。RK3588作为一款性能强劲的ARM SoC&…...

嵌入式开发实战:如何用SPI协议实现主从设备高效通信(附代码示例)

嵌入式开发实战:如何用SPI协议实现主从设备高效通信(附代码示例) 最近在调试一个智能温控面板的项目,面板需要实时从多个分布在房间各处的温湿度传感器读取数据。传感器用的是常见的数字芯片,通过SPI接口通信。本以为这…...

手把手教你拆解中兴B860AV2.1B电视盒子:从硬件识别到固件刷入全流程

中兴B860AV2.1B电视盒子深度改造指南:从硬件探秘到系统焕新 最近在整理家里的旧设备,翻出来好几个运营商送的电视盒子,其中就包括这台中兴B860AV2.1B。相信不少朋友家里都有类似的“吃灰”设备,它们硬件性能其实并不差&#xff0c…...

YOLOv8文件路径全解析:如何快速找到ultralytics的配置文件、权重和运行时文件

YOLOv8文件路径全解析:如何快速找到ultralytics的配置文件、权重和运行时文件 刚上手YOLOv8,你是不是也经历过这种抓狂时刻?模型训练到一半,想改个学习率,却不知道配置文件藏在哪里;好不容易训练完&#xf…...

STM32语音识别智能家居仿真:Proteus虚拟串口实战指南(附完整指令表)

STM32语音识别智能家居仿真:Proteus虚拟串口实战指南(附完整指令表) 你是否曾对智能家居背后的技术感到好奇,想亲手搭建一个能听懂指令的“小管家”,却又被昂贵的硬件成本和复杂的电路焊接劝退?或者&#x…...

orthofinder结果文件实操指南:从Orthogroups.GeneCount.tsv到发表级韦恩图

OrthoFinder结果深度解析:从数据到发表级可视化 刚跑完OrthoFinder,看着满屏的.tsv和.txt文件,是不是有点无从下手?那种感觉我太懂了,就像拿到一份藏宝图,却不知道关键线索藏在哪里。OrthoFinder的分析结果…...

华为eNSP实战:单臂路由配置全流程(含VLAN间通信测试)

华为eNSP实战:单臂路由配置全流程与VLAN间通信深度解析 如果你刚接触企业网络,可能会好奇不同部门的电脑明明连在同一台交换机上,为什么不能直接互相访问。这背后其实是**VLAN(虚拟局域网)**在发挥作用,它将…...

港大神器,让AI一条命令操控桌面软件!

你有没有遇到过这种情况: 让AI帮你做个视频剪辑,或者批量处理一堆图片。 结果AI的操作方式是:截屏,识别按钮位置,模拟鼠标点击。 稍微换个分辨率就崩了。 窗口弹出来挡住了关键按钮也崩了。 软件更新了界面也崩了。 …...

UE5建模工具实战:从Lattice拉伸到法线修复的7个必学技巧

UE5建模工具实战:从Lattice拉伸到法线修复的7个必学技巧 如果你刚开始接触虚幻引擎5,或者已经从蓝图、材质系统迈入了资产制作的门槛,可能会发现一个有趣的现象:UE5内置的建模工具,远比你想象的要强大。它不再是那个只…...

Verilog开发者的VSCode终极配置:从语法高亮到自动生成Testbench

Verilog开发者的VSCode终极配置:从语法高亮到自动生成Testbench 作为一名Verilog开发者,你是否曾经历过这样的场景:面对一个复杂的模块接口,手动编写测试平台(Testbench)耗费数小时;代码格式混乱…...

SAM3点提示进阶技巧:精细分割视频中特定目标的保姆级教程

SAM3点提示进阶技巧:精细分割视频中特定目标的保姆级教程 在视频内容创作、影视后期乃至工业质检的领域里,从动态画面中精准地“抠”出某个特定目标,一直是个既关键又繁琐的活儿。传统的分割方法要么需要海量标注数据,要么对复杂场…...

从零开始配置PostgreSQL三权分立:DBA/SA/AA角色权限详解(附SQL脚本)

从零构建PostgreSQL权限堡垒:DBA、SA、AA三权分立的实战蓝图 最近在帮一家金融科技初创公司做数据库架构评审,他们的CTO提了一个很实际的问题:“我们团队现在人不多,开发、运维、安全的事儿经常混着干,数据库权限全在一…...

为什么C++项目要避免混用new和malloc?5个实际踩坑案例解析

为什么C项目要避免混用new和malloc?5个实际踩坑案例解析 在C开发的世界里,内存管理是区分新手与资深工程师的一道分水岭。很多开发者,尤其是从C语言背景转型过来的,常常会不自觉地沿用malloc和free的习惯,与C的new和de…...

nnUNetV2实战:从零开始处理医学影像2D数据集(附完整代码)

nnUNetV2实战:从零构建医学影像2D分割全流程 如果你刚接触医学影像分割,面对五花八门的模型和复杂的预处理流程感到无从下手,那么这篇文章就是为你准备的。nnUNetV2 不是一个新模型,而是一套高度自动化、标准化的医学影像分割框架…...

PostgreSQL17 Windows版安装包下载全攻略:官网直链+镜像加速

PostgreSQL 17 Windows 安装包极速获取指南:避开官网拥堵,直达高速通道 对于国内的开发者和技术爱好者来说,想要第一时间体验 PostgreSQL 17 的新特性,第一步的“下载”往往就成了拦路虎。官网服务器远在海外,下载速度…...

PyCharm闪退终极指南:从虚拟内存到多进程调优的完整解决方案

PyCharm闪退终极指南:从虚拟内存到多进程调优的完整解决方案 你是否也曾在深夜与代码鏖战时,被PyCharm突如其来的闪退打断思路?屏幕上瞬间消失的IDE窗口,伴随着系统卡顿甚至风扇狂啸,那种无力感足以让任何开发者抓狂。…...

从沙箱到生产环境:Alipay Global API完整对接指南(含常见配置错误修正)

从沙箱到生产环境:Alipay Global API完整对接指南(含常见配置错误修正) 对于许多初次接触Alipay Global API的开发团队来说,从沙箱测试到生产环境上线的过程,往往比预想的要复杂。这不仅仅是更换一个网关地址那么简单&…...

Halcon三维点云实战:从鞋点胶到工业检测的完整流程解析

Halcon三维点云实战:从鞋点胶到工业检测的完整流程解析 在精密制造领域,视觉检测正经历着从二维到三维的深刻变革。过去,工程师们依赖二维图像分析轮廓、对比灰度,但面对复杂曲面、装配间隙、微小形变等三维空间问题,传…...

虚拟UP主必备!用Fish Speech克隆你的声音当24小时数字分身

虚拟UP主的声音革命:用AI语音克隆打造你的“第二声带” 深夜三点,直播间里依然人声鼎沸。屏幕上的虚拟形象正用一口流利的日语与海外观众互动,而屏幕后的你,可能正靠在椅背上小憩,或者同时处理着另一条视频的剪辑。这并…...

ENVI+IDL实战:如何优化NDBI建筑物提取精度(附裸地误判解决方案)

ENVIIDL实战:如何优化NDBI建筑物提取精度(附裸地误判解决方案) 当你第一次在ENVI中计算出NDBI指数,看着屏幕上那些代表建筑物的白色斑块时,是不是既兴奋又有点头疼?兴奋的是,一个简单的公式就能…...

FastAPI实战:5分钟搞定即梦AI文生视频API逆向(附完整代码)

FastAPI实战:构建企业级文生视频API网关的完整架构 最近在帮几个内容创作团队做技术架构升级,发现一个普遍痛点:市面上很多优秀的AI视频生成工具,要么没有开放API,要么调用成本高得吓人。特别是像即梦AI这样的平台&…...

springboot+vue房屋租赁管理系统boot--毕业论文

目录项目技术支持可定制开发之功能亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作项目技术支持 后端语言框架支持: 数据库工具:Navicat/SQLyog等都可以 前端开发框架:vue.js 数据库 mysql 版本不限 1 java(SSM/s…...

springboot+vue当代中国获奖的知名作家信息管理系统的设计与实现毕业论文

目录研究背景与意义系统需求分析技术选型与架构设计核心功能实现系统特色与创新点论文结构建议参考文献方向项目技术支持可定制开发之功能亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作研究背景与意义 当代中国文学发展迅速&#xff…...

避开这些坑!微信表情包审核不通过的常见问题及解决方案(2023最新版)

避开这些坑!微信表情包审核不通过的常见问题及解决方案(2023最新版) 每次看到自己精心绘制的表情包在微信审核那里被无情打回,那种感觉就像精心准备的礼物被原封不动退回来一样,既沮丧又有点摸不着头脑。我身边不少独立…...

Origin 高级图表制作:5个让你的论文图表秒变顶刊级别的技巧

Origin 高级图表制作:5个让你的论文图表秒变顶刊级别的技巧 在科研论文的评审桌上,一张图表往往比几段文字更能决定审稿人的第一印象。对于已经熟悉Origin基础操作的科研人员来说,真正的挑战在于如何跨越“能用”到“卓越”的鸿沟&#xff0c…...

STM32H743串口DMA接收避坑指南:HAL库空闲中断那些事儿

STM32H743串口DMA接收避坑指南:HAL库空闲中断那些事儿 最近在几个基于STM32H743的工业通信项目中,我反复被同一个问题绊倒:串口DMA接收数据时,数据包时断时续,有时能完整收到,有时却莫名其妙地丢失后半截。…...

3DGS实战:如何用协方差矩阵优化高斯分布的渲染效果(附Python代码)

3DGS实战:如何用协方差矩阵优化高斯分布的渲染效果(附Python代码) 最近和几位做神经渲染的朋友聊天,大家不约而同地提到了3D Gaussian Splatting(3DGS)在项目落地时遇到的一个共同瓶颈:渲染出来…...