ECharts中Map(地图)样式配置、渐变色生成
前言
ECharts是我们常用的图表控件,功能特别强大,每次使用都要查API比较繁琐,这里就记录开发中常用的配置。
官网:https://echarts.apache.org/handbook/zh/get-started
配置项:https://echarts.apache.org/zh/option.html#title
第三方示例平台:https://www.makeapie.cn/echarts
主题:https://echarts.apache.org/zh/theme-builder.html
样式
示例
let option = {tooltip: {show: true,formatter: function (params) {if (params.value.length > 1) {return " " + params.name + ":" + params.value[2];} else {return " " + params.name + ":" + (params.value || 0);}},},geo: {map: "china",zoom: 1.2,show: true,roam: false,emphasis: {label: {show: false,},},layoutSize: "100%",itemStyle: {borderColor: "rgba(147, 235, 248, 1)",borderWidth: 2,shadowColor: "rgb(90,160,234)",shadowOffsetX: 0,shadowOffsetY: 10,shadowBlur: 10,},},visualMap: {show: false,seriesIndex: [0],inRange: {color: ["#8db1f1", "#026aa9"],},},series: [{type: "map",map: "china",aspectScale: 0.75,zoom: 1.2,label: {show: true,color: "#ffffff",},itemStyle: {borderColor: "rgba(147, 235, 248, 1)",areaColor: {type: "radial",x: 0.5,y: 0.5,r: 0.9,colorStops: [{offset: 0,color: "rgba(17,217,245,0.5)", // 0% 处的颜色},{offset: 1,color: "rgba(10,209,231,0.2)", // 100% 处的颜色},],globalCoord: false, // 缺省为 false},borderWidth: 1,},emphasis: {label: {show: false,color: "#ffffff",},itemStyle: {areaColor: "#026aa9",borderColor: "#fff",borderWidth: 2,},},data: allData,},],
};
层级
地图的配置是一层盖一层,从底层
到顶层
的配置依次为:
geo
=> series
=> visualMap
geo
和 series
中都有两个配置项
itemStyle
未选中的样式emphasis
选中的样式
geo
隐藏掉只有series
也是能正常显示整个地图的。
geo
和 series
的搭配可以实现一些阴影,偏移从而实现类似立体的效果。
visualMap
其中visualMap
设置的背景颜色是动态的,会根据数值的大小在两个颜色之间变化。
visualMap: {show: false,seriesIndex: [0],inRange: {color: ["#cdcaf8", "#026aa9"],},
},
需要注意的是:
当区域有数据的时候会使用visualMap的颜色覆盖,如果没有数据则会使用
series
的itemStyle
的样式。
默认最小值和最大值会根据数据自动计算,当然我们也可以指定具体的值。
visualMap: {min: 0,max: 100,inRange: {color: ['#e0ffff', '#0066ff'] // 设置颜色范围,浅色到深色},calculable: true,show: true
},
渐变色
线性渐变
沿着一条直线从一种颜色过渡到另一种颜色。
{type: "linear",x: 0,y: 0,x2: 1,y2: 0,colorStops: [{offset: 0,color: "#8db1f1", // 起始颜色},{offset: 1,color: "#026aa9", // 终止颜色},],
}
径向渐变
从一个中心点向四周辐射的渐变色。
{type: 'radial',x: 0.5, y: 0.5,r: 0.5,colorStops: [{offset: 0, color: 'rgba(255, 0, 0, 1)' // 起始颜色}, {offset: 1, color: 'rgba(0, 0, 255, 1)' // 终止颜色}]
}
你可以设置以下属性:
- type:设置渐变的类型,固定值为 ‘radial’。
- x、y:设置渐变的中心点坐标,取值范围为 0~1,其中 (0, 0) 表示左上角,(1, 1) 表示右下角。
- r:设置渐变的半径,也是相对于整个绘图区域的半径,取值范围为 0~1,1 表示半径等于绘图区域的最短边的一半。
- colorStops:设置渐变的起始颜色、终止颜色以及它们的位置。 它是一个数组,每个元素包含两个属性,分别是 offset 和 color。 其中 offset 表示该位置距离渐变位置的百分比,取值范围为 0~1,color 则是该位置所对应的颜色值。
覆盖散点
涟漪散点
series: [{type: "map",map: "china",aspectScale: 0.75,zoom: 1.2,label: {show: true,color: "#11688a",},itemStyle: {areaColor: "rgba(10,76,139,1)",borderColor: "#215495",borderWidth: 1,},emphasis: {label: {show: false,},itemStyle: { areaColor: "#061E3D" },},data: allData,},{type: "effectScatter",coordinateSystem: "geo",rippleEffect: {brushType: "stroke",},showEffectOn: "render",itemStyle: {color: {type: "radial",x: 0.5,y: 0.5,r: 0.5,colorStops: [{offset: 0,color: "rgba(5,80,151,0.2)",},{offset: 0.8,color: "rgba(5,80,151,0.8)",},{offset: 1,color: "rgba(0,108,255,0.7)",},],global: false, // 缺省为 false},},label: {show: true,color: "#fff",fontWeight: "bold",position: "inside",formatter: function (para) {return "{cnNum|" + para.data.value[2] + "}";},rich: {cnNum: {fontSize: 13,color: "#D4EEFF",},},},symbol: "circle",symbolSize: function (val) {if (val[2] === 0) {return 0;}let a = (maxSize4Pin - minSize4Pin) / (max - min);let b = maxSize4Pin - a * max;return a * val[2] + b * 1.2;},data: convertData(allData),zlevel: 1,},
],
let convertData = function (outdata) {let res = [];for (let i = 0; i < outdata.length; i++) {let geoCoord = geoCoordMap[outdata[i].name];if (geoCoord) {res.push({name: outdata[i].name,value: geoCoord.concat(outdata[i].value),});}}return res;
};
值类似于
{name : "陕西",value: [113.0668, 33.8818, 140]
}
普通散点
{type: "scatter",coordinateSystem: "geo",rippleEffect: {brushType: "stroke",},showEffectOn: "render",itemStyle: {color: {type: "radial",x: 0.5,y: 0.5,r: 0.5,colorStops: [{offset: 0,color: "rgba(5,80,151,0.8)",},{offset: 0.5,color: "rgba(0,108,255,0.7)",},{offset: 1,color: "rgba(5,80,151,0.2)",},],global: false, // 缺省为 false},},label: {show: true,color: "#fff",fontWeight: "bold",position: "inside",formatter: function (para) {return "{cnNum|" + para.data.value[2] + "}";},rich: {cnNum: {fontSize: 13,color: "#D4EEFF",},},},symbol: "circle",symbolSize: function (val) {if (val[2] === 0) {return 0;}let a = (maxSize4Pin - minSize4Pin) / (max - min);let b = maxSize4Pin - a * max;return a * val[2] + b * 1.2;},data: convertData(allData),zlevel: 1,
},
放射线
<template><div :class="className" :style="{ height: height, width: width }" />
</template><script>
import * as echarts from "echarts";
import resize from "@/assets/utils/resize.js";
import "@/assets/utils/china.js";export default {name: "BarChart",mixins: [resize],props: {className: {type: String,default: "chart",},width: {type: String,default: "100%",},height: {type: String,default: "100%",},title: {type: String,default: "",},chartData: {type: Object,default: () => {return {};},},},data() {return {chart: null,};},watch: {chartData: function () {this.initChart();},},async mounted() {await this.$nextTick();this.initChart();},beforeDestroy() {if (!this.chart) {return;}this.chart.dispose();this.chart = null;},methods: {initChart() {if (!this.chart) {this.chart = echarts.init(this.$el);}var chinaGeoCoordMap = {黑龙江: [127.9688, 45.368],内蒙古: [110.3467, 41.4899],吉林: [125.8154, 44.2584],北京市: [116.4551, 40.2539],辽宁: [123.1238, 42.1216],河北: [114.4995, 38.1006],天津: [117.4219, 39.4189],山西: [112.3352, 37.9413],陕西: [109.1162, 34.2004],甘肃: [103.5901, 36.3043],宁夏: [106.3586, 38.1775],青海: [101.4038, 36.8207],新疆: [87.9236, 43.5883],西藏: [91.11, 29.97],四川: [103.9526, 30.7617],重庆: [108.384366, 30.439702],山东: [117.1582, 36.8701],河南: [113.4668, 34.6234],江苏: [118.8062, 31.9208],安徽: [117.29, 32.0581],湖北: [114.3896, 30.6628],浙江: [119.5313, 29.8773],福建: [119.4543, 25.9222],江西: [116.0046, 28.6633],湖南: [113.0823, 28.2568],贵州: [106.6992, 26.7682],云南: [102.9199, 25.4663],广东: [113.12244, 23.009505],广西: [108.479, 23.1152],海南: [110.3893, 19.8516],上海: [121.4648, 31.2891],};let chinaDatas = [[{name: "黑龙江",value: 0,},],[{name: "内蒙古",value: 0,},],[{name: "吉林",value: 0,},],[{name: "辽宁",value: 0,},],[{name: "河北",value: 0,},],[{name: "天津",value: 0,},],[{name: "山西",value: 0,},],[{name: "陕西",value: 0,},],[{name: "甘肃",value: 0,},],[{name: "宁夏",value: 0,},],[{name: "青海",value: 0,},],[{name: "新疆",value: 0,},],[{name: "西藏",value: 0,},],[{name: "四川",value: 0,},],[{name: "重庆",value: 0,},],[{name: "山东",value: 0,},],[{name: "河南",value: 0,},],[{name: "江苏",value: 0,},],[{name: "安徽",value: 0,},],[{name: "湖北",value: 0,},],[{name: "浙江",value: 0,},],[{name: "福建",value: 0,},],[{name: "江西",value: 0,},],[{name: "湖南",value: 0,},],[{name: "贵州",value: 0,},],[{name: "广西",value: 0,},],[{name: "海南",value: 0,},],[{name: "上海",value: 1,},],];let allpoints = Object.values(chinaGeoCoordMap);let convertData = function (data) {let res = [];for (let i = 0; i < data.length; i++) {let dataItem = data[i];let fromCoord = chinaGeoCoordMap[dataItem[0].name];let toCoord = allpoints[Math.floor(Math.random() * allpoints.length)];if (fromCoord && toCoord) {res.push([{coord: fromCoord,value: dataItem[0].value,},{coord: toCoord,},]);}}return res;};var series = [];series.push({type: "lines",zlevel: 2,effect: {show: true,period: 4, //箭头指向速度,值越小速度越快trailLength: 0.02, //特效尾迹长度[0,1]值越大,尾迹越长重symbol: "arrow", //箭头图标symbolSize: 5, //图标大小},lineStyle: {normal: {width: 1, //尾迹线条宽度opacity: 1, //尾迹线条透明度curveness: 0.3, //尾迹线条曲直度color: "#17F5FF",},},data: convertData(chinaDatas),},{type: "effectScatter",coordinateSystem: "geo",zlevel: 2,rippleEffect: {//涟漪特效period: 4, //动画时间,值越小速度越快brushType: "stroke", //波纹绘制方式 stroke, fillscale: 4, //波纹圆环最大限制,值越大波纹越大},label: {normal: {show: true,position: "right", //显示位置offset: [5, 0], //偏移设置formatter: function (params) {//圆环显示文字return params.data.name;},fontSize: 10,color: "#FFFFFF",},emphasis: {show: true,},},symbol: "circle",symbolSize: function (val) {return 5 + val[2] * 5; //圆环大小},itemStyle: {normal: {show: false,color: "#17F5FF",},},data: chinaDatas.map(function (dataItem) {return {name: dataItem[0].name,value: chinaGeoCoordMap[dataItem[0].name].concat([dataItem[0].value,]),};}),});let option = {tooltip: {show: false,trigger: "item",backgroundColor: "rgba(166, 200, 76, 0.82)",borderColor: "#FFFFCC",showDelay: 0,hideDelay: 0,enterable: true,transitionDuration: 0,extraCssText: "z-index:100",formatter: function (params) {//根据业务自己拓展要显示的内容var res = "";var name = params.name;var value = params.value[params.seriesIndex + 1];res ="<span style='color:#fff;'>" +name +"</span><br/>数据:" +value || 0;return res;},},geo: {map: "china",zoom: 1.2,label: {emphasis: {show: false,},},roam: false, //是否允许缩放itemStyle: {normal: {color: "rgba(51, 69, 89, .5)", //地图背景色borderColor: "#516a89", //省市边界线00fcff 516a89borderWidth: 1,},emphasis: {color: "rgba(37, 43, 61, .5)", //悬浮背景},},},series: series,};this.chart.setOption(option);},},
};
</script>
背景变色
<template><div :class="className" :style="{ height: height, width: width }" />
</template><script>
import * as echarts from "echarts";
import resize from "@/assets/utils/resize.js";
import "@/assets/utils/china.js";export default {name: "BarChart",mixins: [resize],props: {className: {type: String,default: "chart",},width: {type: String,default: "100%",},height: {type: String,default: "100%",},title: {type: String,default: "",},chartData: {type: Object,default: () => {return {};},},},data() {return {chart: null,};},watch: {chartData: function () {this.initChart();},},async mounted() {await this.$nextTick();this.initChart();},beforeDestroy() {if (!this.chart) {return;}this.chart.dispose();this.chart = null;},methods: {initChart() {if (!this.chart) {this.chart = echarts.init(this.$el);}let dataList = [{name: "重庆",value: 347,},{name: "浙江",value: 59,},{name: "云南",value: 115,},{name: "新疆维吾尔自治区",value: 45,},{name: "香港",value: 81,},{name: "西藏自治区",value: 5,},{name: "天津",value: 121,},{name: "四川",value: 23,},{name: "上海",value: 1140,},{name: "陕西",value: 143,},{name: "山西",value: 77,},{name: "山东",value: 209,},{name: "青海",value: 3,},{name: "宁夏回族自治区",value: 1,},{name: "内蒙古自治区",value: 7,},{name: "辽宁",value: 386,},{name: "江西",value: 67,},{name: "江苏",value: 464,},{name: "湖南",value: 6,},{name: "湖北",value: 614,},{name: "黑龙江",value: 53,},{name: "河南",value: 140,},{name: "河北",value: 190,},{name: "海南",value: 24,},{name: "贵州",value: 2,},{name: "广西壮族自治区",value: 77,},{name: "广东",value: 449,},{name: "甘肃",value: 7,},{name: "福建",value: 23,},{name: "北京",value: 603,},{name: "安徽",value: 29,},];let option = {tooltip: {show: true,formatter: function (params) {if (params.value.length > 1) {return " " + params.name + ":" + params.value[2];} else {return " " + params.name + ":" + (params.value || 0);}},},visualMap: {show: false,seriesIndex: [0],inRange: {color: ["#A5DCF4", "#006edd"],},},geo: {map: "china",zoom: 1.2,show: true,roam: false,label: {emphasis: {show: false,},},layoutSize: "100%",itemStyle: {borderColor: "rgba(147, 235, 248, 1)",borderWidth: 2,shadowColor: "rgba(10,76,139,1)",shadowOffsetY: 0,shadowBlur: 60,},},series: [{type: "map",map: "china",aspectScale: 0.75,zoom: 1.2,label: {normal: {show: true,color: "#4dccff",},emphasis: {show: false,},},itemStyle: {normal: {areaColor: {x: 0,y: 0,x2: 1,y2: 1,colorStops: [{offset: 0,color: "#073684", // 0% 处的颜色},{offset: 1,color: "#061E3D", // 100% 处的颜色},],},borderColor: "#215495",borderWidth: 1,},emphasis: {areaColor: "#061E3D",},},data: dataList,},],};this.chart.setOption(option);},},
};
</script>
相关文章:
ECharts中Map(地图)样式配置、渐变色生成
前言 ECharts是我们常用的图表控件,功能特别强大,每次使用都要查API比较繁琐,这里就记录开发中常用的配置。 官网:https://echarts.apache.org/handbook/zh/get-started 配置项:https://echarts.apache.org/zh/opti…...
PostgreSQL存储管理体系结构学习笔记2
1.表和元组的组织方式 在PostgreSQL中,同一个表中的元组按照创建顺序依次插入到表文件中。元组之间不进行关联,这样的表文件称之为堆文件。PostgreSQL系统中包含了四种堆文件:普通堆,临时堆,序列,TOAST表。…...
【PTA题目解答】7-3 字符串的全排列(20分)next_permutation
1.题目 给定一个全由小写字母构成的字符串,求它的全排列,按照字典序从小到大输出。 输入格式: 一行,一个字符串,长度不大于8。 输出格式: 输出所有全排列,每行一种排列形式,字典序从小到大。 输入样例…...
SOME/IP:用Python实现协议订阅、Offer、订阅ACK与报文接收
文章目录 前言一、代码层次二、详细代码1. eth_scapy_sd.py2、eth_scapy_someip.py3、network_define.py4、packet_define.py5、unpack_define.py6、someip_controller.py 前言 1、需要pip安装scapy库 2、需要修改根据实际情况配置network_define.py 3、执行someip_controller…...
嵌入式八股ARM篇
前言 ARM篇主要介绍一下寄存器和中断机制,至于汇编这一块…还请大家感兴趣自行学习 1.寄存器 R0 - R3 R4 - R11 寄存器 R0 - R3一般用作函数传参 R4 - R11用来保存程序运算的中间结果或函数的局部变量 在函数调用过程中 注意在发生异常的时候 cortex-M0架构会自动将R0-R3压入…...
剑指 Offer II 087. 复原 IP
comments: true edit_url: https://github.com/doocs/leetcode/edit/main/lcof2/%E5%89%91%E6%8C%87%20Offer%20II%20087.%20%E5%A4%8D%E5%8E%9F%20IP/README.md 剑指 Offer II 087. 复原 IP 题目描述 给定一个只包含数字的字符串 s ,用以表示一个 IP 地址…...
RCE-Labs超详细WP-Level10(无字母命令执行_二进制整数替换)
温馨提示 这关涉及的知识点较多, 写的很长, 中间留了很多错误引导(本人在实验时遇到的问题, 或许你们也会遇到), 在后文才逐步解释源码分析 跟前几关一样, 更改了 WAF 的过滤字段这个关卡, 只有0, 1, (单引号), $, <, \ , ( , )可以用解题分析(实验这些命令, 可以先在自己本…...
数据结构(泛型)
1,装箱 int i 10;Integer j Integer.valueOf(i);2.拆箱 Integer i 10;int j i.intValue(); 3.自动装箱 int i 10;Integer j i;int i 10;Integer j (Integer) i; 4,自动拆箱 Integer i 10;int j i;Integer i 10;int j (int) i; 有一段代码需要解析一下: …...
Android Dagger2 框架辅助工具模块深度剖析(六)
一、引言 在 Android 开发领域,依赖注入(Dependency Injection,简称 DI)作为一种至关重要的设计模式,能显著降低代码间的耦合度,提升代码的可测试性与可维护性。Dagger2 作为一款强大的依赖注入框架&#…...
LVGL第三方库的使用(中文库)
一、第三方库文档 3rd party libraries(第三方库) — LVGL 文档 FreeType 中文字库 SDL 模拟器使用freetype中文字库 1.开启字库 2.安装freetype 字库 sudo apt-get update sudo apt-get install libfreetype6-dev 3.修改makefile 添加字库 4.显示中…...
【愚公系列】《高效使用DeepSeek》009-PPT大纲自动生成
标题详情作者简介愚公搬代码头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主,腾讯云内容共创官,掘金优秀博主,亚马逊技领云博主,51CTO博客专家等。近期荣誉2022年度…...
使用easyexcel实现单元格样式设置和下拉框设置
1.单元格样式设置 1.1实体类 public class DemoData {ExcelProperty("PK")private String name;ExcelProperty("年龄")private int age;// 必须提供无参构造方法public DemoData() {}public DemoData(String name, int age) {this.name name;this.age …...
ngx_conf_read_token
file_size ngx_file_size(&cf->conf_file->file.info); 此时 file_size2656 当然还是和上次一样 for ( ;; ) {if (b->pos > b->last) { 此时 b->pos 0x57759a8b77f4 b->last 0x57759a8b8230 b->start0x57759a8b77d0 条件不成立 ch *b->po…...
Certbot实现SSL免费证书自动续签(CentOS 7 + nginx/apache)
在 CentOS 上,你可以使用 Let’s Encrypt 提供的 Certbot 工具来申请和自动续约免费的 SSL 证书。 1. 安装 Certbot CentOS 7 安装 EPEL 和 Certbot yum install -y epel-release yum install -y certbot python3-certbot-nginx如果使用的是 Apache: …...
【使用 Java 调用命令行工具:完整指南】
在 Java 中调用命令行工具是一个常见的需求,尤其是在需要与外部程序交互或执行系统命令时。本文将详细介绍如何使用 Java 调用命令行工具,并提供一个完整的示例来演示如何下载视频。 1. 为什么需要调用命令行工具? 命令行工具通常提供了强大…...
pythonSTL---sys
sys 是 Python 标准库中的一个内置模块,它提供了许多与 Python 解释器和系统环境进行交互的功能。 sys方法 1. 导入 sys 模块 在使用 sys 库的功能之前,需要先导入它: import sys2. 命令行参数 (sys.argv) sys.argv 是一个包含命令行参数…...
数据分布偏移检测:保障模型在生产环境中的稳定性
数据分布偏移检测:保障模型在生产环境中的稳定性 引言 在机器学习系统从开发环境部署到生产环境的过程中,数据分布偏移问题是影响模型性能的主要挑战之一。当训练数据与生产环境中的数据分布不一致时,即使是经过精心调优的模型也可能表现出明显的性能下降。本文将深入探讨…...
redis删除与先判断再删除的区别
在Redis中,“先判断存在再删除”与“直接删除”的区别主要体现在操作效率、原子性保障、并发安全性三个方面,具体对比如下: 1. 操作效率 直接删除:仅需执行DEL命令一次,无论键是否存在均直接操作…...
3.6、数字签名
目录 数字签名数字签名与验证过程 数字签名 数字签名是签名者使用自己的私钥对待签名数据的哈希值做密码运算得到的一个结果 第一签名者用自己的私钥来对我们待签数据的哈希值进行签名,直接对数据进行签名其实也是可以的,只是对数据签名,这…...
华为手机助手输入连接码时光标乱跳
问题复现:输入12345678,光标自动跳转导致连接码出现乱序情况。 千万别试着找出规律,已试动态规律非大牛误轻试 问题原因: 想啥呢?华哥的软件又不是我开发我要Know Why干啥 我只需关心解决方案 (可能时输入…...
本地化部署Deepseek关于Ollama 安全加固方案(新手易学)
本地化部署Deepseek关于Ollama 安全加固方案(新手易学) 本方案针对使用ChatBox调用Ollama部署DeepSeek-R1:14b模型时的安全防护需求,提供四重防护措施。 🔒 一、关闭外网访问(关键步骤) 1. 修改监听地址 …...
C++ STL算法函数 —— 应用及其操作实现
一、STL算法函数分类概述 STL算法库提供了大量实用函数,按功能可分为以下五类: 1. 不修改序列的操作 定义:这些算法不会改变容器中的元素,仅对数据进行查询或统计。 典型函数: 函数功能示例find(first, last, value…...
AI数字人:口播与唇形同步的福音,支持本地部署/批量生成/口齿清晰
Heygem:开源前端界面的老六玩家 好消息!Heygem 在 GitHub 上开源了!不过,嘻嘻,只是前端界面开源,感觉更像是来 GitHub 刷一波知名度。不过这依然是个值得关注的工具。让我们先来看看它的官方介绍ÿ…...
【鸿蒙】封装日志工具类 ohos.hilog打印日志
封装一个ohos.hilog打印日志 首先要了解hilog四大日志类型: info、debug、warm、error 方法中四个参数的作用 domain: number tag: string format: string ...args: any[ ] 实例: //普通的info日志,使用info方法来打印 //第一个参数 : 0x0…...
附下载 | 2024 OWASP Top 10 基础设施安全风险.pdf
《2024 OWASP Top 10 基础设施安全风险》报告,由OWASP(开放网络应用安全项目)发布,旨在提升企业和组织对基础设施安全风险、威胁与漏洞的意识,并提供高质量的信息和最佳实践建议。报告列出了2024年最重要的10大基础设施…...
Chatbox通过百炼调用DeepSeek
解决方案链接:评测|零门槛,即刻拥有DeepSeek-R1满血版 方案概览 本方案以 DeepSeek-R1 满血版为例进行演示,通过百炼模型服务进行 DeepSeek 开源模型调用,可以根据实际需求选择其他参数规模的 DeepSeek 模型。百炼平台…...
Vue前端项目部署到宝塔面板的详细过程
目录 前言 一、项目的打包与上传 1、修改前端项目 2、关于test环境的补充修改 3、打包前端项目 二、添加站点,启动项目 三、总结 前言 书接上回 SpringBoot项目部署到宝塔面板的详细过程-CSDN博客 本次以SmartAdmin的项目为例,通过宝塔面板部署…...
免费高质量贴图(Textures) 网站推荐
以下是一些提供 免费或高质量贴图(Textures) 的网站,包括 PBR 贴图、HDRI 贴图、材质等,适用于 Three.js、Blender、Unity、Unreal Engine 等软件。 🌍 1. Poly Haven(https://polyhaven.com/)⭐…...
C++进阶——map和set的使用
目录 1、序列式容器和关联式容器 2、set系列的使用 2.1 set和multiset的参考文档 2.2 set类的介绍 2.3 set的构造和迭代器 2.4 set的增删查 2.5 set的insert和迭代器遍历 2.6 set的find和erase 2.7 set的lower_bound和upper_bound 2.8 multiset和set的差异 2.9 349.…...
AI机器学习---Anaconda
Anaconda指的是一个开源的Python发行版本,其包含了Conda、Python等180多个科学包及其依赖项。因为包含了大量的科学包,Anaconda 的下载文件比较大(约 531 MB),如果只需要某些包,或者需要节省带宽或存储空间…...
如何在Futter开发中做性能优化?
目录 1. 避免不必要的Widget重建 问题:频繁调用setState()导致整个Widget树重建。 优化策略: 2. 高效处理长列表 问题:ListView一次性加载所有子项导致内存暴涨。 优化策略: 3. 图片加载优化 问题:加载高分辨率…...
leetcode 75.颜色分类(荷兰国旗问题)
题目描述 题目分析 本题是经典的「荷兰国旗问题」,由计算机科学家 Edsger W. Dijkstra 首先提出。 要想单独解决这道题本身还是很简单的,统计0、1、2的数量然后按顺序赋值,或者手写一个冒泡排序,whatever。 但是在这一题中我们主…...
JVM--垃圾回收
垃圾回收的概念 垃圾回收主要针对的是堆中的对象,堆是一个共享的区域,创建的对象和数组都放在这个位置。但是我们不能一直的创建对象,也不是所有的对象能一直存放,如果不进行垃圾回收,内存迟早会耗尽,及时…...
Spring boot3-Http Interface: 声明式编程
来吧 1.首先引入pom.xml依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId> </dependency> 2.创建WebClientController控制器 import com.atguigu.boot3_07_http.serv…...
springboot EasyExcel 实现导入导出
1. 添加依赖 确保 Maven 依赖中包含 EasyExcel 3.0.5: <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.0.5</version></dependency><!-- excel工具 --><dep…...
基于RAGFlow本地部署DeepSpeek-R1大模型与知识库:从配置到应用的全流程解析
作者:后端小肥肠 🍊 有疑问可私信或评论区联系我。 🥑 创作不易未经允许严禁转载。 姊妹篇: DeepSpeek服务器繁忙?这几种替代方案帮你流畅使用!(附本地部署教程)-CSDN博客 10分钟上手…...
spring 创建单例 Bean 源码分析
一、创建单例Bean 1、创建单例 Bean 通过方法getBean()来创建单例bean。 代码入口: org.springframework.beans.factory.support.DefaultListableBeanFactory#preInstantiateSingletons spring boot version:2.6.13 org.springframework.beans.factory…...
GetCurrentTime
在实际编程中难免要获取当前时间并且进行格式化,本文给出了多种 GetCurrentTime() 方法以供选择。 C语言下使用strftime C 语言中可以使用 <time.h> 中的函数来获取和格式化时间 #include <stdio.h> #include <time.h>char* getCurrentTime() …...
HTB 学习笔记 【中/英】《Web 应用简介》P1
📌 这篇文章讲了什么? 介绍了 Web 应用 的概念、架构,以及与传统网站的区别。重点讲解了 Web 安全风险,包括 常见攻击方法(SQL 注入、文件包含、不安全的文件上传等)。介绍了 Web 渗透测试 的重要性&#…...
ROS catkin_make编译报错问题
对问题 CMake Error at graduation_design/CMakeLists.txt:226 (add_dependencies): The dependency target "graduation_design_generate_messages_cpp" of target "listener" does not exist 检查 generate_messages() 是否被注释 对 CMake Error at …...
【结构设计】3D打印创想三维Ender 3 v2
【结构设计】3D打印创想三维Ender 3 v2 文章目录 前言一、Creality Slicer1.2.3打印参数设置二、配件更换1.捆扎绑扎线2.气动接头3D打印机配件插头3.3D打印机配件Ender3pro/V2喷头套件4.读卡器 TF卡5.micro sd卡 三、调平四、参考文章总结 前言 使用工具: 1.创想三…...
并发编程2
接并发编程1 synchronized锁的实现 通过底层指令控制实现,Java提供的一种原子性内置锁,在进入synchronized后会从主内存复制一份共享变量到自己的工作内存,在工作内存中修改完成后,退出时会把工作内存的值写入到主内存ÿ…...
Linux 中 Git 使用指南:从零开始掌握版本控制
目录 1. 什么是 Git? Git 的核心功能: 2. Git 的安装 Ubuntu/Debian 系统: 验证安装: 3.gitee库 4. Git 的首次配置 配置用户名和邮箱: 查看配置: 5. Git 的基本使用 初始化仓库 添加文件到暂存区…...
C# Exe + Web 自动化 (BitComet 绿灯 自动化配置、设置)
BitComet GreenLight,内网黄灯转绿灯 (HighID), 增加p2p连接率提速下载-CSDN博客 前两天写个这个,每次开机关机后要重来一遍很麻烦的索性写个自动化。 先还是按照上面的教程自己制作一遍,留下Luck 以及 路由器相关的 端口记录信息。 (因为自…...
2024年12月CCF-GESP编程能力等级认证C++编程四级真题解析
四级真题的难度: 一、总体难度评价 CCF-GESP编程能力等级认证C++四级真题的难度通常被认为相对较高。它不仅要求考生具备扎实的C++编程基础,还需要考生掌握一定的算法和数据结构知识,以及良好的问题解决能力。 二、具体难度分析 理论知识考察: 单选题和判断题中,会涉…...
谷歌Chrome或微软Edge浏览器修改网页任意内容
在谷歌或微软浏览器按F12,打开开发者工具,切换到console选项卡: 在下面的输入行输入下面的命令回车: document.body.contentEditable"true"效果如下:...
《DeepSeek深度使用教程:开启智能交互新体验》Deepseek深度使用教程
《DeepSeek使用教程:开启智能交互新体验》 在当今数字化时代,人工智能技术正以前所未有的速度改变着我们的生活和工作方式。DeepSeek作为一款强大的人工智能工具,凭借其卓越的自然语言处理能力和多领域应用潜力,受到了众多开发者…...
Dijkstra算法
Dijkstra算法(迪杰斯特拉算法)是一种经典的单源最短路径算法,用于在加权图中找到从一个源点到所有其他顶点的最短路径。它要求图中不能有负权边,因为负权边可能会导致算法的贪心策略失效。 Dijkstra算法的基本思想 Dijkstra算法…...
Python中的静态方法如何使用?
在Python里,类当中的方法可以分为多种不同的类型,其中staticmethod是一个十分有趣而又实用的功能。我们来好好地聊一聊什么是静态方法,它的用途是什么,以及如何在实际应用中使用它们! 首先,定义一下静态方…...
【最后203篇系列】016 Q201架构思考
前言 Q200已经达到了我既定的目标,在最近的3个月,我需要进一步完善,达到可以试产的程度。 在这个过程当中,许多知识和体会一直在变。 qtv200到目前,虽然通过习惯(每晚运行离线策略和比对)方式维持了注意力的集中&…...