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

基于SpringBoot的河道水情大数据可视化分析平台设计与实现(源码+论文+部署讲解等)

需要资料,请文末联系

在这里插入图片描述
在这里插入图片描述

一、平台介绍

水情监测数据大屏

-在这里插入图片描述

平台首页

在这里插入图片描述

日均水位

  • 在这里插入图片描述

日均水速

二、论文内容

在这里插入图片描述在这里插入图片描述

在这里插入图片描述

摘要(中文)

本文针对河道水情监测领域的数据管理和可视化分析需求,设计并实现了一套河道水情大数据可视化分析平台。该平台基于自研的低代码开发框架,采用前后端分离架构,实现了水情数据的采集、存储、分析和可视化展示功能。平台集成了日均水位、日均水速监测、数据完整性评估、河流管理等核心功能,并提供了数据大屏、实时水情日报等直观的可视化界面,为水务管理部门提供决策支持。本文详细阐述了系统的需求分析、架构设计、数据库设计、功能实现及测试过程,并对系统的应用效果进行了评估。实践表明,该平台能够有效提升水情监测的信息化水平,为防洪减灾和水资源管理提供有力支持。

关键词:水情监测;大数据可视化;低代码开发;前后端分离

摘要(英文)

This thesis designs and implements a river water condition big data visualization and analysis platform to address the data management and visualization analysis needs in river water monitoring. Based on a self-developed low-code development framework, the platform adopts a front-end and back-end separation architecture to realize the collection, storage, analysis, and visualization of water condition data. The platform integrates core functions such as daily average water level monitoring, daily average flow velocity monitoring, data integrity assessment, and river management. It also provides intuitive visualization interfaces such as data dashboards and real-time water condition daily reports to support decision-making for water management departments. This thesis elaborates on the system’s requirement analysis, architecture design, database design, function implementation, and testing process, and evaluates the application effects of the system. Practice shows that the platform can effectively improve the information level of water condition monitoring and provide strong support for flood control, disaster reduction, and water resource management.

Keywords: Water Condition Monitoring; Big Data Visualization; Low-Code Development; Front-end and Back-end Separation

第一章 绪论

1.1 研究背景与意义

随着全球气候变化的加速,水资源管理和防洪减灾工作面临着前所未有的挑战。河道水情监测作为水资源管理的重要环节,对于保障城市安全、防范洪涝灾害、优化水资源调配具有重要意义。传统的水情监测方式主要依靠人工观测和简单的数据记录,存在数据获取不及时、分析手段单一、信息共享困难等问题,难以满足现代水务管理的需求。

随着物联网、大数据、云计算等信息技术的快速发展,河道水情监测正在向数字化、智能化方向转变。通过建立完善的水情监测网络,实时采集水位、流速等关键数据,并结合大数据分析和可视化技术,可以实现水情数据的全面感知、智能分析和直观展示,为水务管理决策提供科学依据。

在深圳市龙岗区等城市化程度高、河网密集的地区,建立高效的河道水情监测平台尤为重要。一方面,该地区降雨集中,易发生暴雨洪涝灾害;另一方面,城市化进程导致河道自然调蓄能力下降,增加了防洪压力。因此,开发一套功能完善、性能稳定的河道水情大数据可视化分析平台,对于提升水情监测能力、增强防灾减灾能力具有重要的现实意义。

1.2 国内外研究现状

1.2.1 国外研究现状

国外发达国家在水情监测领域起步较早,已形成较为完善的技术体系和应用模式:

  1. 美国:美国地质调查局(USGS)建立了全国水情信息系统(NWIS),覆盖全美超过1.5万个监测站点,实现了水文数据的实时采集、传输和共享。该系统采用分布式架构,支持多源数据融合和复杂水文模型计算,为防洪预警和水资源管理提供支持。

  2. 欧盟:欧盟水框架指令(WFD)推动了跨国水情监测网络的建设,如欧洲洪水预警系统(EFAS)整合了多国水文气象数据,提供7-10天的洪水预警。该系统注重数据可视化和决策支持功能,采用WebGIS技术实现空间数据展示。

  3. 日本:日本建立了高密度的水情监测网络,结合雷达降雨监测系统,实现了分钟级的洪水预警。其水情监测系统强调实时性和可靠性,广泛应用物联网技术和边缘计算技术提升数据处理效率。

