LVGL实战指南:Bar控件的进阶样式与动态交互

news2026/3/17 13:26:58
1. 从基础到进阶重新认识LVGL的Bar控件很多刚开始接触LVGL的朋友都会觉得Bar控件不就是个进度条嘛设置个值变个颜色好像没什么花样。我刚开始做智能手表UI的时候也是这么想的直到产品经理拿着一个设计稿过来上面是一个带渐变光泽、圆角边框、还能随着音乐节奏脉动的电量条我才发现原来Bar控件能玩出这么多花样。今天我就结合自己踩过的坑和实战经验跟你聊聊怎么让LVGL的Bar控件从“朴实无华”变得“炫酷实用”。简单来说LVGL的Bar控件是一个用来显示数值进度的组件比如电池电量、下载进度、音量大小。它最基础的样子就是一个长方形的背景我们叫它“背景区”上面有一个随着数值增长而变长的“指示区”。但它的强大之处在于这两个部分Part——LV_PART_MAIN背景和LV_PART_INDICATOR指示器——都可以被我们深度定制。你可以把它想象成一个画板MAIN是画布底板INDICATOR是上面那层会动的颜料。我们不仅能控制颜料的颜色还能控制它的质感渐变、画布的边框和形状圆角甚至让颜料以各种酷炫的方式流动起来动画。这篇文章就是为你准备的无论你是刚入门LVGL想做出比默认样式更漂亮的界面还是已经有一定经验想实现更复杂的动态交互效果比如点击按钮让进度条增长、或者根据传感器数据实时平滑变化。我们会抛开那些枯燥的API罗列直接用代码示例和效果对比手把手带你实现那些能提升产品质感的视觉效果。你会发现用好Bar控件你的嵌入式设备UI立刻就能摆脱“工控风”拥有更现代、更细腻的交互体验。2. 玩转Bar控件的两种高级模式默认的Bar模式LV_BAR_MODE_NORMAL是从最小值画到当前值适合大多数从0开始的进度场景。但LVGL还提供了两种更灵活的模式能帮你应对更特殊的数据展示需求。这两种模式我都在车载中控屏的项目里用过用来显示信号强度和温度区间非常直观。2.1 对称模式展现正负平衡对称模式LV_BAR_MODE_SYMMETRICAL特别适合展示有“中间点”或“平衡点”的数据。比如显示陀螺仪的偏移量、音频输入的左右声道平衡、或是电池的充电/放电电流。它的特点是指示器永远从0值开始绘制向正方向或负方向延伸而不管你的最小值设置成了多少。来看个代码例子就明白了。假设我们要做一个表示平衡状态的条范围是-100到100lv_obj_t *bar_sym lv_bar_create(lv_scr_act()); lv_obj_set_size(bar_sym, 200, 20); lv_obj_align(bar_sym, LV_ALIGN_CENTER, 0, -30); // 关键两步设置模式为对称并设置一个包含负值的最小范围 lv_bar_set_mode(bar_sym, LV_BAR_MODE_SYMMETRICAL); lv_bar_set_range(bar_sym, -100, 100); // 设置值为70指示器会从0画到70向右 lv_bar_set_value(bar_sym, 70, LV_ANIM_OFF); // 设置值为-40指示器会从0画到-40向左 lv_bar_set_value(bar_sym, -40, LV_ANIM_ON);这里有个很重要的视觉细节虽然我们设置了范围是-100到100但指示器的起点被“锁定”在了0点。当值为正时它向右增长值为负时它向左增长。你可以把0点理解为进度条的中心。为了让这个中心点更明显我通常会为LV_PART_INDICATOR设置两种不同的渐变颜色比如正值用蓝色渐变负值用红色渐变但这需要更复杂的样式控制我们后面会讲到。2.2 范围模式实现动态高亮区间范围模式LV_BAR_MODE_RANGE是我个人非常喜欢的一个功能它允许你独立设置一个起始值和一个结束值指示器会高亮显示这个区间。这不再是简单的“从起点到当前点”而是“从A点到B点”的一个动态范围。想象一下这些场景在音频编辑软件里高亮选中一段波形在图表中标记出温度的正常区间或者显示一个可变宽度的选择器。用范围模式来实现就非常合适。它的用法和对称模式有点像但多了一个设置起始值的函数。lv_obj_t *bar_range lv_bar_create(lv_scr_act()); lv_obj_set_size(bar_range, 200, 20); lv_obj_align(bar_range, LV_ALIGN_CENTER, 0, 30); lv_bar_set_mode(bar_range, LV_BAR_MODE_RANGE); lv_bar_set_range(bar_range, 0, 200); // 设置整体范围 // 注意必须先设置range再设置start_value否则可能不生效。 lv_bar_set_start_value(bar_range, 60, LV_ANIM_OFF); // 设置范围起始点为60 lv_bar_set_value(bar_range, 140, LV_ANIM_ON); // 设置范围结束点为140这段代码会创建一个进度条但指示器不是从0画到140而是只高亮从60到140的这段区域。你可以分别对start_value和value开启动画这样这个高亮区间就能像“手风琴”一样动态张开或闭合效果非常棒。我在这里踩过一个坑lv_bar_set_start_value一定要在lv_bar_set_range之后调用不然可能会被忽略。这个顺序问题在官方文档里提得不明显但实际开发中不注意就会导致效果出不来。3. 赋予进度条生命力动画与交互实战一个会动的进度条远比一个突然跳变的进度条来得友好。LVGL内置了强大的动画系统让Bar控件的每一次数值变化都能平滑过渡。但光是平滑移动还不够我们还要让它能“响应用户”实现真正的交互。3.1 精细控制动画曲线与时间调用lv_bar_set_value(obj, new_value, LV_ANIM_ON)是最简单的开启动画的方式。但默认的动画效果可能不符合你的产品调性。比如电量快速充电时可能希望动画快而直接而水温缓慢上升时可能希望动画慢而柔和。这就需要我们自定义动画参数。动画时间是最基本的控制项通过给LV_PART_MAIN设置anim_time样式属性来实现lv_obj_t *bar_anim lv_bar_create(lv_scr_act()); lv_obj_align(bar_anim, LV_ALIGN_CENTER, 0, 80); lv_bar_set_range(bar_anim, 0, 100); // 设置动画时间为3000毫秒3秒 lv_obj_set_style_anim_time(bar_anim, 3000, LV_PART_MAIN); // 点击按钮让进度条在3秒内缓慢增长到80% lv_obj_t *btn lv_btn_create(lv_scr_act()); lv_obj_align(btn, LV_ALIGN_CENTER, 0, 120); lv_obj_t *btn_label lv_label_create(btn); lv_label_set_text(btn_label, Animate to 80%); lv_obj_add_event_cb(btn, event_handler, LV_EVENT_CLICKED, bar_anim); static void event_handler(lv_event_t * e) { lv_obj_t * bar (lv_obj_t *)lv_event_get_user_data(e); lv_bar_set_value(bar, 80, LV_ANIM_ON); }除了时间你还可以通过lv_obj_set_style_anim_path来设置动画路径也就是变化曲线。LVGL提供了多种内置曲线比如LV_ANIM_PATH_LINEAR线性默认、LV_ANIM_PATH_EASE_IN先慢后快、LV_ANIM_PATH_EASE_OUT先快后慢、LV_ANIM_PATH_OVERSHOOT略带弹性效果。给进度条加上一个EASE_OUT的曲线会让它停下来的感觉更“自然”像汽车慢慢刹住而不是突然撞墙停下。3.2 实现点击与数据驱动的交互让进度条响应点击是提升交互性的关键一步。比如用户点击进度条的某个位置可以直接跳转到相应的进度。这需要用到LVGL的事件系统。不过Bar控件本身不直接支持点击设值我们需要一点小技巧。一个常见的做法是在Bar控件上层覆盖一个透明的按钮或者给Bar添加一个点击事件然后计算点击位置对应的值。这里演示后一种更直接的方法lv_obj_add_event_cb(bar_anim, bar_event_cb, LV_EVENT_CLICKED, NULL); static void bar_event_cb(lv_event_t * e) { lv_obj_t * bar lv_event_get_target(e); lv_indev_t * indev lv_indev_get_act(); if(indev) { lv_point_t point_act; lv_indev_get_point(indev, point_act); // 获取点击坐标 lv_coord_t bar_width lv_obj_get_width(bar); lv_coord_t bar_x lv_obj_get_x(bar); lv_coord_t click_x_rel point_act.x - bar_x; // 计算相对于Bar的X坐标 // 将点击位置映射到数值范围 int32_t min lv_bar_get_min_value(bar); int32_t max lv_bar_get_max_value(bar); int32_t new_value min (max - min) * click_x_rel / bar_width; // 限制值在有效范围内 new_value LV_CLAMP(min, new_value, max); lv_bar_set_value(bar, new_value, LV_ANIM_ON); // 带动画地设置新值 } }这段代码实现了点击进度条任意位置跳转。核心思路是获取点击的X坐标减去进度条本身的X坐标得到相对位置再根据进度条宽度和数值范围按比例计算出目标值。LV_CLAMP是一个好用的宏确保计算出的值不会超出范围。更进一步我们可以实现“数据驱动”的动态效果。比如进度条实时反映Wi-Fi信号强度、CPU使用率或网络速度。这通常需要一个任务lv_timer来定期更新Bar的值。关键点在于更新时使用LV_ANIM_ON可以保持平滑过渡但如果数据变化非常频繁如毫秒级频繁创建动画可能导致性能问题。这时可以适当降低更新频率或者使用LV_ANIM_OFF并在数据变化剧烈时再启用动画以在流畅性和性能间取得平衡。4. 深度定制视觉样式从平庸到卓越默认的蓝色填充条可能能满足功能但绝对谈不上美观。LVGL的样式系统给了我们极大的自由度来改造Bar的外观。下面我们就来拆解几个能瞬间提升质感的样式技巧。4.1 打造现代感渐变与圆角纯色填充已经过时了渐变色彩能立刻增加视觉深度和现代感。我们可以为LV_PART_INDICATOR设置渐变色。LVGL支持线性渐变你需要指定一个起始颜色和一个结束颜色以及渐变的方向。// 创建一个基础进度条 lv_obj_t *bar_style lv_bar_create(lv_scr_act()); lv_obj_set_size(bar_style, 180, 25); lv_obj_align(bar_style, LV_ALIGN_CENTER, 0, -60); lv_bar_set_value(bar_style, 75, LV_ANIM_OFF); // 1. 设置背景样式浅灰色大圆角内边距 lv_obj_set_style_bg_color(bar_style, lv_color_hex(0xe0e0e0), LV_PART_MAIN); lv_obj_set_style_radius(bar_style, 12, LV_PART_MAIN); // 圆角半径 lv_obj_set_style_pad_all(bar_style, 3, LV_PART_MAIN); // 内边距让指示器不和背景贴边 // 2. 设置指示器样式蓝-紫线性渐变同样带圆角 lv_obj_set_style_bg_color(bar_style, lv_color_hex(0x3498db), LV_PART_INDICATOR); // 起始色蓝色 lv_obj_set_style_bg_grad_color(bar_style, lv_color_hex(0x9b59b6), LV_PART_INDICATOR); // 结束色紫色 lv_obj_set_style_bg_grad_dir(bar_style, LV_GRAD_DIR_HOR, LV_PART_INDICATOR); // 水平渐变 lv_obj_set_style_radius(bar_style, 10, LV_PART_INDICATOR); // 指示器圆角略小于背景这里有几个细节首先我给MAIN部分加了pad_all内边距这样指示器就不会紧贴背景边框产生一种“凹陷”或“悬浮”的层次感。其次指示器的圆角半径最好比背景的小一点这样看起来更协调。渐变方向LV_GRAD_DIR_HOR是水平从左到右你还可以尝试LV_GRAD_DIR_VER垂直甚至LV_GRAD_DIR_NONE无渐变纯色。4.2 添加边框、阴影与创意指示器想让进度条更像一个精致的UI组件边框和阴影少不了。我们可以给背景部分添加边框甚至给指示器加阴影来营造立体感。// 继续上面的bar_style对象 // 3. 为背景添加细边框和阴影 lv_obj_set_style_border_color(bar_style, lv_color_hex(0xbdc3c7), LV_PART_MAIN); lv_obj_set_style_border_width(bar_style, 2, LV_PART_MAIN); lv_obj_set_style_border_opa(bar_style, LV_OPA_80, LV_PART_MAIN); // 边框透明度 lv_obj_set_style_shadow_color(bar_style, lv_color_hex(0x2c3e50), LV_PART_MAIN); lv_obj_set_style_shadow_width(bar_style, 5, LV_PART_MAIN); lv_obj_set_style_shadow_ofs_x(bar_style, 2, LV_PART_MAIN); lv_obj_set_style_shadow_ofs_y(bar_style, 2, LV_PART_MAIN); // 4. 创意指示器分段效果通过背景图实现 // 假设我们有一张包含多个色块的小图片作为纹理 LV_IMG_DECLARE(segment_texture); // 声明你的纹理图片 lv_obj_set_style_bg_img_src(bar_style, segment_texture, LV_PART_INDICATOR); lv_obj_set_style_bg_img_tiled(bar_style, true, LV_PART_INDICATOR); // 关键启用平铺边框样式让组件轮廓更清晰。阴影则增加了立体感和层次shadow_ofs_x和shadow_ofs_y控制阴影偏移方向正值是右下负值是左上你可以根据光源方向调整。更高级的玩法是给指示器设置背景图。比如你可以设计一个由短线段组成的纹理图片然后通过bg_img_tiled属性将其平铺。这样随着进度增长指示器就像由许多小色块拼接而成非常适合做“力量条”、“分段电量”这种游戏化或风格化的设计。4.3 灵活控制绘制方向与RTL支持Bar控件的方向是自动根据宽高比决定的宽度高度时为水平反之为垂直。但有时我们需要更精确的控制或者需要支持从右向左RTL的布局比如阿拉伯语界面。控制基础方向可以通过lv_obj_set_style_base_dir来实现。这个属性影响的是控件内部绘制的起始点。lv_obj_t *bar_rtl lv_bar_create(lv_scr_act()); lv_obj_set_size(bar_rtl, 200, 20); lv_obj_align(bar_rtl, LV_ALIGN_CENTER, 0, 60); lv_bar_set_value(bar_rtl, 70, LV_ANIM_OFF); // 默认方向从左到右 (LV_BASE_DIR_LTR) // 设置为从右到左 lv_obj_set_style_base_dir(bar_rtl, LV_BASE_DIR_RTL, LV_PART_MAIN); // 为指示器也设置一个相反的渐变方向以匹配 lv_obj_set_style_bg_grad_dir(bar_rtl, LV_GRAD_DIR_HOR, LV_PART_INDICATOR); // 渐变方向仍是水平 // 但因为在RTL模式下绘制起点是右边所以视觉效果上渐变方向也反了设置LV_BASE_DIR_RTL后进度条的填充方向会变成从右向左。这在做国际化项目时非常重要。需要注意的是这个属性通常设置在LV_PART_MAIN上它会影响到该对象的所有部分。如果你同时使用了渐变可能需要根据方向调整渐变起止颜色以达到一致的视觉逻辑。5. 综合案例打造一个音乐播放器进度条现在我们把前面学到的所有技巧融合起来做一个实战性很强的例子一个音乐播放器的进度条。这个进度条需要具备1显示播放进度2可点击跳转3显示已缓冲的区间4美观的现代样式。我们将使用两个Bar控件叠加来实现底层Bar显示缓冲进度灰色渐变上层Bar显示播放进度蓝色渐变并且上层Bar响应点击。// 创建底层Bar缓冲进度 lv_obj_t *bar_buffered lv_bar_create(lv_scr_act()); lv_obj_set_size(bar_buffered, 300, 8); lv_obj_align(bar_buffered, LV_ALIGN_CENTER, 0, 0); lv_bar_set_range(bar_buffered, 0, 100); lv_bar_set_value(bar_buffered, 85, LV_ANIM_OFF); // 假设已缓冲85% // 样式浅灰色渐变圆角 lv_obj_set_style_bg_color(bar_buffered, lv_color_hex(0xcccccc), LV_PART_MAIN); lv_obj_set_style_radius(bar_buffered, 4, LV_PART_MAIN); lv_obj_set_style_bg_color(bar_buffered, lv_color_hex(0xeeeeee), LV_PART_INDICATOR); lv_obj_set_style_bg_grad_color(bar_buffered, lv_color_hex(0xaaaaaa), LV_PART_INDICATOR); lv_obj_set_style_bg_grad_dir(bar_buffered, LV_GRAD_DIR_HOR, LV_PART_INDICATOR); lv_obj_set_style_radius(bar_buffered, 3, LV_PART_INDICATOR); // 创建上层Bar播放进度并置于缓冲条之上 lv_obj_t *bar_progress lv_bar_create(lv_scr_act()); lv_obj_set_size(bar_progress, 300, 8); lv_obj_align(bar_progress, LV_ALIGN_CENTER, 0, 0); // 与缓冲条位置相同 lv_bar_set_range(bar_progress, 0, 100); lv_bar_set_value(bar_progress, 45, LV_ANIM_OFF); // 当前播放到45% // 样式蓝色渐变更显眼无背景透明 lv_obj_set_style_bg_opa(bar_progress, LV_OPA_TRANSP, LV_PART_MAIN); // 背景完全透明 lv_obj_set_style_bg_color(bar_progress, lv_color_hex(0x1dd1a1), LV_PART_INDICATOR); lv_obj_set_style_bg_grad_color(bar_progress, lv_color_hex(0x0abde3), LV_PART_INDICATOR); lv_obj_set_style_bg_grad_dir(bar_progress, LV_GRAD_DIR_HOR, LV_PART_INDICATOR); lv_obj_set_style_radius(bar_progress, 3, LV_PART_INDICATOR); // 为上层播放进度条添加点击事件 lv_obj_add_flag(bar_progress, LV_OBJ_FLAG_CLICKABLE); // 确保可点击 lv_obj_add_event_cb(bar_progress, music_bar_click_cb, LV_EVENT_CLICKED, NULL); // 再创建一个小圆点作为“滑块”放在进度条末尾增强视觉反馈 lv_obj_t * slider_knob lv_obj_create(lv_scr_act()); lv_obj_set_size(slider_knob, 16, 16); lv_obj_set_style_radius(slider_knob, LV_RADIUS_CIRCLE, 0); lv_obj_set_style_bg_color(slider_knob, lv_color_white(), 0); lv_obj_set_style_shadow_width(slider_knob, 8, 0); lv_obj_set_style_shadow_color(slider_knob, lv_palette_main(LV_PALETTE_BLUE), 0); // 需要用一个任务或事件回调来实时更新这个圆点的位置使其跟随播放进度这个案例的关键点是层次结构和事件处理。两个Bar重叠通过将上层Bar的背景设置为透明使得下层缓冲条得以显示。点击事件绑定在上层的播放进度条上因为它在最上面。计算点击位置并更新播放进度时只需要更新bar_progress的值即可。那个小圆点滑块是额外的“加分项”它不参与逻辑只是视觉装饰需要你根据进度条的当前值实时计算并更新它的位置这可以通过一个定时器或在每次进度更新后同步位置来实现。通过这个综合案例你应该能感受到将Bar控件的模式、样式、动画和交互组合起来就能创造出满足复杂设计需求的UI组件。在实际项目中我常常会先画出想要的效果图然后拆解它是由哪些基本的样式属性圆角、渐变、边框、阴影构成的再用LVGL的代码去一一实现。多尝试、多组合你的进度条也能变得与众不同。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2411976.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…