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

Unity利用噪声生成动态地形

引言

在游戏开发中,地形是构建游戏世界的基础元素之一。传统的地形创建方法通常依赖于手动建模或预设资源,这种方式虽然精确但缺乏灵活性,且工作量巨大。而使用噪声算法生成地形则提供了一种程序化、动态且高效的解决方案。本文将详细介绍如何在Unity中利用噪声函数生成动态地形,从基本概念到实际实现,帮助开发者掌握这一强大技术。

噪声函数基础

什么是噪声函数?

噪声函数是一种数学函数,能够生成看似随机但实际上是确定性的值。在地形生成中,最常用的噪声函数包括:

  1. Perlin噪声:由Ken Perlin在1980年代开发,能生成自然流畅的随机模式
  2. Simplex噪声:Perlin噪声的改进版,计算效率更高,尤其在高维度空间
  3. 分形布朗运动(FBM):通过叠加不同频率和振幅的噪声来创造更复杂的模式
  4. Worley噪声:也称为Cellular噪声,可以创建类似细胞或蜂窝状的模式

噪声参数解析

理解以下关键参数对掌握噪声地形生成至关重要:

  • 频率(Frequency):控制噪声变化的密集程度,高频率产生更多细节
  • 振幅(Amplitude):控制噪声值的范围大小,影响地形的高度变化
  • 八度(Octaves):叠加的噪声层数,增加八度数可以增加地形细节
  • 持续度(Persistence):控制每个八度的振幅如何变化
  • 粗糙度(Lacunarity):控制每个八度的频率如何变化
  • 种子(Seed):初始化噪声生成的随机数,相同种子产生相同地形

Unity中实现噪声地形生成

基本方法

在Unity中生成噪声地形主要有两种方式:

  1. Mesh生成法:直接创建和修改网格顶点
  2. Unity地形系统:利用Unity内置的Terrain系统

我们将重点介绍Mesh生成法,因为它提供了更多的灵活性和控制力。

实现步骤

1. 创建基础项目结构

首先,创建一个新的Unity项目并设置基本场景:

