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

【HarmonyOS Next】地图使用详解(三)标点定位问题

背景

在使用geoLocationManager的getCurrentLocation方法获得的用户定位经纬度的坐标系为 WGS84 ,但是mapkit使用的是GCJ02坐标系。因此,我们在使用获取用户经纬度然后直接生成标记时,会出现坐标偏移问题。如下:
在这里插入图片描述

解决方案

使用map.convertCoordinateSync方法,对已有的经纬度进行坐标系转换,生成GCJ02坐标系下的经纬度数值。
其中this.LocationLongitude和this.LocationLatitude都是viewmodel类中定义的经纬度。

直接获取经纬度代码

  /*** 更新用户定位*/public async UpdateLocation() {try {const result = await geoLocationManager.getCurrentLocation();this.LocationLongitude = result.longitude;this.LocationLatitude = result.latitude;} catch (err) {console.info("VM", "errCode:" + JSON.stringify(err));}}

获取转换后经纬度代码

public async UpdateLocationByConvert() {try {const result = await geoLocationManager.getCurrentLocation();let wgs84Position: mapCommon.LatLng = {latitude: result.latitude,longitude: result.longitude};let gcj02Position: mapCommon.LatLng =map.convertCoordinateSync(mapCommon.CoordinateType.WGS84, mapCommon.CoordinateType.GCJ02, wgs84Position);this.LocationLongitude = gcj02Position.longitude;this.LocationLatitude = gcj02Position.latitude;} catch (err) {console.info("VM", "errCode:" + JSON.stringify(err));}}

实现效果:
请添加图片描述

完整代码

View

import { MapComponent } from "@kit.MapKit"
import { MapBlogViewModel } from "../ViewModels/MapBlogViewModel"@Entry
@ComponentV2
export struct MapBlogDemo {@Local MapVM: MapBlogViewModel = new MapBlogViewModel()aboutToAppear(): void {}build() {RelativeContainer() {MapComponent({mapOptions: this.MapVM.MapOption,mapCallback: this.MapVM.MapCallBack}).width("100%").height('70%').id("Map")Column({ space: 10 }) {Button("在我的位置创造一个标点").onClick(() => {this.MapVM.CreateLocationMarkerEvent();})Button("在我的位置创造一个转换后的标点").onClick(async () => {await this.MapVM.UpdateLocationByConvert();this.MapVM.CreateLocationMarkerEvent();})}.width("100%").height('30%').alignRules({top: { anchor: "Map", align: VerticalAlign.Bottom },bottom: { anchor: "__container__", align: VerticalAlign.Bottom }})}.height('100%').width('100%')}
}

ViewModel