国外水情监测系统的特点是覆盖范围广、监测精度高、数据处理自动化程度高,并注重数据可视化和决策支持功能。然而,这些系统多为定制开发,系统扩展性和适应性有限,且建设和维护成本较高。

1.2.2 国内研究现状

我国水情监测信息化建设起步相对较晚,但发展迅速:

  1. 国家层面:水利部建立了全国水情信息管理系统,构建了覆盖全国的水情监测网络。"十三五"期间,我国加快了水利信息化建设,初步形成了水情监测、预报、预警的信息化体系。

  2. 地方实践:各省市结合本地特点,开发了多种水情监测系统。如长江水利委员会的长江流域水情监测系统,珠江水利委员会的珠江流域水情信息系统等,这些系统在区域水情监测和防洪减灾中发挥了重要作用。

  3. 技术发展:近年来,我国在水情监测领域积极应用物联网、大数据、人工智能等新技术,如基于北斗卫星的水情监测系统、基于深度学习的水情预测模型等,技术水平不断提升。

国内水情监测系统存在的主要问题包括:系统间数据共享不足、数据分析能力有限、可视化展示不够直观、系统开发效率低等。特别是在低代码开发、大数据分析和可视化方面,与国外先进水平相比仍有差距。

1.3 研究内容与目标

本文旨在设计并实现一套基于自研框架的河道水情大数据可视化分析平台,主要研究内容包括:

  1. 自研低代码开发框架:设计一套适用于水情监测领域的低代码开发框架,提高系统开发效率和可维护性。

  2. 水情数据采集与存储:研究水情数据的采集、传输、存储机制,实现对多源异构数据的统一管理。

  3. 水情数据分析与可视化:研究水情数据的分析方法和可视化技术,实现数据的多维分析和直观展示。

  4. 系统架构与功能设计:研究适合水情监测的系统架构和功能模块,实现系统的高可用性和可扩展性。

研究目标:

  1. 构建一套基于自研低代码框架的河道水情大数据可视化分析平台,实现水情数据的采集、存储、分析和可视化展示。

  2. 提供日均水位、日均水速、数据完整性评估、河流管理等核心功能,满足水情监测的业务需求。

  3. 实现数据大屏、实时水情日报等可视化界面,提升数据展示的直观性和交互性。

  4. 建立完善的系统管理功能,包括用户管理、角色管理、菜单管理、定时任务等,保障系统的安全性和可维护性。

  5. 通过系统应用,提升水情监测的信息化水平,为防洪减灾和水资源管理提供决策支持。

1.4 论文结构安排

本文共分为六章,各章内容安排如下:

第一章 绪论:介绍研究背景与意义、国内外研究现状、研究内容与目标,明确论文的研究范围和方向。

第二章 相关技术介绍:介绍系统开发所涉及的关键技术,包括自研低代码开发框架、前端技术栈、后端技术栈、数据可视化技术等。

第三章 系统需求分析:分析系统的业务需求、功能需求和非功能需求,明确系统开发的目标和范围。

第四章 系统设计:详细阐述系统的架构设计、数据库设计、功能模块设计和接口设计,为系统实现奠定了基础。

第五章 系统实现与测试:介绍系统的开发环境、核心功能实现、数据可视化实现、系统部署过程以及系统测试,展示系统的实现效果并验证系统的功能性和性能。

第六章 总结与展望:总结系统开发的成果和创新点,分析存在的不足,提出未来的改进方向。

第二章 相关技术介绍

2.1 自研低代码开发框架

本系统采用自研的低代码开发框架,该框架是一套面向企业级应用的开发平台,具有以下特点:

  1. 低代码开发:通过可视化设计器和丰富的组件库,减少手工编码量,提高开发效率。

  2. 前后端分离:采用前后端分离架构,前端负责界面展示和用户交互,后端负责业务逻辑和数据处理,实现了前后端的解耦。

  3. 组件化设计:系统功能以组件形式封装,支持组件的复用和扩展,提高了系统的可维护性。

  4. 插件化机制:支持功能插件的动态加载和卸载,便于系统功能的扩展和定制。

  5. 代码生成器:提供强大的代码生成功能,能够根据数据库表结构自动生成前后端代码,大幅提高开发效率。

  6. 权限管理:内置完善的权限管理机制,支持细粒度的权限控制,保障系统安全。

