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

flutter 曲线学习 使用第三方插件实现左右滑动

flutter 曲线的使用 实现左右滑动

TemperatureChartPage()
在这里插入图片描述

TemperatureChartPage2() – 不太完善
在这里插入图片描述
方法 ChartDrawPage
在这里插入图片描述

import 'package:doluyo/dly_package/widget/dly_widget.dart';
import 'package:fl_chart/fl_chart.dart';
import 'package:flutter/material.dart';
import 'package:syncfusion_flutter_charts/charts.dart';显示图表使用 syncfusion_flutter_charts 插件实现
class TemperatureData {TemperatureData(this.time, this.temperature);final String time;final double temperature;
}class TempChart extends StatelessWidget {const TempChart({super.key});Widget build(BuildContext context) {return MaterialApp(home: ChartDrawPage('℃', '温度'),);}
}//其他方案
class TemperatureChartPage extends StatefulWidget {_TemperatureChartPageState createState() => _TemperatureChartPageState();
}class _TemperatureChartPageState extends State<TemperatureChartPage> {final List<TemperatureData> _temperatureData = [TemperatureData('00:00', -20.5),TemperatureData('01:00', -21.0),TemperatureData('02:00', -22.5),TemperatureData('03:00', -23.0),TemperatureData('04:00', -24.5),TemperatureData('05:00', -25.0),TemperatureData('06:00', -26.5),TemperatureData('07:00', -27.0),TemperatureData('08:00', -28.5),TemperatureData('09:00', -29.0),TemperatureData('10:00', -30.5),TemperatureData('11:00', -31.0),TemperatureData('12:00', -32.5),TemperatureData('13:00', -33.0),TemperatureData('14:00', -34.5),TemperatureData('15:00', -35.0),TemperatureData('16:00', -34.5),TemperatureData('17:00', -33.0),TemperatureData('18:00', -32.5),TemperatureData('19:00', -31.0),TemperatureData('20:00', -30.5),TemperatureData('21:00', -29.0),TemperatureData('22:00', -28.5),TemperatureData('23:00', -27.0),];double _visibleMinimum = 0;double _visibleMaximum = 10;void initState() {super.initState();// 设置初始可见范围为最后10个数据点_visibleMinimum = _temperatureData.length - 10;_visibleMaximum = _temperatureData.length.toDouble() - 1;}//实现左右滑动显示数据Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('温度曲线'),),body: Center(child: GestureDetector(onHorizontalDragUpdate: (details) {double delta = details.delta.dx;setState(() {_visibleMinimum = (_visibleMinimum - delta / 10).clamp(0, _temperatureData.length - 10);_visibleMaximum = _visibleMinimum + 9;});},child: Container(height: 200,decoration: BoxDecoration(color: Colors.white,borderRadius: BorderRadius.circular(20),boxShadow: [BoxShadow(color: Colors.grey.withOpacity(0.5),spreadRadius: 5,blurRadius: 7,offset: const Offset(0, 3),),],),child: SfCartesianChart(//backgroundColor: Colors.white,// zoomPanBehavior: ZoomPanBehavior(///图表不能滑动//   enablePanning: true,// ),primaryXAxis: CategoryAxis(labelRotation: -45,minimum: _visibleMinimum,maximum: _visibleMaximum,labelStyle: TextStyle(color: Colors.black,fontSize: 12,),axisLine: AxisLine(color: Colors.grey,width: 1,),majorGridLines: MajorGridLines(// color: Colors.grey.withOpacity(0.3),width: 0,//dashArray: [5, 5], // 设置虚线),),primaryYAxis: NumericAxis(title: AxisTitle(text: '温度 (°C)',alignment: ChartAlignment.center,),labelStyle: TextStyle(color: Colors.black,fontSize: 12,),axisLine: AxisLine(color: Colors.grey,width: 1,),majorGridLines: MajorGridLines(color: Colors.grey.withOpacity(0.3),width: 1,dashArray: [5, 5], // 设置虚线),),tooltipBehavior: TooltipBehavior(enable: true),series: <CartesianSeries>[LineSeries<TemperatureData, String>(dataSource: _temperatureData,xValueMapper: (TemperatureData data, _) => data.time,yValueMapper: (TemperatureData data, _) => data.temperature,dataLabelSettings: DataLabelSettings(isVisible: true),name: '温度',markerSettings: MarkerSettings(isVisible: true),color: Colors.blue,width: 3,//dashArray: [5, 5], // 设置虚线),],),).withPadding(EdgeInsets.all(20)),),),);}///不能滑动查看数据
// @override
// Widget build(BuildContext context) {
//   return Scaffold(
//     appBar: AppBar(
//       title: const Text('温度曲线'),
//     ),
//     body: Center(
//       child: Container(
//         height: 400,
//         child: SfCartesianChart(
//           zoomPanBehavior: ZoomPanBehavior(
//             enablePanning: true,
//           ),
//           primaryXAxis: CategoryAxis(
//             labelRotation: -45,
//           ),
//           primaryYAxis: NumericAxis(
//             title: AxisTitle(text: '温度 (°C)'),
//           ),
//           tooltipBehavior: TooltipBehavior(enable: true),//点击查看详情
//           series: <CartesianSeries>[
//             LineSeries<TemperatureData, String>(
//               dataSource: _temperatureData,
//               xValueMapper: (TemperatureData data, _) => data.time,
//               yValueMapper: (TemperatureData data, _) => data.temperature,
//               dataLabelSettings: DataLabelSettings(isVisible: true),//显示点参数
//               name: '温度',
//               markerSettings: MarkerSettings(isVisible: true),//显示圆点
//             ),
//           ],
//         ),
//       ),
//     ),
//   );
// }
}///不理想
class TemperatureChartPage2 extends StatefulWidget {_TemperatureChartPageState2 createState() => _TemperatureChartPageState2();
}class _TemperatureChartPageState2 extends State<TemperatureChartPage2> {final List<TemperatureData> _temperatureData = [TemperatureData('00:00', -20.5),TemperatureData('01:00', -21.0),TemperatureData('02:00', -22.5),TemperatureData('03:00', -23.0),TemperatureData('04:00', -24.5),TemperatureData('05:00', -25.0),TemperatureData('06:00', -26.5),TemperatureData('07:00', -27.0),TemperatureData('08:00', -28.5),TemperatureData('09:00', -29.0),TemperatureData('10:00', -30.5),TemperatureData('11:00', -31.0),TemperatureData('12:00', -32.5),TemperatureData('13:00', -33.0),TemperatureData('14:00', -34.5),TemperatureData('15:00', -35.0),TemperatureData('16:00', -34.5),TemperatureData('17:00', -33.0),TemperatureData('18:00', -32.5),TemperatureData('19:00', -31.0),TemperatureData('20:00', -30.5),TemperatureData('21:00', -29.0),TemperatureData('22:00', -28.5),TemperatureData('23:00', -27.0),];double _visibleMinimum = 0;double _visibleMaximum = 10;void initState() {super.initState();_visibleMinimum = _temperatureData.length - 10;_visibleMaximum = _temperatureData.length.toDouble() - 1;}Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('温度曲线'),),body: Center(child: GestureDetector(onHorizontalDragUpdate: (details) {double delta = details.delta.dx;setState(() {_visibleMinimum = (_visibleMinimum - delta / 10).clamp(0, _temperatureData.length - 10);_visibleMaximum = _visibleMinimum + 9;});},child: Container(height: 400,decoration: BoxDecoration(color: Colors.white,borderRadius: BorderRadius.circular(10),boxShadow: [BoxShadow(color: Colors.grey.withOpacity(0.5),spreadRadius: 5,blurRadius: 7,offset: const Offset(0, 3),),],),child: LineChart(LineChartData(minX: _visibleMinimum,maxX: _visibleMaximum,minY: -40,maxY: 0,lineTouchData: LineTouchData(enabled: true),gridData: FlGridData(show: true,drawHorizontalLine: true,drawVerticalLine: true,getDrawingHorizontalLine: (value) {return FlLine(color: Colors.grey.withOpacity(0.3),strokeWidth: 1,dashArray: [5, 5],);},getDrawingVerticalLine: (value) {return FlLine(color: Colors.grey.withOpacity(0.3),strokeWidth: 1,dashArray: [5, 5],);},),borderData: FlBorderData(show: true,border: Border.all(color: Colors.grey,width: 1,),),titlesData: FlTitlesData(show: true,rightTitles: const AxisTitles(sideTitles: SideTitles(showTitles: false),),topTitles: const AxisTitles(sideTitles: SideTitles(showTitles: false),),// bottomTitles: SideTitles(//   showTitles: true,//   getTitles: (value) {//     int index = value.toInt();//     if (index >= 0 && index < _temperatureData.length) {//       return _temperatureData[index].time;//     }//     return '';//   },//   getTextStyles: (value) => TextStyle(//     color: Colors.black,//     fontSize: 12,//   ),//   margin: 10,// ),bottomTitles: AxisTitles(sideTitles: SideTitles(showTitles: true,getTitlesWidget: (value, meta) =>bottomTitleWidgets(value, meta),reservedSize: 36,interval: 1,),drawBelowEverything: true,),),lineBarsData: [LineChartBarData(spots: _temperatureData.asMap().entries.map((entry) => FlSpot(entry.key.toDouble(),entry.value.temperature,)).toList(),isCurved: true,barWidth: 3,color: Colors.blue,dotData: FlDotData(show: true,getDotPainter: (spot, percent, barData, index) {return FlDotCirclePainter(radius: 4,color: Colors.blue,strokeWidth: 2,strokeColor: Colors.white,);},),belowBarData: BarAreaData(show: true,color: Colors.blue.withOpacity(0.3),),),],),),).withPadding(EdgeInsets.all(10)),),),);}Widget bottomTitleWidgets(double value, TitleMeta meta) {if (value % 1 != 0) {return Container();}final style = TextStyle(//color: AppColors.contentColorBlack,fontWeight: FontWeight.bold,//fontSize: min(18, 18 * chartWidth / 300),);return SideTitleWidget(axisSide: meta.axisSide,space: 16,child: Text(meta.formattedValue, style: style),);}
}///没效果
class TemperatureChartPage3 extends StatefulWidget {_TemperatureChartPageState3 createState() => _TemperatureChartPageState3();
}class _TemperatureChartPageState3 extends State<TemperatureChartPage3> {final List<TemperatureData> _temperatureData = [TemperatureData('00:00', -20.5),TemperatureData('01:00', -21.0),TemperatureData('02:00', -22.5),TemperatureData('03:00', -23.0),TemperatureData('04:00', -24.5),TemperatureData('05:00', -25.0),TemperatureData('06:00', -26.5),TemperatureData('07:00', -27.0),TemperatureData('08:00', -28.5),TemperatureData('09:00', -29.0),TemperatureData('10:00', -30.5),TemperatureData('11:00', -31.0),TemperatureData('12:00', -32.5),TemperatureData('13:00', -33.0),TemperatureData('14:00', -34.5),TemperatureData('15:00', -35.0),TemperatureData('16:00', -34.5),TemperatureData('17:00', -33.0),TemperatureData('18:00', -32.5),TemperatureData('19:00', -31.0),TemperatureData('20:00', -30.5),TemperatureData('21:00', -29.0),TemperatureData('22:00', -28.5),TemperatureData('23:00', -27.0),];double _visibleMinimum = 0;double _visibleMaximum = 10;void initState() {super.initState();_visibleMinimum = _temperatureData.length - 10;_visibleMaximum = _temperatureData.length.toDouble() - 1;}Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('温度曲线'),),body: Center(child: GestureDetector(onHorizontalDragUpdate: (details) {double delta = details.delta.dx;setState(() {_visibleMinimum = (_visibleMinimum - delta / 10).clamp(0, _temperatureData.length - 10);_visibleMaximum = _visibleMinimum + 9;});},child: Container(height: 400,decoration: BoxDecoration(color: Colors.white,borderRadius: BorderRadius.circular(10),boxShadow: [BoxShadow(color: Colors.grey.withOpacity(0.5),spreadRadius: 5,blurRadius: 7,offset: const Offset(0, 3),),],),child: LineChart(LineChartData(minX: _visibleMinimum,maxX: _visibleMaximum,minY: -40,maxY: 0,lineTouchData: LineTouchData(enabled: true),gridData: FlGridData(show: true,drawHorizontalLine: true,drawVerticalLine: true,getDrawingHorizontalLine: (value) {return FlLine(color: Colors.grey.withOpacity(0.3),strokeWidth: 1,dashArray: [5, 5],);},getDrawingVerticalLine: (value) {return FlLine(color: Colors.grey.withOpacity(0.3),strokeWidth: 1,dashArray: [5, 5],);},),borderData: FlBorderData(show: true,border: Border.all(color: Colors.grey,width: 1,),),titlesData: FlTitlesData(show: true,),lineBarsData: [LineChartBarData(spots: _temperatureData.asMap().entries.map((entry) => FlSpot(entry.key.toDouble(),entry.value.temperature,)).toList(),isCurved: true,barWidth: 3,color: Colors.blue,dotData: FlDotData(show: true,getDotPainter: (spot, percent, barData, index) {return FlDotCirclePainter(radius: 4,color: Colors.blue,strokeWidth: 2,strokeColor: Colors.white,);},),belowBarData: BarAreaData(show: true,color: Colors.blue.withOpacity(0.3),),),],),),),),),);}
}///没效果
class TemperatureChartPage4 extends StatefulWidget {_TemperatureChartPageState4 createState() => _TemperatureChartPageState4();
}class _TemperatureChartPageState4 extends State<TemperatureChartPage4> {final List<TemperatureData> _temperatureData = [TemperatureData('00:00', -20.5),TemperatureData('01:00', -21.0),TemperatureData('02:00', -22.5),TemperatureData('03:00', -23.0),TemperatureData('04:00', -24.5),TemperatureData('05:00', -25.0),TemperatureData('06:00', -26.5),TemperatureData('07:00', -27.0),TemperatureData('08:00', -28.5),TemperatureData('09:00', -29.0),TemperatureData('10:00', -30.5),TemperatureData('11:00', -31.0),TemperatureData('12:00', -32.5),TemperatureData('13:00', -33.0),TemperatureData('14:00', -34.5),TemperatureData('15:00', -35.0),TemperatureData('16:00', -34.5),TemperatureData('17:00', -33.0),TemperatureData('18:00', -32.5),TemperatureData('19:00', -31.0),TemperatureData('20:00', -30.5),TemperatureData('21:00', -29.0),TemperatureData('22:00', -28.5),TemperatureData('23:00', -27.0),];double _visibleMinimum = 0;double _visibleMaximum = 10;void initState() {super.initState();_visibleMinimum = _temperatureData.length - 10;_visibleMaximum = _temperatureData.length.toDouble() - 1;}Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('温度曲线'),),body: Center(child: GestureDetector(onHorizontalDragUpdate: (details) {// 调整滑动的灵敏度,避免遮挡Y轴double delta = details.delta.dx;setState(() {_visibleMinimum = (_visibleMinimum - delta / 20).clamp(0, _temperatureData.length - 10);_visibleMaximum = _visibleMinimum + 9;});},child: Container(height: 400,decoration: BoxDecoration(color: Colors.white,borderRadius: BorderRadius.circular(10),boxShadow: [BoxShadow(color: Colors.grey.withOpacity(0.5),spreadRadius: 5,blurRadius: 7,offset: const Offset(0, 3),),],),child: LineChart(LineChartData(minX: _visibleMinimum,maxX: _visibleMaximum,minY: -40,maxY: 0,lineTouchData: LineTouchData(enabled: false),gridData: FlGridData(show: true,drawHorizontalLine: true,drawVerticalLine: true,getDrawingHorizontalLine: (value) {return FlLine(color: Colors.grey.withOpacity(0.3),strokeWidth: 1,dashArray: [5, 5],);},getDrawingVerticalLine: (value) {return FlLine(color: Colors.grey.withOpacity(0.3),strokeWidth: 1,dashArray: [5, 5],);},),borderData: FlBorderData(show: true,border: Border.all(color: Colors.grey,width: 1,),),titlesData: FlTitlesData(show: true,topTitles: const AxisTitles(sideTitles: SideTitles(showTitles: false),),rightTitles: const AxisTitles(sideTitles: SideTitles(showTitles: false),),leftTitles: AxisTitles(sideTitles: SideTitles(showTitles: true,reservedSize: 50, // 为Y轴标题预留空间getTitlesWidget: (value, meta) {return SideTitleWidget(axisSide: meta.axisSide,child: Text('${value.toInt()}°C'),);},),),bottomTitles: AxisTitles(sideTitles: SideTitles(showTitles: true,reservedSize: 30,interval: 1,getTitlesWidget: bottomTitleWidgets,),),),lineBarsData: [LineChartBarData(spots: _temperatureData.asMap().entries.map((entry) => FlSpot(entry.key.toDouble(),entry.value.temperature,)).toList(),isCurved: true,//是否曲线barWidth: 3,color: Colors.blue,dotData: FlDotData(show: true, //显示点getDotPainter: (spot, percent, barData, index) {//圆点装饰return FlDotCirclePainter(radius: 4,color: Colors.blue,strokeWidth: 2,strokeColor: Colors.white,);},),belowBarData: BarAreaData(//阴影show: false,//color: Colors.blue.withOpacity(0.3),),),],),).withPadding(EdgeInsets.only(left: 10, top: 10, right: 10),),).withPadding(// 添加padding,确保Y轴不被遮挡EdgeInsets.all(20),),),),);}Widget bottomTitleWidgets(double value, TitleMeta meta) {const style = TextStyle(fontWeight: FontWeight.bold,fontSize: 13,//color: AppColors.contentColorBlack,);Widget text;text = Text('${_temperatureData[value.toInt()].time}', style: style);return SideTitleWidget(axisSide: meta.axisSide,child: text,);}
}//其他方案
class ChartDrawPage extends StatefulWidget {final String unit;final String sTitle;final List<TemperatureData>? list;const ChartDrawPage(this.unit,this.sTitle, {this.list = null,Key? key,}) : super(key: key);_ChartDrawPageState createState() => _ChartDrawPageState();
}class _ChartDrawPageState extends State<ChartDrawPage> {late List<TemperatureData> _temperatureData = [TemperatureData('00:00', -20.5),TemperatureData('01:00', -21.0),TemperatureData('02:00', -22.5),TemperatureData('03:00', -23.0),TemperatureData('04:00', -24.5),TemperatureData('05:00', -25.0),TemperatureData('06:00', -26.5),TemperatureData('07:00', -27.0),TemperatureData('08:00', -28.5),TemperatureData('09:00', -29.0),TemperatureData('10:00', -30.5),TemperatureData('11:00', -31.0),TemperatureData('12:00', -32.5),TemperatureData('13:00', -33.0),TemperatureData('14:00', -34.5),TemperatureData('15:00', -35.0),TemperatureData('16:00', -34.5),TemperatureData('17:00', -33.0),TemperatureData('18:00', -32.5),TemperatureData('19:00', -31.0),TemperatureData('20:00', -30.5),TemperatureData('21:00', -29.0),TemperatureData('22:00', -28.5),TemperatureData('23:00', -27.0),];double _visibleMinimum = 0;double _visibleMaximum = 10;void initState() {super.initState();if (widget.list != null && widget.list!.isNotEmpty) {_temperatureData = widget.list!;}// 设置初始可见范围为最后10个数据点_visibleMinimum = _temperatureData.length - 10;_visibleMaximum = _temperatureData.length.toDouble() - 1;}//实现左右滑动显示数据Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('温度曲线'),),body: Center(child: (_temperatureData.length > 10)? _build_chart2(context): _build_chart1(context),),);}///滑动查看数据Widget _build_chart2(BuildContext context) {return GestureDetector(onHorizontalDragUpdate: (details) {double delta = details.delta.dx;setState(() {_visibleMinimum = (_visibleMinimum - delta / 10).clamp(0, _temperatureData.length - 10);_visibleMaximum = _visibleMinimum + 9;});},child: SfCartesianChart(//backgroundColor: Colors.white,// zoomPanBehavior: ZoomPanBehavior(///图表不能滑动//   enablePanning: true,// ),primaryXAxis: CategoryAxis(labelRotation: -45,minimum: _visibleMinimum,maximum: _visibleMaximum,labelStyle: TextStyle(color: Colors.black,fontSize: 12,),axisLine: AxisLine(color: Colors.grey,width: 1,),majorGridLines: MajorGridLines(// color: Colors.grey.withOpacity(0.3),width: 0,//dashArray: [5, 5], // 设置虚线),),primaryYAxis: NumericAxis(// title: AxisTitle(//标题说明//   text: '${widget.sTitle}(${widget.unit})',//   alignment: ChartAlignment.center,// ),labelStyle: TextStyle(color: Colors.black,fontSize: 12,),axisLine: AxisLine(color: Colors.grey,width: 1,),majorGridLines: MajorGridLines(color: Colors.grey.withOpacity(0.3),width: 1,dashArray: [5, 5], // 设置虚线),),tooltipBehavior: TooltipBehavior(enable: true),series: <CartesianSeries>[LineSeries<TemperatureData, String>(dataSource: _temperatureData,xValueMapper: (TemperatureData data, _) => data.time,yValueMapper: (TemperatureData data, _) => data.temperature,dataLabelSettings: DataLabelSettings(isVisible: true),name: '${widget.sTitle}',markerSettings: MarkerSettings(isVisible: true),color: Colors.blue,width: 3,//dashArray: [5, 5], // 设置虚线),],),);}///不能滑动查看数据Widget _build_chart1(BuildContext context) {return SfCartesianChart(zoomPanBehavior: ZoomPanBehavior(enablePanning: true,),primaryXAxis: CategoryAxis(labelRotation: -45,),// primaryYAxis: NumericAxis(//   title: AxisTitle(text: '温度 (°C)'),// ),tooltipBehavior: TooltipBehavior(enable: true),//点击查看详情series: <CartesianSeries>[LineSeries<TemperatureData, String>(dataSource: _temperatureData,xValueMapper: (TemperatureData data, _) => data.time,yValueMapper: (TemperatureData data, _) => data.temperature,dataLabelSettings: DataLabelSettings(isVisible: true),//显示点参数name: '${widget.sTitle}',markerSettings: MarkerSettings(isVisible: true),color: Colors.blue,width: 3,),],);}
}

插件

  #图表使用--曲线 https://pub.dev/packages/fl_chart/versionsfl_chart: ^0.69.0#图表--曲线 https://pub.dev/packages/syncfusion_flutter_chartssyncfusion_flutter_charts: ^27.2.4

相关文章:

flutter 曲线学习 使用第三方插件实现左右滑动

flutter 曲线的使用 实现左右滑动 TemperatureChartPage() TemperatureChartPage2() – 不太完善 方法 ChartDrawPage import package:doluyo/dly_package/widget/dly_widget.dart; import package:fl_chart/fl_chart.dart; import package:flutter/material.dart; impor…...

【WRF工具】GIS4WRF详细介绍:配置 WPS/WRF

【WRF工具】GIS4WRF详细介绍 QGIS-GIS4WRF安装&#xff08;Installation&#xff09;安装 QGIS安装 GIS4WRF GIS4WRF 配置(Configuration)一、如何进入配置界面二、可配置内容1️⃣ 设置工作目录2️⃣ 与 WPS/WRF 集成3️⃣ 与 NCAR 数据档案集成 参考 GIS4WRF 是一个在 QGIS 中…...

【自用记录】本地关联GitHub以及遇到的问题

最近终于又想起GitHub&#xff0c;想上传代码和项目到仓库里。 由于很早之前有在本地连接过GitHub&#xff08;但没怎么用&#xff09;&#xff0c;现在需要重新搞起&#xff08;操作忘得差不多&#xff09;。 在看教程实操的过程中遇到了一些小问题&#xff0c;遂记录一下。 前…...

小程序中跨页面组件共享数据的实现方法与对比

小程序中跨页面/组件共享数据的实现方法与对比 在小程序开发中&#xff0c;实现不同页面或组件之间的数据共享是常见需求。以下是几种主要实现方式的详细总结与对比分析&#xff1a; 一、常用数据共享方法 全局变量&#xff08;getApp()&#xff09;、本地缓存&#xff08;w…...

ngx_http_core_merge_srv_conf

定义在 src\http\ngx_http_core_module.c static char * ngx_http_core_merge_srv_conf(ngx_conf_t *cf, void *parent, void *child) {ngx_http_core_srv_conf_t *prev parent;ngx_http_core_srv_conf_t *conf child;ngx_str_t name;ngx_http_server_name_t…...

如何在中科方德llinux系统上离线安装salt-minion

1&#xff0c;我的系统是什么 国产操作系统 中科方德 NFSChina Server release 4.0.240701 (RTM4-G320) 2&#xff0c;首先准备好两个安装包 salt-minion-2015.8.8-2.el7.noarch.rpm和salt-2015.8.8-2.el7.noarch.rpm 后者这个是前者的依赖项。 所以先安装salt-2015.8.8-2.e…...

RAG系统实战:当检索为空时,如何实现生成模块的优雅降级(Fallback)?

目录 RAG系统实战&#xff1a;当检索为空时&#xff0c;如何实现生成模块的优雅降级&#xff08;Fallback&#xff09;&#xff1f; 一、为什么需要优雅降级&#xff08;Fallback&#xff09;&#xff1f; 二、常用的优雅降级策略 策略一&#xff1a;预设后备提示&#xff0…...

输电线路航空标志球:低空飞行的安全路标 / 恒峰智慧科技

在现代社会&#xff0c;随着航空业的快速发展&#xff0c;低空飞行活动日益频繁。为了确保飞行安全&#xff0c;避免飞机与高压电线等障碍物发生碰撞&#xff0c;输电线路航空标志球应运而生。这种装置被广泛应用于高压输电线路上&#xff0c;尤其是超高压和跨江输电线&#xf…...

【SPP】蓝牙 SDP 协议在SPP中的互操作性解析

在蓝牙通信体系中&#xff0c;服务发现协议&#xff08;SDP, Service Discovery Protocol&#xff09;扮演着 "服务目录" 的核心角色。对于串口通信协议&#xff08;SPP, Serial Port Profile&#xff09;而言&#xff0c;SDP 服务记录是设备间建立串口连接的基础&am…...

本地部署vanna ai+通过http请求调用vanna

本地部署vanna ai ① 准备python环境&#xff0c;推荐最新的python12、13版本 ② 安装vanna库 我这里安装的python环境是python312 进入目录python312/Scripts&#xff0c;在该目录下的命令行窗口中输入以下命令&#xff1a;pip jinstall vanna pip install vanna③ 配置向…...

seq2seq

理解 transformer 中的 encoder decoder 详细的 transformer 教程见&#xff1a;【极速版 – 大模型入门到进阶】Transformer 文章目录 &#x1f30a; Encoder: 给一排向量输出另外一排向量&#x1f30a; Encoder vs. Decoder: multi-head attention vs. masked multi-head at…...

C++ ---- 虚继承

一、什么是虚继承 虚继承就是子类中只有一份间接父类的数据。用于解决多继承中的父类为非虚继承时出现的二义性问题&#xff0c;即菱形继承问题。继承方式需要加上virtual关键字。 二、虚继承的特性 以菱形继承为例&#xff1a; 1.不使用虚继承 根据输出的大小和关系图&…...

COMSOL多层圆片随机堆积三维模型

构建多层圆片随机堆积三维模型可用于材料、化工、土木、生物医学等多领域的研究&#xff0c;如复合材料设计、催化剂载体、颗粒物堆积研究等。本案例介绍在COMSOL内建立三维圆片堆积模型。 三维圆片堆积模型可采用CAD纤维密堆积3D插件建立&#xff0c;参数设置如图所示&#…...

PHP 开发API接口签名验证

就安全来说&#xff0c;所有客户端和服务器端的通信内容应该都要通过加密通道(HTTPS)传输&#xff0c;明文的HTTP通道将会是man-in-the- middle及其各种变种攻击的温床。所谓man-in-the-middle攻击简单讲就是指恶意的黑客可以在客户端和服务器端的明文通信通道上做手 脚&#x…...

Web开发-JavaEE应用ORM框架SQL预编译JDBCMyBatisHibernateMaven

知识点&#xff1a; 0、安全开发-JavaEE-构建工具-Maven 1、安全开发-JavaEE-ORM框架-JDBC 2、安全开发-JavaEE-ORM框架-Mybatis 3、安全开发-JavaEE-ORM框架-Hibernate 4、安全开发-JavaEE-ORM框架-SQL注入&预编译 一、演示案例-WEB开发-JavaEE-构建工具-Maven IDEA配置m…...

软考-数据库系统工程师第四版pdf

软考-数据库系统工程师第四版pdf git中的文件相对没有那么清楚&#xff0c;网盘的有高清版 github下载 这里我给出仓库地址 链接: https://github.com/yaodada123/ruankao-pdf https://github.com/yaodada123/ruankao-pdf gitee下载 https://gitee.com/yao-hengchao/ruank…...

扫描仪+文档pdf编辑器+pdf格式转换器

小扫描仪是一款集“扫描仪文档pdf编辑器pdf格式转换器”于一体的多功能扫描软件&#xff0c;软件功能丰富&#xff0c;而且目前是免费&#xff0c;功能包括扫描、编辑、转换三部分。 扫描&#xff1a;扫描的功能包括文档扫描、身份证扫描、护照扫描、书籍扫描、OCR和二维码。 扫…...

【stm32--HAL库DMA+USART+空闲中断不定长收发数据】

串口通信-Hal库实现不定长度收发&#xff0c;DMAUSART DMA串口STM32CUBEMX配置&#xff08;工程创建&#xff09;基础配置时钟配置工程配置 代码编写现象 DMA 在正式配置之前&#xff0c;我们先来一起简单了解一下DMA。DMA&#xff08;Direct Memory Access&#xff0c;直接内…...

5G-A技术

最近的iOS 18.4 推送了 新功能&#xff0c;最引人注目的便是这个5G-A的这个功能&#xff0c;那什么是5G-A呢 &#xff1f; 目前北京 四环内 还是有能显示出5G-A标志的。 5G-A &#x1f310; 一句话概括&#xff1a; 5G-A 更快的速度 更低的延迟 更强的AI能力 更智能的网…...

Vue 组件 - 动态组件

Vue 渐进式JavaScript 框架 基于Vue2的学习笔记 - Vue 组件 - 动态组件 目录 动态组件 选项卡页面示例 更简单写法 增加输入框 弥补措施 总结 动态组件 选项卡页面示例 功能&#xff1a;选项卡功能&#xff0c;设置导航点击哪个显示相应页面。 设置三个全局组件&#…...

ffmpeg滤镜使用

ffmpeg实现画中画效果 FFmpeg中&#xff0c;可以通过overlay将多个视频流、多个多媒体采集设备、多个视频文件合并到一个界面中&#xff0c;生成画中画的效果 FFmpeg 滤镜 overlay 基本参数 x和y x坐标和Y坐标 eof action 遇到 eof表示时的处理方式&#xff0c;默认为重复。…...

【MVC简介-产生原因、演变历史、核心思想、组成部分、使用场景】

MVC简介 产生原因&#xff1a; MVC&#xff08;Model-View-Controller&#xff09;模式诞生于20世纪70年代&#xff0c;由Trygve Reenskaug在施乐帕克研究中心&#xff08;Xerox PARC&#xff09;为Smalltalk语言设计&#xff0c;目的是解决图形用户界面&#xff08;GUI&…...

基于大模型的房间隔缺损手术全流程预测与方案优化研究报告

目录 一、引言 1.1 研究背景与意义 1.2 研究目的与目标 1.3 研究方法与创新点 二、房间隔缺损概述 2.1 房间隔缺损定义与分类 2.2 发病机制与病理生理 2.3 流行病学特征 三、大模型在房间隔缺损预测中的应用原理 3.1 大模型技术简介 3.2 数据收集与预处理 3.3 模型…...

什么是 CSSD?

文章目录 一、什么是 CSSD&#xff1f;CSSD 的职责 二、CSSD 是如何工作的&#xff1f;三、CSSD 为什么会重启节点&#xff1f;情况一&#xff1a;网络和存储都断联&#xff08;失联&#xff09;情况二&#xff1a;收到其他节点对自己的踢出通知&#xff08;外部 fencing&#…...

uniapp APP端在线升级(简版)

设计思路&#xff1a; 1.版本比较&#xff1a;应用程序检查其当前版本与远程服务器上可用的最新版本 2. 更新状态指示&#xff1a;如果应用程序是不是最新的版本&#xff0c;则页面提示下载最新版本。 3.下载启动&#xff1a;通过plus.downloader.createDownload()启动新应用…...

2024年蓝桥杯Java B组省赛真题超详解析-分布式队列

问题&#xff1a;你需要回答在某个时刻&#xff0c;队列中有多少个元素具有可见性 方案&#xff1a;跟踪每个副节点已经同步到主节点队列的元素数量&#xff0c;并找出所有副节点中同步到的最少元素数量&#xff0c;这个数量即为所有副节点都已经同步的元素数量。 解析&#…...

Vue3入门

环境准备: node.js vscode or webstorm 哪个熟悉用哪个 这两个都是傻瓜式安装 浏览器直接搜索 下载即可 安装: 安装完node.js之后 按住快捷键 winR 打开命令提示符输入node 将显示版本信息 接着我们通过 vite 构建vue3工程 优点: 轻量快速的热重载&#xff08;HMR&#xf…...

向量库(Vector Database)概述

向量库&#xff08;Vector Database&#xff09;概述 1. 核心概念 ​向量 高维空间中的数值数组&#xff0c;通常由模型&#xff08;如BERT、ResNet&#xff09;将非结构化数据&#xff08;文本、图像等&#xff09;转换为嵌入向量。 ​向量相似性 衡量方法&#xff1a;余弦相…...

Oracle迁移达梦遇中断?试试SQLark的断点续迁功能!

在企业级数据迁移项目中&#xff0c;如果迁移单表数据量超过亿行、占用空间超过100GB时&#xff0c;一旦遇到网络中断或迁移报错&#xff0c;往往需要整表重新迁移&#xff0c;导致效率低下&#xff0c;严重影响项目进度。针对这一痛点&#xff0c;SQLark 支持对 Oracle→DM 的…...

上海某海外视频平台Android高级工程师视频一面

问的问题比较细&#xff0c;有很多小细节在里面&#xff0c;平时真不一定会注意到&#xff0c;做一个备忘&#xff1a; 1.Object类里面有哪些方法&#xff1f; Object 类是 Java 中所有类的根类&#xff0c;它定义了一些基本方法&#xff0c;供所有类继承和重写1. 常用方法 1…...

基于yolov11的汽车损伤检测系统python源码+onnx模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv11的汽车损伤检测系统是一种先进的计算机视觉技术&#xff0c;旨在快速准确地识别汽车的各种损伤类型。该系统利用YOLOv11模型的强大性能&#xff0c;实现了对车辆损伤的精确检测与分类。 该系统能够识别的损伤类型包括裂纹&#xff08;crack&#xff…...

华为IP(3)

DHCP Relay报文格式 DHCP Relay主要负责转发DHCP客户端与DHCP服务器之间的DHCP报文&#xff0c;所以DHCP Relay的报文格式只是把DHCP的报文部分字段做了相应的修改&#xff0c;报文格式没有发生变化 hops&#xff1a;表示当前DHCP报文经过DHCP中继的数目&#xff0c;该字段由…...

面试问题总结:qt工程师/c++工程师

C 语言相关问题答案 面试问题总结&#xff1a;qt工程师/c工程师 C 语言相关问题答案 目录基础语法与特性内存管理预处理与编译 C 相关问题答案面向对象编程模板与泛型编程STL 标准模板库 Qt 相关问题答案Qt 基础与信号槽机制Qt 界面设计与布局管理Qt 多线程与并发编程 目录 基础…...

【TS学习】(15)分布式条件特性

在 TypeScript 中&#xff0c;分布式条件类型&#xff08;Distributive Conditional Types&#xff09; 是一种特殊的行为&#xff0c;发生在条件类型作用于裸类型参数&#xff08;Naked Type Parameter&#xff09; 时。这种特性使得条件类型可以“分布”到联合类型的每个成员…...

四款高效数据报表工具 让数据分析更简单

概述 在数字化时代&#xff0c;企业和组织越来越依赖数据驱动决策&#xff0c;报表软件成为提高数据可视化能力、优化业务管理的关键工具。本文将为大家介绍四款功能强大的报表软件&#xff0c;帮助不同需求的企业找到合适的解决方案。 一、山海鲸报表 山海鲸报表是一款零代…...

QT 非空指针 软件奔溃

在用QT的实际项目中&#xff0c;出现如下现象&#xff1a; 运行软件再关闭软件&#xff0c;然后再运行软件会崩溃。等待5~10分钟&#xff0c;再运行软件&#xff0c;又正常&#xff0c;百思不得其解&#xff0c;后面找到原因是在头文件里定义指针变量时没有赋初nullptr&#x…...

图漾相机——C#语言属性设置

文章目录 前言1.示例程序说明2.SDK API功能介绍2.1 ListDevice2.2 Open2.3 OpenDeviceByIP2.4 Close2.5 DeviceStreamEnable2.6 DeviceStreamFormatDump2.7 DeviceStreamFormatConfig2.8 DeviceReadCurrentEnumData2.9 DeviceReadCalibData2.10 DeviceStreamOn2.11 DeviceStrea…...

WPF中viewmodel单例模式

1、单例模式介绍 单例模式是一种创建型设计模式&#xff0c;确保一个类只有一个实例&#xff0c;并提供一个全局访问点来获取这个实例。它常用于需要全局唯一访问点的场景&#xff0c;如配置管理、日志记录、数据库连接等。 2、WPF 中 ViewModel 的单例实现 在 WPF 中&#…...

AI比人脑更强,因为被植入思维模型【36】时光机理论思维

giszz的理解&#xff1a;据说是软银孙正义提出的一种思维模型&#xff0c;他利用同一时间内的地区差&#xff0c;通过引入技术、思维&#xff0c;在同一地区&#xff0c;形成了时间差。所谓商业模式&#xff0c;有时就是打空间差、时间差&#xff0c;信息差。 一、定义 时光机…...

SQL Server:用户权限

创建 & 删除 1. 创建用户命令整理 创建 admin2 用户 -- 在 master 数据库创建登录名 USE master; BEGINCREATE LOGIN [admin2] WITH PASSWORDNCljslrl0620!, DEFAULT_DATABASE[master], CHECK_EXPIRATIONOFF, CHECK_POLICYON; END;-- 在 db03 数据库创建用户并添加到相应…...

Qt之QTextEdit控制文本滚动, 停止滚动, 开始滚动, 鼠标控制滚动

对工作台文本框进行控制。含以下内容。详细说明在源码中可查看 至最底部停止滚动开始滚动 源码分两部分. .h文件和.cpp文件 MyTextEdit.h #ifndef MYTEXTEDIT_H #define MYTEXTEDIT_H#include <QObject> #include <QTextEdit> #include <QScrollBar> #includ…...

策略模式与元数据映射模式融合 JSR 380 验证规范实现枚举范围校验

类文件 Target({ElementType.METHOD,ElementType.FIELD,ElementType.ANNOTATION_TYPE,ElementType.CONSTRUCTOR,ElementType.PARAMETER,ElementType.TYPE_USE }) Retention(RetentionPolicy.RUNTIME) Documented Constraint(validatedBy {InEnumValidator.class, InEnumColle…...

9对象树(3)

目录 创建自定义的类&#xff0c;最主要的目的,是自定义一个析构函数,在析构函数中,完成打印.方便咱们看到最终的自动销毁对象的效果!!! 写完一个函数的声名之后, 按下 altenter, 在按下enter就可以自动的在对应的 cpp 文件中添加函数的定义了 内置类型&#xff0c;析构不会明…...

深入 OpenPDF:高级 PDF 生成与操作技巧

1 引言 1.1 项目背景 在许多企业级应用中,生成和操作 PDF 文档是一个常见的需求。PDF(Portable Document Format)因其格式统一、易于打印和分发而被广泛使用。本文将介绍如何使用 OpenPDF 库在 Java 项目中生成和操作 PDF 文档。 1.2 技术选型理由 OpenPDF:OpenPDF 是一…...

电脑屏幕亮度随心控,在Windows上自由调整屏幕亮度的方法

调整电脑屏幕的亮度对于保护视力和适应不同环境光线条件非常重要。无论是在白天强光下还是夜晚昏暗环境中&#xff0c;合适的屏幕亮度都能让您的眼睛更加舒适。本文中简鹿办公小编将向您介绍几种在 Windows 系统中调整屏幕亮度的方法。 方法一&#xff1a;使用快捷键 大多数笔…...

Navicat导出mysql数据库表结构说明到excel、word,单表导出方式记录

目前只找到一张一张表导出的方式 使用information_schema传入表名查询 字段名根据需要自行删减&#xff0c;一般保留序号、字段名、类型、说明就行 SELECT COLUMNS.ORDINAL_POSITION AS 序号, COLUMNS.COLUMN_NAME AS 字段名, COLUMNS.COLUMN_TYPE AS 类型(长度), COLUMNS.N…...

【C++笔记】C++常见二叉树OJ和拓扑排序

【C笔记】C常见二叉树OJ和拓扑排序 &#x1f525;个人主页&#xff1a;大白的编程日记 &#x1f525;专栏&#xff1a;C笔记 文章目录 【C笔记】C常见二叉树OJ和拓扑排序前言一.二叉树OJ1.1 根据二叉树创建字符串1.2 二叉树的层序遍历1.3 二叉树的最近公共祖先1.4 将二叉搜索…...

ARM-----数据处理、异常处理、模式切换

实列一&#xff1a; 1. 异常向量表 area reset, code, readonly code32 entry area reset, code, readonly&#xff1a;定义一个名为reset的代码区域&#xff0c;只读。 code32&#xff1a;指示编译器生成32位ARM指令。 entry&#xff1a;标记程序的入口点。 2. 程序入口…...

mapbox基础,使用geojson加载line线图层,实现铁路黑白间隔效果

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️line线图层样式二、🍀使用geojson加载…...

Python FastAPI + Celery + RabbitMQ 分布式图片水印处理系统

FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理 首先创建项目结构&#xff1a; c:\Users\Administrator\Desktop\meitu\ ├── app/ │ ├── __init__.py │ ├── main.py │ ├── celery_app.py │ ├── tasks.py │ └── config.py…...