import { map, mapCommon, sceneMap } from "@kit.MapKit"
import { AsyncCallback } from "@kit.BasicServicesKit"
import { geoLocationManager } from "@kit.LocationKit"
import { common } from "@kit.AbilityKit"
import { trustedAppService } from "@kit.DeviceSecurityKit"@ObservedV2
export class MapBlogViewModel {/*** 地图初始化参数设置*/@Trace MapOption?: mapCommon.MapOptions/*** 地图回调方法*/MapCallBack?: AsyncCallback<map.MapComponentController>/*** 地图控制器*/@Trace MapController?: map.MapComponentController/*** 地图监听管理器*/@Trace MapEventManager?: map.MapEventManager/*** 当前位置的维度*/public LocationLatitude: number = 39.9;/*** 当前位置的经度*/public LocationLongitude: number = 116.4;/*** 缩放数值*/public ZoomNumber: number = 20/*** 定位标记*/@Trace LocationMarker?: map.Markerconstructor() {this.MapOption = {//相机位置position: {target: {latitude: 39.9,longitude: 116.4},zoom: this.ZoomNumber},//地图类型mapType: mapCommon.MapType.STANDARD,//地图最小图层,默认值为2minZoom: 2,//地图最大图层,默认值为20maxZoom: 20,//是否支持旋转手势rotateGesturesEnabled: true,//是否支持滑动手势scrollGesturesEnabled: true,//是否支持缩放手势zoomGesturesEnabled: true,//是否支持倾斜手势tiltGesturesEnabled: true,//是否展示缩放控件zoomControlsEnabled: true,//是否展示定位按钮myLocationControlsEnabled: true,//是否展示指南针控件compassControlsEnabled: true,//是否展示比例尺scaleControlsEnabled: false,//是否一直显示比例尺,只有比例尺启用时该参数才生效。alwaysShowScaleEnabled: false};this.MapCallBack = async (err, mapController) => {if (!err) {this.MapController = mapController;//地图监听时间管理器this.MapEventManager = this.MapController.getEventManager();//启用我的位置图层this.MapController.setMyLocationEnabled(true);this.UpdateLocation().then(() => {});}}this.MoveCamera(this.LocationLatitude, this.LocationLongitude)}/*** 创建我的位置定位标记*/public async CreateLocationMarkerEvent() {let markerKey: string = 'DirectionKey';// Marker初始化参数let markerOptions: mapCommon.MarkerOptions = {position: {latitude: this.LocationLatitude,longitude: this.LocationLongitude},rotation: 0,visible: true,zIndex: 0,alpha: 1,anchorU: 0.5,anchorV: 1,clickable: false,draggable: false,flat: false,icon: "LocationIcon.svg",infoWindowAnchorU: 0,infoWindowAnchorV: 0};if (this.MapController) {// 创建Markerthis.LocationMarker = await this.MapController.addMarker(markerOptions);//设置标记可以拖拽this.LocationMarker.setDraggable(false);// 设置信息窗的标题// this.LocationMarker.setTitle(markerKey);// 设置标记可点击this.LocationMarker.setClickable(false);// 设置信息窗的锚点位置this.LocationMarker.setInfoWindowAnchor(1, 1);this.MoveCamera(this.LocationLatitude, this.LocationLongitude);}}/*** 展示地点选取页,更新标记地点*/public async ShowChoosingLocation() {let locationChoosingOptions: sceneMap.LocationChoosingOptions = {// 地图中心点坐标location: { latitude: this.LocationLatitude, longitude: this.LocationLongitude },language: 'zh_cn',// 展示搜索控件searchEnabled: true,// 展示附近PoishowNearbyPoi: true};// 拉起地点选取页let result: sceneMap.LocationChoosingResult =await sceneMap.chooseLocation(getContext(this) as common.UIAbilityContext, locationChoosingOptions);this.LocationLatitude = result.location.latitude;this.LocationLongitude = result.location.longitude;animateTo({duration: 500}, () => {this.MoveCamera(this.LocationLatitude, this.LocationLongitude);this.UpdateLocationMarker(result.location);})}/*** 更新定位位置* @param latLng*/private UpdateLocationMarker(latLng: mapCommon.LatLng) {if (this.LocationMarker) {this.LocationLatitude = latLng.latitude;this.LocationLongitude = latLng.longitude;this.LocationMarker.setPosition(latLng);}}/*** 更新用户定位*/public async UpdateLocation() {try {const result = await geoLocationManager.getCurrentLocation();this.LocationLongitude = result.longitude;this.LocationLatitude = result.latitude;} catch (err) {console.info("VM", "errCode:" + JSON.stringify(err));}}public async UpdateLocationByConvert() {try {const result = await geoLocationManager.getCurrentLocation();let wgs84Position: mapCommon.LatLng = {latitude: result.latitude,longitude: result.longitude};let gcj02Position: mapCommon.LatLng =map.convertCoordinateSync(mapCommon.CoordinateType.WGS84, mapCommon.CoordinateType.GCJ02, wgs84Position);this.LocationLongitude = gcj02Position.longitude;this.LocationLatitude = gcj02Position.latitude;} catch (err) {console.info("VM", "errCode:" + JSON.stringify(err));}}/*** 移动视图相机* @param latitude 维度* @param longitude 经度*/public async MoveCamera(latitude: number, longitude: number) {if (this.MapController) {//将视图移动到标点位置let nwPosition = map.newCameraPosition({target: {latitude: latitude,longitude: longitude},zoom: 15})// 以动画方式移动地图相机this.MapController.animateCamera(nwPosition, 1000);}}
}

总结

上面地图遇到获取当前位置的经纬度的数值直接用来做标点时候,标点位置不正确的bug

相关文章:

【HarmonyOS Next】地图使用详解(三)标点定位问题

背景 在使用geoLocationManager的getCurrentLocation方法获得的用户定位经纬度的坐标系为 WGS84 &#xff0c;但是mapkit使用的是GCJ02坐标系。因此&#xff0c;我们在使用获取用户经纬度然后直接生成标记时&#xff0c;会出现坐标偏移问题。如下&#xff1a; 解决方案 使用…...

Linux运维中常用的磁盘监控方式

在Linux运维中&#xff0c;磁盘监控是一项关键任务&#xff0c;因为它能帮助我们预防磁盘空间不足或性能问题导致的服务中断或数据丢失。让我们来看看有哪些常用的磁盘监控方法吧&#xff01; 1. 查看磁盘使用情况&#xff08;df命令&#xff09; df命令用于显示文件系统的…...

前端面经-VUE3篇--vue3基础知识(二)计算属性(computed)、监听属性(Watch)

一、计算属性(computed) 计算属性&#xff08;Computed Properties&#xff09;是 Vue 中一种特殊的响应式数据&#xff0c;它能基于已有的响应式数据动态计算出新的数据。 计算属性有以下特性&#xff1a; 自动缓存&#xff1a;只有当它依赖的响应式数据发生变化时&#xff…...

双向链表详解

一、双向链表介绍 二、实现双向链表 1.定义双向链表的结构 2.双向链表的初始化 3.双向链表的尾插 4.双向链表的头插 5.双向链表的打印 6.双向链表的尾删 7.双向链表的头删 8.查找指定位置的数据 9.在指定位置之后插入数据 10.删除指定位置的数据 11.链表的销毁 三、…...

基于SpringBoot+Vue实现的电影推荐平台功能一

一、前言介绍&#xff1a; 1.1 项目摘要 2023年全球流媒体用户突破15亿&#xff0c;用户面临海量内容选择困难&#xff0c;传统推荐方式存在信息过载、推荐精准度低等问题。传统推荐系统存在响应延迟高&#xff08;平均>2s&#xff09;。随着互联网的快速发展&#xff0c;…...

预订接口优化:使用本地消息表保证订单生成、库存扣减的一致性

&#x1f3af; 本文介绍了一种优化预订接口的方法&#xff0c;通过引入本地消息表解决分布式事务中的最终一致性问题。原先的实现是在一个事务中同时扣减库存和创建订单&#xff0c;容易因网络不稳定导致数据不一致。改进后的方法将业务操作和消息发送封装在本地事务中&#xf…...

深度学习与 PyTorch 基础

笔记 1 深度学习简介 1.1 深度学习概念 深度学习是机器学习的一类算法, 以人工神经网络为结构, 可以实现自动提取特征 深度学习核心思想是人工神经网络为结构, 自动提取特征 1.2 深度学习特点 自动提取特征 解释性差 大量数据和高性能计算能力 非线性转换(引入非线性因…...

libevent库详解:高性能异步IO的利器

目录 一、libevent 简介 主要特点&#xff1a; 二、事件模型原理 1. event_base 2. event 3. evconnlistener&#xff08;TCP监听器&#xff09; 4. bufferevent 简化流程如下&#xff1a; 三、libevent 使用示例 1. 创建事件主循环 2. 创建监听器&#xff08;TCP&a…...

第一章:A Primer on Memory Consistency and Cache Coherence - 2nd Edition

引言&#xff1a; 许多现代计算机系统&#xff0c;包括同构和异构架构的系统&#xff0c;都在硬件层面支持共享内存。在共享内存系统中&#xff0c;每个处理器核心都可以对单一的共享地址空间进行读写操作。对于共享内存计算机而言&#xff0c;内存一致性模型定义了其内存系统在…...

NVIDIA Omniverse在数字孪生中的算力消耗模型构建方法

引言&#xff1a;虚拟实验室的算力经济学 在高校虚拟实验室建设中&#xff0c;数字孪生系统的实时物理仿真精度与算力成本之间存在显著矛盾。以H800 GPU集群为例&#xff0c;单个8卡节点每秒可处理2.3亿个物理粒子交互&#xff0c;但若未建立精准的算力消耗模型&#xff0c;资…...

C++ 动态内存管理详讲

1. 四个全局函数的定义与作用 这四个函数只负责空间的开辟和释放&#xff0c;不会调构造和析构 (1) ::operator new cpp void* operator new(size_t size); // 全局版本 功能&#xff1a;分配 size 字节的未初始化内存。 底层实现&#xff1a;调用 malloc(size)。 调用场…...

纹理对象创建

纹理对象通俗点就是贴图&#xff0c;像游戏的皮肤什么就是纹理。常间的结构就是激活纹理单元&#xff08;0-15有16个&#xff09;&#xff0c;将纹理对象挂在纹理单元上&#xff0c;纹理采样器需要采哪个样品就与哪个单元挂钩就行了&#xff0c;加载纹理对象需要用到stb_image库…...

如何利用dify 生成Fine‑tune 需要的Alpaca 格式数据

如果你选择llamafactory 格式进行微调&#xff0c;它只是格式是Alpaca格式&#xff0c;dify 的agent dsl 如下&#xff0c;你可以导入本地的dify 或者导入cloud 版本的&#xff1b;测试版本是0.1.5 app:description: 上传文件&#xff0c;基于文件内容&#xff0c;使用 Silico…...

软件第三方测试:关键部分、意义、流程及方法全解析?

软件第三方测试是保障软件质量的关键部分&#xff0c;它由专业的机构来开展&#xff0c;这个机构不隶属于开发方和使用方&#xff0c;能以客观公正的视角找出软件问题。 测试意义 软件第三方测试意义重大&#xff0c;它依靠专业技术&#xff0c;依照严格流程&#xff0c;对软…...

贪心算法解决会议安排问题

文章目录 前言 一、什么是贪心算法&#xff1f; 贪心算法的基本概念&#xff1a;贪心算法并不从整体最优上加以考虑&#xff0c;所做的选择只是在某种意义上的局部最优选择。 二、会议安排题目 1.题目理解 2.思路剖析 总结 前言 本文将主要介绍贪心算法需要注意的地方以…...

高露洁牙膏是哪个国家的品牌?高露洁牙膏哪一款最好?

高露洁是来自于美国一个比较有知名度的品牌&#xff0c;在1806年的时候创立。总部是在美国纽约公园大道&#xff0c;在1873年时&#xff0c;高露洁就已经开始销售罐装牙膏。 在1896年时期推出可折叠管牙膏&#xff0c;在口腔护理产品发展的过程中拥有着不容忽视的地位。在1992…...

lin接口在线计算数据帧的校验位

在线校验计算链接&#xff1a;https://linchecksumcalculator.machsystems.cz/ 插入图片&#xff1a;...

Linux-07-Shell

一、Shell概述: Shell是一个命令行解释器&#xff0c;它接受应用程序/用户命令&#xff0c;然后调用操作系统内核 二、Shell中的变量: 1.系统预定义的变量: $HOME,$PWD,$SHELL,$USER等 2.用户自定义的变量: (1).基本语法: 定义变量:变量名变量值&#xff0c;注意前后不能…...

【云盘】使用阿里云盘托管项目大文件

【云盘】使用阿里云盘托管项目大文件 由于经常需要切换服务器运行项目实验&#xff0c;不同服务器在项目实验过程中会产生不同的数据、模型等较大文件&#xff0c;不能像代码那样能够使用git托管&#xff0c;因此考虑使用阿里云盘作为”第三方平台“托管这些大文件。 一、使用…...

《缓存策略:移动应用网络请求的“效能密钥” 》

用户体验无疑是重中之重&#xff0c;而网络请求性能&#xff0c;恰似一座桥梁&#xff0c;连接着用户与应用丰富的内容和功能。当网络不佳或者请求频繁时&#xff0c;缓慢的响应速度常常让用户兴致索然&#xff0c;甚至可能导致用户流失。此时&#xff0c;缓存策略就如同一位幕…...

深入解析C++11委托构造函数:消除冗余初始化的利器

一、传统构造函数的痛点 在C11之前&#xff0c;当多个构造函数需要执行相同的初始化逻辑时&#xff0c;开发者往往面临两难选择&#xff1a; class DataProcessor {std::string dataPath;bool verbose;int bufferSize; public:// 基础版本DataProcessor(const std::string&am…...

文章七《深度学习调优与超参数优化》

&#x1f680; 文章7&#xff1a;深度学习调优与超参数优化——你的AI模型需要一场"整容手术" 一、模型调优核心策略&#xff1a;像调整游戏装备一样优化模型 1. 学习率调整&#xff1a;掌控训练的"油门踏板" 比喻&#xff1a;把模型训练想象成赛车游戏&…...

python入门(1)变量与输入输出

一、变量 使用规则 变量名值例子 a13变量名规则 变量名可以用大小写字母、数字、下划线。 数字、下划线不可开头 例子 name name1 1name name_first _first 二、输入输出 输出print print(*objects,sep"",end"\n") objects:多个要输出的值 sep:每个…...

藏文情感分析器入门学习实践

&#x1f3af; 项目目标&#xff1a; 输入一段藏文短句。自动分析这句话的情感倾向&#xff1a;积极&#xff08;正面&#xff09;/消极&#xff08;负面&#xff09;/中立。 &#x1f50d; 技术原理简介 情感分析是什么&#xff1f; 情感分析&#xff08;Sentiment Analysi…...

爱胜品ICSP YPS-1133DN Plus黑白激光打印机报“自动进纸盒进纸失败”处理方法之一

故障现象如下图提示&#xff1a; 用户的爱胜品ICSP YPS-1133DN Plus黑白激光打印机在工作过程中提示自动进纸盒进纸失败并且红色故障灯闪烁&#xff1b; 给出常见故障一般处理建议如下&#xff1a; 当您的爱胜品ICSP YPS-1133DN Plus 黑白激光打印机出现“自动进纸盒进纸失败”…...

数据库索引重建与优化操作在数据库性能维护与数据更新频繁场景下的应用

数据库索引重建与优化操作在数据库性能维护与数据更新频繁场景下的应用 数据库索引的作用与重要性 索引的定义与作用 数据库索引是一种特殊的数据结构&#xff0c;用于加快数据库表的数据检索速度。它类似于书籍的目录&#xff0c;能够快速定位到需要的数据页&#xff0c;而不必…...

前端应用开发技术历程的简要概览

前端应用开发技术详解 一、萌芽期&#xff08;1990s - 2004&#xff09; 技术特征 HTML 3.2 / HTML 4.01 是主流版本。 样式用 CSS1/CSS2&#xff0c;但大部分样式写在 <style> 标签甚至行内。 动态效果主要通过 JavaScript 控制 DOM&#xff0c;兼容性极差。 代表事…...

SPOJ 11576 TRIP2 - A Famous King’s Trip 【Tarjan+欧拉回路】

自我吐槽 &#xff08;哭 题目传送门 SPOJ 洛谷 题目大意 让你在简单无向图上删去2条边&#xff0c;使该图联通并存在欧拉回路 输出字典序最小的一对边 思路 考虑到存在欧拉回路的充要条件&#xff0c;即 i n x ≡ 0 ( m o d 2 ) ∀ i ( 1 ≤ i ≤ n ) in_x\equiv 0 (\m…...

DeepSeek R1:强化学习范式的推理强化模型

定位与目标 DeepSeek R1 的推出并非 DeepSeek V3 的简单迭代,而是一次在训练范式上的大胆探索。与传统大模型主要依靠监督微调(SFT)后进行强化学习不同,R1 将重点放在推理能力和行为对齐上,尝试通过大规模强化学习直接激发模型的推理潜力。其目标是利用强化学习的反馈机制,…...

ubuntu22.04安装显卡驱动与cuda+cuDNN

背景&#xff1a; 紧接前文&#xff1a;Proxmox VE 8.4 显卡直通完整指南&#xff1a;NVIDIA 2080 Ti 实战。在R740服务器完成了proxmox的安装&#xff0c;并且安装了一张2080ti 魔改22g显存的的显卡。配置完了proxmox显卡直通&#xff0c;并将显卡挂载到了vm 301&#xff08;…...

使用python爬取百度搜索中关于python相关的数据信息

Python爬取百度搜索"Python"相关数据信息 一、准备工作 在开始爬取之前&#xff0c;需要了解以下几点&#xff1a; 百度搜索有反爬机制&#xff0c;需要合理设置请求头百度搜索结果页面结构可能会变化需要遵守robots.txt协议&#xff08;百度允许爬取搜索结果&…...

Bootstrap(自助法)​​:无需假设分布的统计推断工具

核心思想​​ Bootstrap 是一种​​重采样&#xff08;Resampling&#xff09;技术​​&#xff0c;通过在原始数据中​​有放回地重复抽样​​&#xff0c;生成大量新样本集&#xff0c;用于估计统计量&#xff08;如均值、方差&#xff09;的分布或模型性能的不确定性。 ​​…...

lib和dll介绍和VS2019生成实例

目录 lib文件和dll文件的作用dll和lib的优缺点VS2019 编译YOLOv5的dll和lib lib文件和dll文件的作用 (1)lib是编译时需要的&#xff0c;dll是运行时需要的。 如果要完成源代码的编译&#xff0c;有lib就够了。 如果也使动态连接的程序运行起来&#xff0c;有dll就够了。 在开发…...

tinycudann安装过程加ubuntu18.04gcc版本的升级(成功版!!!!)

使用的是 Linux&#xff0c;安装以下软件包 sudo apt-get install build-essential git安装 CUDA 并将 CUDA 安装添加到您的 PATH。 例如&#xff0c;如果您有 CUDA 12.6.3&#xff0c;请将以下内容添加到您的/usr/local/~/.bashrcexport PATH"/usr/local/cuda-12.6.3/bi…...

数字智慧方案5869丨智慧健康医疗养老大数据整体规划方案(76页PPT)(文末有下载方式)

资料解读&#xff1a;智慧健康医疗养老大数据整体规划方案 详细资料请看本解读文章的最后内容。 随着科技的飞速发展&#xff0c;健康医疗领域正经历着一场深刻的变革。特别是在大数据和人工智能技术的推动下&#xff0c;智慧健康医疗养老的整体规划方案逐渐浮出水面。本文将…...

使用huggingface_hub需要注意的事项

在安装huggingface_hub的时候要注意如果你的python是放在c盘下时记得用管理员模式命令行来安装huggingface_hub&#xff0c;否则安装过程会报错&#xff0c;之后也不会有huggingface-cli命令。 如果安装时因为没有用管理员权限安装而报错了&#xff0c;可以先卸载huggingface-…...

Matplotlib核心课程-2

4.1 数据加载、储存 4.1.1 从数据文件读取数据 导入支持库&#xff1a; import numpy as np from pandas import Series,DataFrame import pandas as pd 从csv文件读取数据&#xff0c;一般方法&#xff1a; pd.read_csv(../data/ex1.csv,encodinggbk) 从csv文件读取数据&#…...

友元函数和友元类

友元 友元是 C 提供的一种 打破封装 的机制&#xff0c;允许 友元函数 或 友元类 访问某个类的 非公有成员&#xff08;private/protected&#xff09;。 友元函数 友元函数 可以 直接访问 类的所有 成员&#xff0c;它是 定义在类外部 的 普通函数 &#xff0c;不属于任何类…...

5.2刷题

P1064 [NOIP 2006 提高组] 金明的预算方案 背包&#xff0b;附属品DP #include<bits/stdc.h> using namespace std; #define int long long int n, m, v, p, q; struct node{int id, v, s, f; }a[100]; int b[32010], dp[32010]; bool cmp(node a, node b){if(a.id b.…...

用VNA进行天线阻抗匹配的实例大图

比如我这天线&#xff0c;在7Mhz时不谐振&#xff0c;我进行匹配 天线的阻抗很高&#xff0c;大约是在500-1400欧&#xff0c;而等效电容电感很小。 所以我考虑使用阻抗变压器降低阻抗。 1。测试天线阻抗&#xff0c;电阻相当高&#xff0c;等效电容很小。 2。通过磁环匹配到…...

普通IT的股票交易成长史--20250502 突破(1)

声明&#xff1a;本文章的内容只是自己学习的总结&#xff0c;不构成投资建议。文中观点基本来自yt站方方土priceaction&#xff0c;综合自己的观点得出。感谢他们的无私分享。 送给自己的话&#xff1a; 仓位就是生命&#xff0c;绝对不能满仓&#xff01;&#xff01;&#…...

[预备知识]5. 优化理论(一)

优化理论 梯度下降&#xff08;Gradient Descent&#xff09; 数学原理与可视化 梯度下降是优化领域的基石算法&#xff0c;其核心思想是沿负梯度方向迭代更新参数。数学表达式为&#xff1a; θ t 1 θ t − α ∇ θ J ( θ t ) \theta_{t1} \theta_t - \alpha \nabla…...

AI人工智能的接入和使用

缘起 从参加工作开始就在从事AI的落地和接入&#xff0c;到现在已经25年了。所以对AI一直有种情怀&#xff0c;还写了一系列的《基于语音识别的智能电子病历》的文章&#xff0c;记录了这条路上的潮起潮落。 年少多痴狂 2015年开始负责开发语音识别引擎语义分析&#xff0c;…...

QT6(32)4.5常用按钮组件:Button 例题的代码实现

&#xff08;103&#xff09; 先设置对齐&#xff1a; 再设置粗体、斜体、下划线&#xff1a; 给出这三个按钮的源码; 颜色按钮的实现 &#xff1a; 至此完结&#xff0c;谢谢老师们的无私教导。 &#xff08;104&#xff09; 谢谢...

B站Michale_ee——ESP32_IDF SDK——FreeRTOS_8 消息缓冲区

Message Buffer&#xff08;消息缓冲区&#xff09;与Stream Buffer&#xff08;流数据缓冲区&#xff09;类似&#xff0c;但有2点不同&#xff1a; Message Buffer每次只接收1次完整的Message;Message Buffer接收缓冲区小于1条Message大小时&#xff0c;会接收不到数据&#…...

DarkGS:论文解读与全流程环境配置及数据集测试【基于Ubuntu20.04 】【2025最新实战无坑版!!】

一、背景及意义 DarkGS是一个创新性的研究项目&#xff0c;旨在解决机器人在黑暗或低光照环境中探索的问题。传统的3D重建和视觉定位系统在光照条件不佳时表现不佳&#xff0c;这严重限制了机器人在黑暗环境中的应用&#xff0c;如夜间救援、深海探索或洞穴勘测等场景。 这项工…...

【大模型面试每日一题】Day 6:分布式训练中 loss 出现 NaN,可能原因及排查方法?

【大模型面试每日一题】Day 6&#xff1a;分布式训练中 loss 出现 NaN&#xff0c;可能原因及排查方法&#xff1f; &#x1f4cc; 题目重现 &#x1f31f;&#x1f31f; 面试官&#xff1a;你在使用 PyTorch 进行大规模语言模型的分布式训练时&#xff0c;发现 loss 变成 Na…...

[面试]SoC验证工程师面试常见问题(二)

SoC验证工程师面试常见问题(二) 摘要:面试SoC验证工程师时,SystemVerilog (SV) 和 UVM (Universal Verification Methodology) 是核心技能,而AXI总线是现代SoC中最常见的接口协议之一,因此也是必考点。以下是可能被问到的问题及优质答案的详细列表: 一、 System…...

BLE协议栈的解析

目录 概述 1 BLE协议栈层次结构 1.1 控制器&#xff08;Controller&#xff09; 1.2 主机&#xff08;Host&#xff09; 1.3 应用层(Application) 1.3.1 业务层功能 1.3.2 实现方法 2 重要属性介绍 2.1 GATT属性 2.2 服务&#xff08;Service&#xff09; 2.3 特征值…...

中小企业MES系统需求文档

适用对象&#xff1a;中小型离散制造企业&#xff08;年产值1-5亿&#xff0c;员工200-800人&#xff09; 版本&#xff1a;V1.0 日期&#xff1a;2025年5月2日 一、业务背景与目标 1.1 现状痛点 生产黑箱化&#xff1a;车间进度依赖人工汇报&#xff0c;异常响应延迟>2小…...