该框架采用现代化的技术栈,前端基于Vue.js和Ant Design Vue,后端基于Spring Boot和MyBatis-Plus,数据库支持MySQL、Oracle等主流数据库,为系统开发提供了坚实的技术基础。

三、主要流程图

日均水位监测

在这里插入图片描述

实时水情日报

在这里插入图片描述

水位-流速年对比

在这里插入图片描述

河流管理

在这里插入图片描述

数据大屏

在这里插入图片描述

四、论文目录

基于开源框架的河道水情大数据可视化分析平台设计与实现 3
封面和声明页 3
摘要(中文) 3
摘要(英文) 4
第一章 绪论 4
1.1 研究背景与意义 4
1.2 国内外研究现状 5
1.3 研究内容与目标 6
1.4 论文结构安排 7
第二章 相关技术介绍 7
2.1 自研低代码开发框架 7
2.2 前端技术栈 8
2.3 后端技术栈 9
2.4 数据可视化技术 10
2.5 本章小结 11
第三章 系统需求分析 11
3.1 业务需求分析 11
3.2 功能需求分析 12
3.3 非功能需求分析 14
3.4 本章小结 15
第四章 系统设计 15
4.1 系统架构设计 15
4.2 数据库设计 17
4.3 功能模块设计 20
4.4 接口设计 33
4.5 本章小结 37
4.2 数据库设计 38
数据库表结构设计 38

  1. 系统管理相关表 38
    1.1 用户表(sys_user) 38
    1.2 角色表(sys_role) 39
    1.3 菜单表(sys_menu) 39
    1.4 用户角色关联表(sys_user_role) 40
    1.5 角色菜单关联表(sys_role_menu) 40
    1.6 数据字典表(sys_dict) 40
    1.7 数据字典项表(sys_dict_item) 40
  2. 业务相关表 41
    2.1 河流表(river_info) 41
    2.2 监测站点表(monitor_station) 41
    2.3 水位数据表(water_level_data) 42
    2.4 流速数据表(water_flow_data) 42
    2.5 数据源表(data_source) 43
    2.6 定时任务表(sys_quartz_job) 43
    4.3 功能模块设计 44
    功能流程图设计 44
  3. 日均水位监测 44
  4. 日均水速监测 47
  5. 实时水情日报 50
  6. 水位-流速年对比 53
    功能流程图设计 56
  7. 河流管理 56
  8. 监测站点管理 58
  9. 数据源管理 60
  10. 数据完整性评估 62
    功能流程图设计 65
  11. 数据大屏 65
  12. 统计图表 68
  13. GIS地图 71
  14. 专题分析 73
    功能流程图设计 76
  15. 用户管理 76
  16. 角色管理 78
  17. 菜单管理 80
  18. 数据字典 82
  19. 定时任务 84
  20. 日志管理 87
  21. 性能监控 89
    功能描述 89
    4.4 接口设计 92
    4.5 本章小结 96
    第五章 系统实现 96
    5.1 开发环境搭建 96
    5.2 核心功能实现 99
    5.3 系统部署 133
    5.4 系统测试 138
    5.5 本章小结 140
    第六章 总结与展望 141
    6.1 研究总结 141
    5.3 系统部署 152
    5.4 系统测试 157
    5.5 本章小结 160
    第六章 总结与展望 160
    6.1 研究总结 160
    6.2 创新点 161
    6.3 未来展望 162
    o 提供开放API接口,支持第三方系统集成 162
    参考文献 162

五、实现代码

