【vue echart】echart实现风速风向图

实现效果:

风向原始数据如下:

风速原始数据如下:

具体代码:

javascript 复制代码
<div id="echartFs" style="width: 100%; height: 80%" />
javascript 复制代码
    getRendererFs(item) {
      
      let yearList = item[0].dateList
      // 重组风速风向的数据,因为我们后端传回的风速风向数据是一个数组,一组数据为风速,一组数据为风向
      let fs;
      let fx;
      item.forEach((item2)=>{
        if(item2.monitorCnName=='风向'){
          fx=item2.data[0].hisData
        }else if(item2.monitorCnName=='风速'){
          fs=item2.data[0].hisData
        }
      })
      
      let fsfx=[]
      let sameTime=''
      fs.forEach((item,index)=>{
        let fxz=fx[index].data/10<0?-fx[index].data/10:fx[index].data/10
        fsfx.push({
          value:item.data,
          symbolRotate:fxz,
          symbolRotateStr:this.changeFX(fx[index].data)
        })
      })
      
      // 处理传入的数据
      let EChart = this.$echarts.init(document.getElementById("echartFs"))
      let config = {
            // X轴
            xAxis: {
                type: 'category',
                data: yearList,
                axisLabel:{
                  color: '#FFFFFF',
                  formatter:function(value,index){
                    return value.slice(11,13)
                  }
                },
                axisLine: {
            //y轴线的颜色以及宽度
            show: true,
            lineStyle: {
              color: '#FFFFFF',
              width: 1,
              type: 'solid',
            },
          },
            },
            // Y轴
            yAxis: {
                type: 'value',
                name: "风速(m/s)",
                axisLine: {
            //y轴线的颜色以及宽度
            show: true,
            lineStyle: {
              color: '#FFFFFF',
              width: 1,
              type: 'solid',
            },
          },
            },
            // 鼠标悬浮提示
            tooltip: {
                trigger: "axis",
                formatter(params) {
                    let tip =
                        "时间:" +
                        params[0].axisValue +
                        "<br/>风速:" +
                        (params[0].value ? params[0].value : "--") +
                        "m/s<br/>风向:" +
                        (params[0].data ? params[0].data.symbolRotateStr : "--")
                    return tip;
                },
            },
            // 数据
            series: [{
                data: fsfx,
                type: 'line',
                smooth: true, //这句就是让曲线变平滑的
                symbol: "arrow", //可以使用默认箭头,也可以换上自己的图片
                // symbol: "image://" + require("../../../assets/img/weather/wind.png"),
                symbolSize: 15,
                //折线样式
                lineStyle: {
                    color: '#38FFD7',
                    width: 2,
                },
                // symbol样式
                itemStyle: {
                    borderWidth: 1,
                    borderColor: '#38FFD7',
                    color: '#38FFD7'
                }
            }]
        };

      // 设置参数
      EChart.setOption(config)

      window.addEventListener('resize', function () {
        EChart.resize()
        
      })
    },
javascript 复制代码
//处理风向的函数    
changeFX(data){
        data=data/10
        //console.log('计算后风向',this.qxData[1].data)
        if(data<0){
          data=-data
        }
        if(data==0){
          data='北'
          return data
        }else if(data>0&&data<90){
          data='东北'
          return data
        }else if(data==90){
          data='东'
          return data
        }else if(data>90&&data<180){
          data='东南'
          return data
        }else if(data==180){
          data='南'
          return data
        }else if(data>180&&data<270){
          data='西南'
          return data
        }else if(data==270){
          data='西'
          return data
        }else if(data>270&&data<360){
          data='西北'
          return data
        }else if(data==360){
          data='北'
          return data
        }
      },
相关推荐
爱滑雪的码农10 小时前
详细说说React大型项目结构以及日常开发核心语法
前端·javascript·react.js
@大迁世界11 小时前
43.HTML 事件处理和 React 事件处理有什么区别?
前端·javascript·react.js·html·ecmascript
ZC跨境爬虫11 小时前
跟着 MDN 学 HTML day_38:(DocumentFragment 文档片段接口详解)
前端·javascript·ui·html·音视频
@大迁世界12 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
xiangxiongfly91514 小时前
Vue3 根据角色权限动态加载路由
前端·javascript·vue.js·动态加载路由
Aolith15 小时前
我是怎么把个人论坛首页性能从80分优化到100分的(附踩坑全记录)
vue.js·性能优化
费曼学习法15 小时前
React 18 并发模式(Concurrent Mode):Fiber 架构的终极进化
javascript·react.js
_风满楼15 小时前
TDD 进阶:换个角度看会议室预约
前端·javascript·github
Amy_yang15 小时前
uni-app 安卓端纯前端预览 DOCX 的实现思路
前端·vue.js
子兮曰16 小时前
SuperSplat 深度解析:7.6K Stars 的浏览器端 3D 高斯泼溅编辑器 — 在 Web 上编辑现实
前端·javascript·webgl