using UnityEngine;public class TerrainGenerator : MonoBehaviour
{[Header("地形设置")]public int width = 256;public int height = 256;public float scale = 20f;[Header("噪声设置")]public int octaves = 4;public float persistence = 0.5f;public float lacunarity = 2f;public int seed = 42;public Vector2 offset = Vector2.zero;[Header("地形网格")]public float heightMultiplier = 10f;public AnimationCurve heightCurve;private MeshFilter meshFilter;private MeshRenderer meshRenderer;void Start(){// 初始化组件meshFilter = GetComponent<MeshFilter>();meshRenderer = GetComponent<MeshRenderer>();// 生成地形GenerateTerrain();}// 更新地形(可在运行时调用以动态更新)public void GenerateTerrain(){// 实现地形生成逻辑}
}
2. 实现噪声函数

接下来,我们需要实现噪声计算函数:

// 生成噪声高度图
float[,] GenerateNoiseMap()
{float[,] noiseMap = new float[width, height];// 使用种子初始化随机数生成器System.Random prng = new System.Random(seed);Vector2[] octaveOffsets = new Vector2[octaves];for (int i = 0; i < octaves; i++){float offsetX = prng.Next(-100000, 100000) + offset.x;float offsetY = prng.Next(-100000, 100000) + offset.y;octaveOffsets[i] = new Vector2(offsetX, offsetY);}float maxNoiseHeight = float.MinValue;float minNoiseHeight = float.MaxValue;// 计算噪声中心点,使缩放效果以地图中心为基准float halfWidth = width / 2f;float halfHeight = height / 2f;for (int y = 0; y < height; y++){for (int x = 0; x < width; x++){float amplitude = 1;float frequency = 1;float noiseHeight = 0;// 计算多个八度的噪声叠加for (int i = 0; i < octaves; i++){float sampleX = (x - halfWidth) / scale * frequency + octaveOffsets[i].x;float sampleY = (y - halfHeight) / scale * frequency + octaveOffsets[i].y;// 使用Unity内置的Perlin噪声函数float perlinValue = Mathf.PerlinNoise(sampleX, sampleY) * 2 - 1;noiseHeight += perlinValue * amplitude;// 应用持续度和粗糙度amplitude *= persistence;frequency *= lacunarity;}// 记录最大和最小噪声高度,用于后续归一化if (noiseHeight > maxNoiseHeight)maxNoiseHeight = noiseHeight;if (noiseHeight < minNoiseHeight)minNoiseHeight = noiseHeight;noiseMap[x, y] = noiseHeight;}}// 归一化噪声值到0-1范围for (int y = 0; y < height; y++){for (int x = 0; x < width; x++){noiseMap[x, y] = Mathf.InverseLerp(minNoiseHeight, maxNoiseHeight, noiseMap[x, y]);}}return noiseMap;
}
3. 生成网格

使用噪声高度图生成实际的地形网格:

void GenerateTerrain()
{// 生成噪声高度图float[,] noiseMap = GenerateNoiseMap();// 创建网格数据Mesh mesh = new Mesh();Vector3[] vertices = new Vector3[(width + 1) * (height + 1)];int[] triangles = new int[width * height * 6];Vector2[] uvs = new Vector2[(width + 1) * (height + 1)];// 设置顶点和UV坐标for (int i = 0, y = 0; y <= height; y++){for (int x = 0; x <= width; x++, i++){// 计算顶点高度float heightValue = 0;if (x < width && y < height){heightValue = noiseMap[x, y];// 应用高度曲线和乘数heightValue = heightCurve.Evaluate(heightValue) * heightMultiplier;}vertices[i] = new Vector3(x, heightValue, y);uvs[i] = new Vector2((float)x / width, (float)y / height);}}// 设置三角形索引int vert = 0;int tris = 0;for (int y = 0; y < height; y++){for (int x = 0; x < width; x++){triangles[tris + 0] = vert + 0;triangles[tris + 1] = vert + width + 1;triangles[tris + 2] = vert + 1;triangles[tris + 3] = vert + 1;triangles[tris + 4] = vert + width + 1;triangles[tris + 5] = vert + width + 2;vert++;tris += 6;}vert++;}// 设置网格数据mesh.Clear();mesh.vertices = vertices;mesh.triangles = triangles;mesh.uv = uvs;// 重新计算法线和边界mesh.RecalculateNormals();mesh.RecalculateBounds();// 应用到网格过滤器meshFilter.sharedMesh = mesh;
}
4. 添加材质和纹理

为了使地形更加真实,我们可以添加基于高度的纹理:

[Header("纹理设置")]
public Texture2D[] terrainTextures;  // 不同高度的纹理
public float[] textureHeights;       // 纹理对应的高度阈值// 在GenerateTerrain方法中添加
void ApplyTerrainTexture(float[,] noiseMap)
{int textureWidth = width + 1;int textureHeight = height + 1;// 创建颜色图Texture2D texture = new Texture2D(textureWidth, textureHeight);Color[] colorMap = new Color[textureWidth * textureHeight];for (int y = 0; y < textureHeight; y++){for (int x = 0; x < textureWidth; x++){if (x < width && y < height){float currentHeight = noiseMap[x, y];// 根据高度选择纹理for (int i = 0; i < textureHeights.Length; i++){if (currentHeight <= textureHeights[i]){// 从纹理中采样颜色float u = (float)x / width * terrainTextures[i].width;float v = (float)y / height * terrainTextures[i].height;colorMap[y * textureWidth + x] = terrainTextures[i].GetPixelBilinear(u, v);break;}}}else{// 边缘处理colorMap[y * textureWidth + x] = Color.black;}}}texture.SetPixels(colorMap);texture.Apply();// 应用到渲染器meshRenderer.material.mainTexture = texture;
}

5. 实现动态更新

为了实现动态地形,我们可以添加实时更新功能:

[Header("动态更新")]
public bool autoUpdate = true;
public float updateInterval = 1f;
private float updateTimer = 0f;void Update()
{if (autoUpdate){updateTimer += Time.deltaTime;if (updateTimer >= updateInterval){// 更新偏移以创建移动效果offset += new Vector2(0.01f, 0.01f);GenerateTerrain();updateTimer = 0f;}}
}

高级技术与优化

LOD系统实现

对于大型地形,实现级别细节(LOD)系统至关重要:

[Header("LOD设置")]
public int maxLOD = 3;
public float[] lodDistances = new float[] { 50f, 100f, 200f };void UpdateLOD()
{// 获取到相机的距离float distanceToCamera = Vector3.Distance(Camera.main.transform.position, transform.position);// 根据距离确定LOD级别int currentLOD = maxLOD;for (int i = 0; i < lodDistances.Length; i++){if (distanceToCamera < lodDistances[i]){currentLOD = i;break;}}// 根据LOD级别调整网格细节int lodWidth = width >> currentLOD;  // 位移操作,相当于除以2的currentLOD次方int lodHeight = height >> currentLOD;// 使用调整后的分辨率生成地形GenerateTerrainWithResolution(lodWidth, lodHeight);
}void GenerateTerrainWithResolution(int resWidth, int resHeight)
{// 类似GenerateTerrain,但使用指定分辨率// ...
}

多线程优化

噪声计算是CPU密集型操作,可以使用多线程优化:

using System.Threading;
using System.Collections.Generic;[Header("多线程设置")]
public bool useMultithreading = true;
public int threadCount = 4;// 多线程生成噪声图
float[,] GenerateNoiseMapMultithreaded()
{float[,] noiseMap = new float[width, height];if (!useMultithreading){return GenerateNoiseMap();}// 准备线程参数int rowsPerThread = height / threadCount;Thread[] threads = new Thread[threadCount];NoiseMapThreadInfo[] threadInfos = new NoiseMapThreadInfo[threadCount];// 启动线程for (int i = 0; i < threadCount; i++){int threadIndex = i;threadInfos[i] = new NoiseMapThreadInfo(threadIndex * rowsPerThread,(threadIndex == threadCount - 1) ? height : (threadIndex + 1) * rowsPerThread);threads[i] = new Thread(() => GenerateNoiseMapPart(noiseMap, threadInfos[threadIndex]));threads[i].Start();}// 等待所有线程完成foreach (Thread thread in threads){thread.Join();}// 归一化处理NormalizeNoiseMap(noiseMap);return noiseMap;
}// 线程信息类
class NoiseMapThreadInfo
{public int startY;public int endY;public float maxNoiseHeight;public float minNoiseHeight;public NoiseMapThreadInfo(int startY, int endY){this.startY = startY;this.endY = endY;this.maxNoiseHeight = float.MinValue;this.minNoiseHeight = float.MaxValue;}
}// 生成部分噪声图
void GenerateNoiseMapPart(float[,] noiseMap, NoiseMapThreadInfo threadInfo)
{// 类似GenerateNoiseMap中的循环,但只处理指定范围的行// ...
}

GPU加速

对于更高性能需求,可以使用计算着色器在GPU上生成噪声:

[Header("GPU加速")]
public bool useGPU = true;
public ComputeShader noiseComputeShader;// 使用GPU生成噪声图
float[,] GenerateNoiseMapGPU()
{if (!useGPU || noiseComputeShader == null){return GenerateNoiseMap();}// 创建结果缓冲区float[] noiseData = new float[width * height];ComputeBuffer noiseBuffer = new ComputeBuffer(width * height, sizeof(float));noiseBuffer.SetData(noiseData);// 设置计算着色器参数int kernelHandle = noiseComputeShader.FindKernel("CSMain");noiseComputeShader.SetBuffer(kernelHandle, "NoiseBuffer", noiseBuffer);noiseComputeShader.SetInt("Width", width);noiseComputeShader.SetInt("Height", height);noiseComputeShader.SetFloat("Scale", scale);noiseComputeShader.SetInt("Octaves", octaves);noiseComputeShader.SetFloat("Persistence", persistence);noiseComputeShader.SetFloat("Lacunarity", lacunarity);noiseComputeShader.SetInt("Seed", seed);noiseComputeShader.SetVector("Offset", new Vector4(offset.x, offset.y, 0, 0));// 执行计算着色器int threadGroupsX = Mathf.CeilToInt(width / 8.0f);int threadGroupsY = Mathf.CeilToInt(height / 8.0f);noiseComputeShader.Dispatch(kernelHandle, threadGroupsX, threadGroupsY, 1);// 获取结果noiseBuffer.GetData(noiseData);noiseBuffer.Release();// 转换为二维数组float[,] noiseMap = new float[width, height];for (int y = 0; y < height; y++){for (int x = 0; x < width; x++){noiseMap[x, y] = noiseData[y * width + x];}}return noiseMap;
}

实际应用案例

无限地形生成

通过分块加载和卸载,可以实现"无限"地形:

[Header("无限地形设置")]
public Transform viewer;           // 通常是玩家或相机
public float viewDistance = 300f;  // 可见距离
public int chunkSize = 256;        // 每个地形块的大小
public int chunksVisibleInViewDst = 5;Dictionary<Vector2, TerrainChunk> terrainChunks = new Dictionary<Vector2, TerrainChunk>();
List<TerrainChunk> visibleTerrainChunks = new List<TerrainChunk>();void Update()
{// 获取玩家当前所在的地形块坐标Vector2 viewerPosition = new Vector2(viewer.position.x, viewer.position.z);Vector2 viewerChunkCoord = new Vector2(Mathf.RoundToInt(viewerPosition.x / chunkSize),Mathf.RoundToInt(viewerPosition.y / chunkSize));// 更新可见地形块for (int yOffset = -chunksVisibleInViewDst; yOffset <= chunksVisibleInViewDst; yOffset++){for (int xOffset = -chunksVisibleInViewDst; xOffset <= chunksVisibleInViewDst; xOffset++){Vector2 chunkCoord = new Vector2(viewerChunkCoord.x + xOffset, viewerChunkCoord.y + yOffset);// 检查该块是否已加载if (terrainChunks.ContainsKey(chunkCoord)){terrainChunks[chunkCoord].UpdateChunk();}else{// 创建新的地形块terrainChunks.Add(chunkCoord, new TerrainChunk(chunkCoord, chunkSize, transform, material));}}}
}// 地形块类
public class TerrainChunk
{GameObject meshObject;Vector2 position;Bounds bounds;public TerrainChunk(Vector2 coord, int size, Transform parent, Material material){position = coord * size;bounds = new Bounds(position, Vector2.one * size);// 创建地形块游戏对象meshObject = new GameObject("Terrain Chunk");meshObject.transform.position = new Vector3(position.x, 0, position.y);meshObject.transform.parent = parent;// 添加组件MeshRenderer meshRenderer = meshObject.AddComponent<MeshRenderer>();meshRenderer.material = material;MeshFilter meshFilter = meshObject.AddComponent<MeshFilter>();// 生成地形// ...}public void UpdateChunk(){// 检查是否在视距内float viewerDistanceFromNearestEdge = bounds.SqrDistance(viewerPosition);bool visible = viewerDistanceFromNearestEdge <= viewDistance * viewDistance;meshObject.SetActive(visible);}
}

地形编辑器

创建一个自定义编辑器工具,方便调整地形参数:

#if UNITY_EDITOR
using UnityEditor;[CustomEditor(typeof(TerrainGenerator))]
public class TerrainGeneratorEditor : Editor
{public override void OnInspectorGUI(){TerrainGenerator terrainGen = (TerrainGenerator)target;// 绘制默认检查器DrawDefaultInspector();// 添加生成按钮if (GUILayout.Button("生成地形")){terrainGen.GenerateTerrain();}// 添加随机种子按钮if (GUILayout.Button("随机种子")){terrainGen.seed = Random.Range(0, 100000);terrainGen.GenerateTerrain();}// 添加保存地形按钮if (GUILayout.Button("保存地形")){SaveTerrainMesh(terrainGen);}}void SaveTerrainMesh(TerrainGenerator terrainGen){// 获取当前网格Mesh mesh = terrainGen.GetComponent<MeshFilter>().sharedMesh;// 保存为资源if (mesh != null){string path = EditorUtility.SaveFilePanelInProject("保存地形网格","TerrainMesh","asset","请选择保存位置");if (path.Length > 0){AssetDatabase.CreateAsset(mesh, path);AssetDatabase.SaveAssets();}}}
}
#endif

总结与展望

通过本文的介绍,我们详细探讨了如何在Unity中利用噪声函数生成动态地形。从基本的Perlin噪声应用到高级的多线程和GPU优化,从简单的网格生成到无限地形系统,这些技术为游戏开发者提供了强大的工具,可以创建丰富多样的游戏环境。

随着技术的不断发展,基于噪声的程序化地形生成还将继续演进。未来的发展方向包括:

  1. 机器学习辅助地形生成:利用GAN等技术学习真实地形特征
  2. 混合噪声算法:结合多种噪声函数创造更自然的地形
  3. 实时全球尺度地形:支持行星级别的无缝地形生成和探索
  4. 地形与生态系统集成:基于地形特征自动生成匹配的植被和生态系统

无论是独立游戏开发者还是大型游戏工作室,掌握噪声地形生成技术都能显著提升游戏开发效率和游戏世界的丰富度。希望本文能为您的Unity开发之旅提供有价值的参考。

参考资源

  • Unity官方文档 - 程序化地形生成
  • Sebastian Lague - 程序化地形生成教程
  • The Nature of Code - 噪声算法
  • GPU Gems 3 - 实时程序化地形技术

相关文章:

Unity利用噪声生成动态地形

引言 在游戏开发中&#xff0c;地形是构建游戏世界的基础元素之一。传统的地形创建方法通常依赖于手动建模或预设资源&#xff0c;这种方式虽然精确但缺乏灵活性&#xff0c;且工作量巨大。而使用噪声算法生成地形则提供了一种程序化、动态且高效的解决方案。本文将详细介绍如…...

【Linux】Ext系列文件系统(上)

目录 一、 理解硬件 1-1 磁盘 1-2 磁盘物理结构 1-3 磁盘的存储结构 1-4 如何定位一个扇区 1-4 磁盘的逻辑结构 1-4-1 理解过程 1-4-2 真实过程 1-5 CHS && LBA地址 二、文件系统 2-1 "块"概念 2-2 "分区"概念 2-3 "inode"…...

解决diffusers加载stablediffusion模型,输入prompt总是报错token数超出clip最大长度限制

1. StableDiffusion1.5 在加载huggingface中的扩散模型时&#xff0c;输入prompt总是会被报错超过clip的最大长度限制。 解决方案&#xff1a;使用compel库 from diffusers import AutoPipelineForText2Image import torch import pdb from compel import Compeldevice torc…...

metersphere接口测试(1)使用MeterSphere进行接口测试

文章目录 前言接口文档单接口测试环境配置梳理接口测试场景测试接口 接口自动化怎么写复用性高的自动化测试用例 总结 前言 大汉堡工作第203天&#xff0c;本篇记录我第一次接触接口测试任务&#xff0c;最近有些懈怠啊~ 接口文档 首先就是接口地址&#xff0c;接口测试时用…...

Android第三次面试总结(网络篇)

在计算机网络领域&#xff0c;网络模型是理解通信原理的基础框架。本文将详细解析 OSI 参考模型和 TCP/IP 模型的分层结构、核心功能及实际应用&#xff0c;并通过对比帮助读者建立完整的知识体系。 一、OSI 参考模型&#xff1a;七层架构的理论基石 OSI&#xff08;开放系统…...

AirtestIDE用法

包括airtest和poco 1. airtest 安装python3.7.9 64 python3 -m pip install -U airtest 或者&#xff1a; git clone https://github.com/AirtestProject/Airtest.git pip install -e airtest 无界面的airtest用法&#xff1a; 打开手机中的 开发者选项 , 以及 允许USB调…...

【面试手撕】非常规算法,多线程常见手撕题目

【面试手撕】非常规算法&#xff0c;多线程常见手撕题目 生产者消费者ReentrantLock实现的生产苹果/消费苹果synchronized实现的生产消费LinkedBlockingQueue阻塞队列方法实现多条件资源分配分布式任务调度模拟 交替打印两个线程交替打印1-100之间的数ReentrantLock 实现synchr…...

MySQL复合查询

目录 多表查询 自连接 子查询 单行子查询 多行子查询 in关键字 all关键字 any关键字 多列子查询 from中使用子查询 合并查询 union 操作符 union all 操作符 内外连接 内连接 外连接 左外连接 右外连接 前几期我们已经学习了MySQL的基本查询&…...

登录Xshell主机及Linux基本指令

✅博客主页:爆打维c-CSDN博客​​​​​​ &#x1f43e; &#x1f539;分享c、c知识及代码 &#x1f43e; &#x1f539;Gitee代码仓库 五彩斑斓黑1 (colorful-black-1) - Gitee.com 一、操作系统简介 Linux其实跟我们熟知的Window一样&#xff0c;它们都是操作系统。 &#x…...

[LevelDB]关于LevelDB存储架构到底怎么设计的?

本文内容组织形式 LevelDB 存储架构重要特点总体概括LevelDB中内存模型MemTableMemTable的数据结构背景&#xff1a;SkipListSkiplist的数据结构 Skiplist的数据访问细节 SkipList的核心方法Node细节源代码 MemTable的数据加速方式Iterator 的核心方法 MemTable 的读取&写入…...

深入解析 React Diff 算法:原理、优化与实践

深入解析 React Diff 算法&#xff1a;原理、优化与实践 1. 引言 React 作为前端领域的标杆框架&#xff0c;采用 虚拟 DOM&#xff08;Virtual DOM&#xff09; 来提升 UI 更新性能。React 的 Diff 算法&#xff08;Reconciliation&#xff09; 是虚拟 DOM 运行机制的核心&a…...

【从零开始】Air780EPM的LuatOS二次开发——OneWire协议调试注意事项!

当涉及到与传感器、执行器等外部设备交互时&#xff0c;OneWire协议的高效调试成为决定项目成败的关键环节。OneWire协议&#xff08;单总线协议&#xff09;以其仅需一根数据线即可实现设备通信的极简特性&#xff0c;被广泛应用于温度传感器、身份识别模块等场景。 一、LuatO…...

响应(Response)

在 Flask 中&#xff0c;视图函数可以返回多种类型的响应&#xff0c;例如字符串、HTML、JSON、文件等。Flask 提供了 make_response 函数&#xff0c;用于生成和自定义 HTTP 响应。 2.1 默认响应 默认情况下&#xff0c;视图函数返回的字符串会被 Flask 包装成一个 HTTP 响应…...

C++学习之云盘项目fastDFS

1.资料介绍 1.1 一些概念 1. 什么是服务器 硬件 : 一台配置高的电脑 软件 : 电脑必须有一个能够解析 http 协议的软件 2. 常见的 Web 服务器 tomcat 服务器 apache 组织产品 , 开源的免费服务器 weblogic 服务器 bea 公司 , 收费的服务器 不交费 , 访问量受限…...

使用vue3+el-form实现动态新增名称,值,并对名称进行必填校验

使用vue3el-form实现动态新增名称&#xff0c;值&#xff0c;并对名称进行必填校验 效果图 代码 <template><el-form :model"form" :rules"rules" ref"dynamicForm"><!-- 动态添加的名称和值 --><el-row v-for"(ite…...

Spring Boot 集成高德地图电子围栏

摘要&#xff1a;本文手把手教你通过 Spring Boot 调用高德地图 API 实现电子围栏功能&#xff0c;涵盖云端围栏创建、设备位置监控与本地算法校验&#xff0c;附带完整代码和避坑经验&#xff01; 一、电子围栏核心原理 1.1 什么是电子围栏&#xff1f; 虚拟地理边界&#x…...

3.JVM-内部结构

栈结构 动态链接 栈中的对象指向堆中的实际引用 符号引用: 比如一个类的名称 直接引用: 具体堆中数据信息 方法返回 栈中上一层的结果和下一层的指令 操作数栈 局部变量 该线程中需要的变量 PC计数器 程序计数器:存当前执行到那一步 操作数栈里面将计算完之后的结果推入局…...

Spring 框架中常用注解和使用方法

Spring 框架中常用注解的详细解释与应用场景&#xff0c;结合核心功能和实际开发需求进行分类说明&#xff1a; 1.组件定义注解 1.1 Component 作用&#xff1a;通用注解&#xff0c;将普通 Java 类标记为 Spring 管理的 Bean&#xff0c;由容器实例化和管理&#xff0c;相当…...

神策数据接入 DeepSeek,AI 赋能数据分析与智能运营

在 AI 技术迅猛发展的浪潮下&#xff0c;神策数据正在加速推进人工智能在数据分析和智能运营领域的深度应用。近日&#xff0c;神策数据宣布全面接入 DeepSeek&#xff0c;为企业客户带来更加智能化、高效的数据分析与智能运营服务。这一举措展现了神策数据在人工智能方向的探索…...

微软OneNote无法同步解决方案

目录 前言原因UWP特性 解决方案C***h注册表 参考链接 前言 假设有多台Windows电脑&#xff0c;最方便且免费的多设备笔记同步方案就是微软自家的OneNote&#xff0c;使用OneDrive自带的5G云存储。 但是在国内大陆的OneNote&#xff0c;经常会出现无法同步、同步失败&#xff1…...

一般机器学习有哪些算法?

传统的机器学习算法主要依赖统计学和优化方法&#xff0c;不依赖深层神经网络&#xff0c;通常具有较高的可解释性且适用于中小规模数据集。以下是经典的传统机器学习算法分类及代表性模型&#xff1a; 一、监督学习&#xff08;Supervised Learning&#xff09; 1. 回归&…...

RAGFlow部署与使用(开源本地知识库管理系统,包括kibana配置)

一、RAGFlow 简介 戳我访问RAGFlow RAGFlow 是一款基于深度文档理解构建的开源 RAG&#xff08;Retrieval-Augmented Generation&#xff09;引擎。它可以给我们搭建本地知识库&#xff0c;将用户的知识文档上传到RAGFlow后&#xff0c;通过文档切分、向量入库&#xff0c;在…...

STM32G070CBT6读写FLASH中的数据

向FLASH中写入数据函数 /*函数说明&#xff1a;向FLASH中写数据形参&#xff1a;addr-要写入数据的起始地址 data-准备写入数据 len-数据大小返回值&#xff1a;1-成功&#xff0c;0-失败 */ uint8_t FlashWriteData(uint64_t addr,uint8_t data[],size_t len) {uint32_t Fir…...

如何使用HACS一键集成米家与果家设备到HomeAssistant玩转智能家居

文章目录 前言1. 下载HACS源码2. 添加HACS商店3. 绑定米家设备 前言 各位科技潮人和智能家居发烧友们&#xff0c;是不是也梦想着把家里变成一个高科技的空间&#xff1f;有了群晖NAS这位得力助手&#xff0c;不仅存储空间大得吓人&#xff0c;还能通过Docker轻松安装各种应用…...

Flutter_学习记录_状态管理之GetX

1. 状态管理、Flutter Getx介绍 1.1 状态管理 通俗的讲&#xff1a;当我们想在多个页面&#xff08;组件/Widget&#xff09;之间共享状态&#xff08;数据&#xff09;&#xff0c;或者一个页面&#xff08;组件/Widget&#xff09;中的多个子组件之间共享状态&#xff08;数…...

DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之添加列宽调整功能,示例Table14_09自定义单元格的固定表头表格

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)之添加列宽调整功能,示例Table14_09自定义单元格…...

基于 Prometheus + Grafana 监控微服务和数据库

以下是基于 Prometheus Grafana 监控微服务和数据库的详细指南&#xff0c;包含架构设计、安装配置及验证步骤&#xff1a; 一、整体架构设计 二、监控微服务 1. 微服务指标暴露 Spring Boot 应用&#xff1a; xml <!-- 添加 Micrometer 依赖 --> <dependency>…...

文件解析漏洞

一&#xff0c;IIS解析漏洞 1&#xff0c;IIS6.X 目录解析 在iis的⽹站根⽬录新建⼀个名为q.asp的⽂件&#xff0c;在q.asp中新建⼀个txt⽂件 在外部浏览器中访问windows2003的iis⽹站中的1.txt 发现asp代码被执⾏ 2&#xff0c;IIS6.X 畸形文件解析 在iis的⽹站根⽬录新建⼀…...

C++学习笔记(二十一)——文件读写

一、文件读写 作用&#xff1a; 文件读写指的是将数据从程序存储到文件&#xff0c;或从文件读取数据&#xff0c;以实现数据的持久化存储。 C 提供了 fstream 头文件&#xff0c;用于文件操作&#xff0c;主要包括&#xff1a; ofstream&#xff08;输出文件流&#xff09;—…...

Ubuntu上部署Flask+MySQL项目

一、服务器安装python环境 1、安装gcc&#xff08;Ubuntu默认已安装&#xff09; 2、安装python源码 wget https://www.python.org/ftp/python/3.13.2/Python-3.13.2.tar.xz 3、安装Python依赖库 4、配置python豆瓣源 二、服务器安装虚拟环境 1、安装virtualenv pip3.10 ins…...

Unity WebGL项目访问时自动全屏

Unity WebGL项目访问时自动全屏 打开TemplateData/style.css文件 在文件最下方添加红色框内的两行代码 使用vscode或者其他编辑器打开index.html 将按钮注释掉&#xff0c;并且更改为默认全屏...

C#RTSP代理推流程序

将不支持rtsp的相机通过rtspserver实现推流 主要功能 1. rtsp交互 2. udp推流 3. Bitmap转H264,RTP打包 4. 支持多路播放...

Redis--渐进式遍历

目录 一、引言 二、介绍 三、命令 四、总结 一、引言 本篇文章将介绍Redis中的渐进式遍历 二、介绍 一般使用keys * 来获取所有的key&#xff0c;但这样的操作如果数据量很大的时候&#xff0c;会将服务器给卡死&#xff0c;所以通过渐进式遍历&#xff0c;就会避免这个问题…...

PyTorch深度学习框架60天进阶学习计划 - 第23天:Transformer架构解析

让我继续完成机器翻译示例的代码&#xff1a; PyTorch深度学习框架60天进阶学习计划&#xff1a;第23天 Transformer架构解析 学习目标 推导自注意力机制数学公式详解位置编码的傅里叶基函数设计对比编码器-解码器结构的信息流动差异 1. Transformer架构概述 Transformer架…...

《C#上位机开发从门外到门内》3-4:基于TCP/IP的远程监控系统设计与实现

文章目录 一、项目概述二、系统架构设计三、通信协议设计四、功能模块实现五、系统安全性与稳定性六、性能优化与测试七、实际应用案例八、结论 随着信息技术的飞速发展&#xff0c;远程监控系统在工业自动化、智能家居、环境监测等领域的应用日益广泛。基于TCP/IP协议的远程监…...

【MySQL】MySQL审计工具Audit Plugin安装使用

MySQL审计工具Audit Plugin安装使用 https://www.cnblogs.com/waynechou/p/mysql_audit.html MySQL 5.6 开启审计功能 https://blog.51cto.com/u_15127556/4344503 MySQL之添加日志审计功能 https://blog.csdn.net/weixin_43279032/article/details/105507170 MySQL开启日志记录…...

Flutter 按钮组件 ElevatedButton 详解

目录 1. 引言 2. ElevatedButton 的基本用法 3. 主要属性 4. 自定义按钮样式 4.1 修改背景颜色和文本颜色 4.2 修改按钮形状和边框 4.3 修改按钮大小 4.4 阴影控制 4.5 水波纹效果 5. 结论 相关推荐 1. 引言 在 Flutter 中&#xff0c;ElevatedButton 是一个常用的…...

AndroidStudio+Android8.0下的Launcher3 导入,编译,烧录,调试

文章目录 编译完成搜索输出文件Android.mk配置gradle编译环境报错一报错二报错三输出文件下载INSTALL_FAILED_TEST_ONLY查找系统签名查找签名工具开始签名查看签名签名问题重新生成秘钥解决方案生成成功挽救错误:重新刷机更换testkey秘钥keystore生成keystoreINSTALL_FAILED_S…...

【差分约束】P5590 赛车游戏|省选-

本文涉及知识点 【数学 线性代数】差分约束 P5590 赛车游戏 题目描述 R 君和小伙伴打算一起玩赛车。但他们被老司机 mocania 骗去了秋名山。 秋名山上有 n n n 个点和 m m m 条边&#xff0c;R 君和他的小伙伴要从点 1 1 1 出发开往点 n n n&#xff0c;每条边都有一个…...

咪咕MG101_晨星MSO9380芯片_安卓5.1.1_免拆卡刷固件包

咪咕MG101_晨星MSO9380芯片_安卓5.1.1_免拆卡刷固件包&#xff08;内有教程&#xff09; 刷机教程简单说明&#xff1a; 1、把下载好的刷机包&#xff0c;U盘里建立一个upgrade文件夹&#xff0c;固件放入此文件夹里&#xff0c;放入U盘中&#xff0c;注意升级包为压缩包不要对…...

【软件工程】06_软件设计

6.1 软件设计概述 1. 软件设计的目标 软件设计的最基本目标就是回答 “概括地描述系统如何实现用户所提出来的功能和性能等方面的需求?” 这个问题。 软件设计的目标是根据软件需求分析的结果,设想并设计软件,即根据目标系统的逻辑模型确定目标系统的物理模型。包括软件体系…...

在Flutter中使用Future读取一个大文件会导致线程阻塞吗

目录 一、Future 与文件读取的机制 1. Dart 的异步 I/O 原理 2. 代码示例 二、什么情况下会阻塞主线程? 1. I/O 操作本身不会阻塞 2. 数据处理可能阻塞 3. 示例对比 三、如何避免阻塞主线程? 1. 将耗时操作移到 Isolate 2. 使用 compute 函数(简化 Isolate 操作)…...

2025-03-17 Unity 网络基础1——网络基本概念

文章目录 1 网络1.1 局域网1.2 以太网1.3 城域网1.4 广域网1.5 互联网&#xff08;因特网&#xff09;1.6 万维网1.7 小结 2 IP 地址2.1 IP 地址2.2 端口号2.3 Mac 地址2.4 小结 3 客户端与服务端3.1 客户端3.2 服务端3.3 网络游戏中的客户端与服务端 1 网络 ​ 在没有网络之前…...

2025-03-17 学习记录--C/C++-PTA 习题4-8 高空坠球

合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、题目描述 ⭐️ 习题4-8 高空坠球 皮球从某给定高度自由落下&#xff0c;触地后反弹到原高度的一半&#xff0c;再落下&…...

Java网络编程socket

一、UDP 特点&#xff1a; ① 用户数据报协议&#xff08;User Datagram Protocol&#xff09; ​ ② UDP是面向无连接通信协议 ​③ 速度快&#xff0c;一次只能传输64KB数据&#xff0c;数据不安全&#xff0c;容易丢失 &#xff08;1&#xff09;单播 一对一 客户端&#xf…...

蓝桥杯备赛 Day0_移动零

&#x1f388; 个人主页&#x1f449;&#xff1a;tbRNA-CSDN博客tbRNA-CSDN博客tbRNA-CSDN博客 &#x1f4af; 个人简介&#xff1a;在校大学生一枚&#x1f48b;. &#x1f60d; 希望我的文章对大家有着不一样的帮助&#xff0c;欢迎大家关注我&#xff0c;感谢大家的多多支持…...

Razor C# 变量

Razor C# 变量 引言 在ASP.NET MVC和Razor视图引擎中,变量是构建动态网页的基础。理解Razor C#变量的使用对于开发者来说至关重要。本文将详细介绍Razor C#变量的概念、类型、作用域以及如何在实际项目中有效使用它们。 一、Razor C# 变量的概念 Razor C# 变量是存储在Raz…...

产品更新丨谷云科技ETLCloud 3月更新速递

本月&#xff0c;我们的数据集成产品ETLCloud继续迎来多项更新&#xff0c;进一步提升系统的兼容性和用户体验。以下是本月更新的亮点内容&#xff1a; 新增10项功能组件&#xff0c;持续丰富产品易用性 聚水潭-奇门通用组件 新增聚水潭-奇门通用组件&#xff0c;帮助企业更…...

如何高效定位网络丢包问题?

引言 本期分享一个比较常见的网络问题--丢包。例如我们去ping一个网站&#xff0c;如果能ping通&#xff0c;且网站返回信息全面&#xff0c;则说明与网站服务器的通信是畅通的&#xff0c;如果ping不通&#xff0c;或者网站返回的信息不全等&#xff0c;则很可能是数据被丢包…...

gitlab将本地项目提交到远程dev分支

获取Git路径 首先从远程获取到git路径&#xff0c;将给的git地址进行克隆到本地文件&#xff1b; git clone http:************.git 按照git地址的文件路径将本地项目&#xff0c;拷贝到目标文件中 在该路径中&#xff0c;初始化命令&#xff1b; # 初始化项目 git init #…...