<template><div class="water-level-container"><a-form layout="inline" :model="queryParams" @submit="handleQuery"><a-form-item label="河流"><a-select v-model="queryParams.riverId" placeholder="请选择河流" style="width: 200px"><a-select-option v-for="river in riverList" :key="river.riverId" :value="river.riverId">{{ river.riverName }}</a-select-option></a-select></a-form-item><a-form-item label="站点"><a-select v-model="queryParams.stationId" placeholder="请选择站点" style="width: 200px"><a-select-option v-for="station in stationList" :key="station.stationId" :value="station.stationId">{{ station.stationName }}</a-select-option></a-select></a-form-item><a-form-item label="时间范围"><a-range-picker v-model="queryParams.dateRange" style="width: 300px" /></a-form-item><a-form-item><a-button type="primary" html-type="submit">查询</a-button><a-button style="margin-left: 8px" @click="resetQuery">重置</a-button></a-form-item></a-form><div class="chart-container" style="height: 400px" ref="chartContainer"></div><a-table :columns="columns" :dataSource="dataList" :pagination="pagination" @change="handleTableChange"><template slot="operation" slot-scope="text, record"><a @click="viewDetail(record)">查看详情</a></template></a-table></div>
</template><script>
import { getWaterLevelData, getRiverList, getStationList } from '@/api/waterLevel';
import * as echarts from 'echarts';export default {name: 'WaterLevelMonitor',data() {return {queryParams: {riverId: undefined,stationId: undefined,dateRange: [],pageNum: 1,pageSize: 10},riverList: [],stationList: [],dataList: [],pagination: {current: 1,pageSize: 10,total: 0},columns: [{ title: '日期', dataIndex: 'dataTime', key: 'dataTime' },{ title: '河流', dataIndex: 'riverName', key: 'riverName' },{ title: '站点', dataIndex: 'stationName', key: 'stationName' },{ title: '水位(m)', dataIndex: 'waterLevel', key: 'waterLevel' },{ title: '警戒水位(m)', dataIndex: 'warningLevel', key: 'warningLevel' },{ title: '操作', key: 'operation', scopedSlots: { customRender: 'operation' } }],chart: null};},mounted() {this.initData();},methods: {async initData() {// 获取河流列表const riverRes = await getRiverList();this.riverList = riverRes.data;// 获取站点列表const stationRes = await getStationList();this.stationList = stationRes.data;// 初始化查询this.handleQuery();},async handleQuery() {// 处理查询参数const params = {riverId: this.queryParams.riverId,stationId: this.queryParams.stationId,startDate: this.queryParams.dateRange[0] ? this.queryParams.dateRange[0].format('YYYY-MM-DD') : undefined,endDate: this.queryParams.dateRange[1] ? this.queryParams.dateRange[1].format('YYYY-MM-DD') : undefined,pageNum: this.queryParams.pageNum,pageSize: this.queryParams.pageSize};// 调用接口获取数据const res = await getWaterLevelData(params);this.dataList = res.data.records;this.pagination.total = res.data.total;// 更新图表this.updateChart();},resetQuery() {this.queryParams = {riverId: undefined,stationId: undefined,dateRange: [],pageNum: 1,pageSize: 10};this.handleQuery();},handleTableChange(pagination) {我将继续编写论文的第五章系统实现部分,接着前面的内容进行。```markdown:d:\个人资料\论文资料\基于JeecgBoot的河道水情大数据可视化分析平台设计与实现\论文.mdthis.queryParams.pageNum = pagination.current;this.queryParams.pageSize = pagination.pageSize;this.handleQuery();},updateChart() {// 初始化图表if (!this.chart) {this.chart = echarts.init(this.$refs.chartContainer);}// 准备图表数据const dates = this.dataList.map(item => item.dataTime);const waterLevels = this.dataList.map(item => item.waterLevel);const warningLevels = this.dataList.map(item => item.warningLevel);// 设置图表配置const option = {title: {text: '水位监测数据'},tooltip: {trigger: 'axis'},legend: {data: ['水位', '警戒水位']},xAxis: {type: 'category',data: dates},yAxis: {type: 'value',name: '水位(m)'},series: [{name: '水位',type: 'line',data: waterLevels,itemStyle: {color: '#1890ff'}},{name: '警戒水位',type: 'line',data: warningLevels,lineStyle: {type: 'dashed',color: '#ff4d4f'},itemStyle: {color: '#ff4d4f'}}]};// 渲染图表this.chart.setOption(option);},viewDetail(record) {// 查看详情逻辑this.$router.push({path: '/water-level/detail',query: {id: record.id}});}}
};
</script>```

相关文章:

基于SpringBoot的河道水情大数据可视化分析平台设计与实现(源码+论文+部署讲解等)

需要资料&#xff0c;请文末联系 一、平台介绍 水情监测数据大屏 - 平台首页 日均水位 日均水速 二、论文内容 摘要&#xff08;中文&#xff09; 本文针对河道水情监测领域的数据管理和可视化分析需求&#xff0c;设计并实现了一套河道水情大数据可视化分析平台。该平台基…...

日志统计(双指针)

题目描述 小明维护着一个程序员论坛。现在他收集了一份"点赞"日志&#xff0c;日志共有 NN 行。其中每一行的格式是&#xff1a; ts idts id 表示在 tsts 时刻编号 idid 的帖子收到一个"赞"。 现在小明想统计有哪些帖子曾经是"热帖"。如果一个帖…...

广告推荐算法:COSMO算法与A9算法的对比

COSMO算法与A9算法的概念解析 1. A9算法 定义与背景&#xff1a; A9算法是亚马逊早期为电商平台研发的核心搜索算法&#xff0c;主要用于优化商品搜索结果的排序和推荐&#xff0c;其核心逻辑围绕产品属性与关键词匹配展开。自2003年推出以来&#xff0c;A9通过分析商品标题…...

Java进阶之旅-day05:网络编程

引言 在当今数字化的时代&#xff0c;网络编程在软件开发中扮演着至关重要的角色。Java 作为一门广泛应用的编程语言&#xff0c;提供了强大的网络编程能力。今天&#xff0c;我们深入学习了 Java 网络编程的基础知识&#xff0c;包括基本的通信架构、网络编程三要素、IP 地址、…...

Vue 3 的响应式原理

Vue 3 的响应式原理可以比喻为“智能监控系统”&#xff1a;当数据变化时&#xff0c;它能自动追踪依赖关系并触发更新。以下是通俗解释和核心机制&#xff1a; 一、核心原理&#xff1a;Proxy 代理 Vue 3 的响应式系统基于 JavaScript 的 Proxy 对象实现&#xff08;Vue 2 使…...

Python解决“组成字符串ku的最大次数”问题

Python解决“组成字符串ku的最大次数”问题 问题描述测试样例解题思路代码 问题描述 给定一个字符串 s&#xff0c;该字符串中只包含英文大小写字母。你需要计算从字符串中最多能组成多少个字符串 “ku”。每次可以随机从字符串中选一个字符&#xff0c;并且选中的字符不能再使…...

【JS】使用滑动窗口得到无重复字符的最长子串

题目 思路 本题采用滑动窗口思想&#xff0c;定义左右指针作为滑动窗口的边界&#xff0c;使用Set数据结构处理重复字符&#xff0c;需要注意的是&#xff1a;每次遍历时采用Math.max方法实时更新最长子串的长度&#xff1b;当左指针移动时&#xff0c;set要删除对应字符。 步…...

libreoffice-help-common` 的版本(`24.8.5`)与官方源要求的版本(`24.2.7`)不一致

出现此错误的原因主要是软件包依赖冲突&#xff0c;具体分析如下&#xff1a; ### 主要原因 1. **软件源版本不匹配&#xff08;国内和官方服务器版本有差距&#xff09; 系统中可能启用了第三方软件源&#xff08;如 PPA 或 backports 源&#xff09;&#xff0c;导致 lib…...

2025-04-05 吴恩达机器学习4——逻辑回归(1):基础入门

文章目录 1 分类问题1.1 介绍1.2 线性回归与分类1.2 逻辑回归 2 逻辑回归2.1 介绍2.2 Sigmoid 函数2.3 逻辑回归模型 3 决策边界3.1 概念3.2 线性决策边界3.3 非线性决策边界 4 代价函数4.1 不使用平方误差4.2 损失函数4.3 整体代价函数 5 梯度下降5.1 参数更新5.2 逻辑回归 vs…...

P1125 [NOIP 2008 提高组] 笨小猴

#include<bits/stdc.h> using namespace std; int a[300],ma,mi105;//数组用来记录每个字符出现的次数&#xff0c;将mi初始为一个比较大的值 bool is_prime(int x){if(x0||x1)return false;for(int i2;i*i<x;i){if(x%i0)return false;}return true; }//判断是否为质…...

Linux systemd 服务全面详解

一、systemd 是什么&#xff1f; systemd 是 Linux 系统的现代初始化系统&#xff08;init&#xff09;和服务管理器&#xff0c;替代传统的 SysVinit 和 Upstart。它不仅是系统启动的“总指挥”&#xff0c;还统一管理服务、日志、设备挂载、定时任务等。 核心作用 服务管理…...

SortedSet结构之用户积分实时榜单实战

Redis 中的SortedSet结构非常适合用于实现实时榜单的场景&#xff0c;它根据成员的分数自动进行排序&#xff0c;支持高效的添加、更新和查询操作。 SortedSet实时榜单的一些典型应用场景&#xff1a; 游戏中的玩家排行榜&#xff1a;在多人在线游戏中&#xff0c;使用 Sorte…...

C++_类和对象(中)

【本节目标】 类的6个默认成员函数构造函数析构函数拷贝构造函数赋值运算符重载const成员函数取地址及const取地址操作符重载 1. 类的6个默认成员函数 如果一个类中什么成员都没有&#xff0c;简称为空类。 空类中真的什么都没有吗&#xff1f;并不是&#xff0c;任何类在什…...

#SVA语法滴水穿石# (007)关于 $past 的用法

今天,我们要学习比较重要的一个关键字。$past 的用法,今天系统学习。 1. $past 函数的核心作用 $past 用于 获取某个信号在过去指定时钟周期前的值,通常用于检查历史状态是否符合预期。 其语法如下: $past(signal, [num_cycles], [gating_condition], [clock], [reset])…...

学习笔记—C++—入门基础()

目录 C介绍 参考文档 C第一个程序 命名空间namespace namespace的价值 namespace的定义 namespace使用 指定命名空间访问 using将命名空间中某个成员展开 展开命名空间中全部成员 输入和输出 缺省参数 函数重载 引用 引用的概念 应用 const引用 指针和引用的关…...

kotlin函数类型

一 函数类型定义 1 定义 函数类型就是 (Int, Int) -> Int 函数类型其实就是将函数的 “参数类型” 和 “返回值类型” 抽象出来 2 示例 &#xff1a; (Int, Int) -> Int 表示接收两个 Int 参数并返回 Int 的函数类型&#xff1b; (String) -> Unit 表示接收 Strin…...

大数据Spark(五十七):Spark运行架构与MapReduce区别

文章目录 Spark运行架构与MapReduce区别 一、Spark运行架构 二、Spark与MapReduce区别 Spark运行架构与MapReduce区别 一、Spark运行架构 Master:Spark集群中资源管理主节点&#xff0c;负责管理Worker节点。Worker:Spark集群中资源管理的从节点&#xff0c;负责任务的运行…...

虚拟Ashx页面,在WEB.CONFIG中不添加handlers如何运行

https://localhost:44311/webapi.ashx 虚拟ASHX页面,在WEB.CONFIG中添加handlers&#xff0c;如何不添加节点&#xff0c;直接运行?把页面直接保存ASHX名称&#xff1f;现在是.VB 如果你不想通过在 web.config 里添加 handlers 节点来配置处理程序&#xff0c;而是直接让 .as…...

道路裂缝数据集CrackForest-156-labelme

来源于开源的数据集 https://github.com/cuilimeng/CrackForest-dataset 进行整理修改而成。 文章目录 1. 介绍2. 应用场景3. 相关工具4. 下载地址 1. 介绍 在现代城市管理中&#xff0c;道路状况的监测与维护是确保交通安全和城市基础设施健康的重要环节。 CrackForest是一个…...

HTML 表单:构建交互式网页的关键元素

HTML 表单:构建交互式网页的关键元素 引言 HTML表单是构建交互式网页的核心组件之一,它允许用户与网站进行交互,提交信息、填写问卷或进行其他操作。本文将深入探讨HTML表单的基础知识、常用元素、表单验证以及如何优化表单设计,以提高用户体验和网站的可访问性。 HTML表…...

Java进阶-day06:反射、注解与动态代理深度解析

目录 一、反射机制&#xff1a;Java的自我认知能力 1.1 认识反射 1.2 获取Class对象 1.3 获取类的成分 二、注解&#xff1a;Java的元数据机制 2.1 注解概述 2.2 元注解 2.3 注解解析 2.4 注解的实际应用 三、动态代理&#xff1a;灵活的间接访问机制 3.1 为什么需要…...

Redis数据结构之Hash

目录 1.概述2.常见操作2.1 H(M)SET/H(M)GET2.2 HGETALL2.3 HDEL2.4 HLEN2.5 HEXISTS2.6 HKEYS/HVALS2.7 HINCRBY2.8 HSETNX 3.总结 1.概述 Hash是一个String类型的field(字段)和value(值)的映射表&#xff0c;而且value是一个键值对集合&#xff0c;类似Map<String, Map<…...

故障矩阵像素照片效果ps标题文本特效滤镜样机 Glitched Arcade Text Logo Effect

有时&#xff0c;视觉效果比文字本身更能讲述故事&#xff0c;因此请确保您已竭尽全力提供令人敬畏的展示。品牌标识或演示元素&#xff0c;该资产可以处理您的项目所涉及的任何内容。由于智能对象图层&#xff0c;此文本效果将为获得理想的结果铺平道路。这些允许您在指定的图…...

[创业之路-352]:从创业和公司经营的角度看:分析美国的三大财务报表

一、美国政府的财务报表 如果把美国政府看成一个公司&#xff0c;从三大财务报表上看&#xff0c;美国政府资产雄厚&#xff0c;但利润表年年亏损&#xff0c;现金流量表年年为负&#xff0c;现金流持续吃紧&#xff0c;面临现金流断裂导致公司倒闭的风险。 马斯克在降低公司各…...

【学Rust写CAD】27 双线性插值函数(bilinear_interpolation.rs)

源码 use super::constant::BILINEAR_INTERPOLATION_BITS; // Inspired by Filter_32_opaque from Skia. fn bilinear_interpolation(tl: u32,tr: u32,bl: u32,br: u32,mut distx: u32,mut disty: u32, ) -> u32 {let distxy;let distxiy;let distixy;let distixiy;let mut…...

vs环境中编译osg以及osgQt

1、下载 OpenSceneGraph 获取源代码 您可以通过以下方式获取 OSG 源代码: 官网下载:https://github.com/openscenegraph/OpenSceneGraph/releases 使用 git 克隆: git clone https://github.com/openscenegraph/OpenSceneGraph.git 2、下载必要的第三方依赖库 依赖库 ht…...

【教学类-102-02】自制剪纸图案(留白边、沿线剪)02——Python+PS自动化添加虚线边框

背景需求: 01版本实现了对透明背景png图案边界线的扩展,黑线实线描边 【教学类-102-01】自制剪纸图案(留白边、沿线剪)01-CSDN博客文章浏览阅读974次,点赞15次,收藏7次。【教学类-102-01】自制剪纸图案(留白边、沿线剪)01https://blog.csdn.net/reasonsummer/article…...

基于 Netty 框架的 Java TCP 服务器端实现,用于启动一个 TCP 服务器来处理客户端的连接和数据传输

代码&#xff1a; package com.example.tpson_tcp;import io.netty.bootstrap.ServerBootstrap; import io.netty.channel.ChannelFuture; import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelOption; import io.netty.channel.EventLoopGroup; imp…...

fbx bip互转 测试OK

目录 fbx bip互转 3dmax插件fbx转bip: 测试可以转: MotionBuilder fbx转bip fbx bip互转 3dmax插件fbx转bip: 测试可以转: 不用插件!!无脑把Mxiamo转bip骨骼动画 - CG软件插件脚本交流 - Powered by Discuz!...

iptables只允许指定网段的ip访问某端口配置

yum install -y iptables-services #安装 systemctl restart iptables.service #重启防火墙使配置生效 systemctl enable iptables.service #设置防火墙开机启动 systemctl disable iptables.service #禁止防火墙开机启动 iptables -F 清除所有链的规则。 关闭所有访问端口 …...