zoukankan      html  css  js  c++  java
  • 液位量筒

    1.效果如下:

    预览页:

    https://volodyan.github.io/vue3_level_dh_echars_preview/#/

    2.代码如下:

    echartsDemo.vue
    <template>
      <div class="chart"></div>
    </template>
    <script>
    import Bus from "@/utils/bus.js";
    import { debounce } from "@/utils";
    
    
    export default {
      name: "echartsDemo",
      data() {
        return {
          autoResize: true,
          chart: null,
          sidebarElm: null,
          chartData: null,
          imgtest: require("@/assets/img/bar.png"),
        };
      },
    
      // watch: {
      //   chartData: {
      //     deep: true,
      //     immediate:true,
      //     handler(val) {
      //       this.drawEcharts();
      //     },
      //   },
      // },
      mounted() {
        Bus.$on("ToEcharts2", (e, e2,MaxData) => {
          let linedata = e;
          let linedata2 = e2;
          let a = { linedata, linedata2 ,MaxData};
          this.chartData = a;
          this.$nextTick(() => {
            this.drawEcharts();
          });
        });
       this.resetSizefun();
      },
      beforeDestroy() {
        if (!this.chart) {
          return;
        }
        if (this.autoResize) {
          window.removeEventListener("resize", this.__resizeHandler);
        }
    
        this.sidebarElm &&
          this.sidebarElm.removeEventListener(
            "transitionend",
            this.sidebarResizeHandler
          );
    
        this.chart.dispose();
        this.chart = null;
      },
      methods: {
        drawEcharts() {
          this.initChart();
        },
        initChart() {
          this.chart = this.$echarts.init(this.$el, "macarons");
          this.chart.clear();
          this.setOptions(this.chartData);
        },
    
        setOptions(chartData) {
          console.log("chartData", chartData);
          this.chart.setOption({
            // backgroundColor: "#242424",
            grid: [
              {//液位静态
                top: "80",
                bottom: "20",
                right: "24%",
                left: "16.8%",
                 "63.8%",
                height: "55%",
              },
              {//"检查井"
                top: "60",
                bottom: "20",
                right: "25%",
                left: "16%",
                 "80%",
                height: "60%",
              },
                {//液位波浪动画
                top: "80",
                bottom: "20",
                right: "24%",
                left: "16.8%",
                 "63.8%",
                height: "55%",
              }, {//rightLabel—series
                top: "80",
                bottom: "20",
                right: "24%",
                left: "16.8%",
                 "63.8%",
                height: "55%",
              },
            ],
            animation: false,
            tooltip: {
              trigger: "axis",
              show: false,
              axisPointer: {
                type: "cross",
              },
            },
    
            xAxis: [
              {
                type: "category",
                gridIndex: 0,
                boundaryGap: false,
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisLabel: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
              {
                type: "category",
                gridIndex: 1,
                boundaryGap: false,
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisLabel: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
               {
                type: "category",
                gridIndex: 2,
                boundaryGap: false,
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisLabel: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },{
                type: "category",
                gridIndex: 3,
                boundaryGap: false,
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisLabel: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
            ],
         
            yAxis: [
              {//液位静态
                type: "value",
                gridIndex: 0,
                max: chartData.MaxData,
                offset: 10,
                axisLabel: {
                  show: true,
                  formatter: "{value} ",
                  fontSize: "16px",
                },
                axisPointer: {
                  snap: true,
                },
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
    
              {
                type: "value",//"检查井"
                gridIndex: 1,
               
                max: 100,
                axisLabel: {
                  show: false,
                },
                axisPointer: {
                  snap: true,
                },
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
              {
                type: "value",
                gridIndex: 2,//液位波浪动画
                max: chartData.MaxData,
                axisLabel: {
                  show: false,
                },
                axisPointer: {
                  snap: true,
                },
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
              {
                type: "value",//rightLabel—series
                gridIndex: 3,
                max: 100,
                position: "right",
                offset: 15,
                axisLabel: {
                  show: true,
                  formatter: "{value}% ",
                  fontSize: "16px",
                },
                axisPointer: {
                  snap: true,
                },
                splitLine: { show: false },
                axisLine: {
                  show: false,
                },
                axisTick: {
                  show: false,
                },
              },
            ],
            series: [
              {
                name: "液位波浪动画",
                data: chartData.linedata2,
                type: "line",
                xAxisIndex: 2,
                yAxisIndex: 2,
                animation: false,
                smooth: true,
                connectNulls: true,
                symbol: "none",
                lineStyle: {
                   0,
                },
                areaStyle: {
                  //覆盖区域的渐变色
                  normal: {
                    // color: '#6698FF', //改变区域颜色
                    color: new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [
                      {
                        offset: 1,
                        color: "#5986E4 ", // 60% 处的颜色
                      },
                      {
                        offset: 0.55,
                        color: "#8FC0FD ", // 30% 处的颜色
                      },
                      {
                        offset: 0,
                        color: "#5986E4", // 100% 处的颜色
                      },
                    ]), //背景渐变色
    
                    opacity: 1,
                  },
                },
    
                z: 23,
              },
    
              {
                name: "液位静态",
                data: chartData.linedata,
                type: "line",
                xAxisIndex: 0,
                yAxisIndex: 0,
                animation: false,
                smooth: true,
                connectNulls: true,
                symbol: "none",
                lineStyle: {
                   0,
                  color: {
                    type: "linear",
                    colorStops: [
                      {
                        offset: 0,
                        color: "#D575C2", // 0% 处的颜色,
                        transition: 2,
                      },
                      {
                        offset: 0.66,
                        color: "#D575C2", // 66% 处的颜色
                        transition: 2,
                      },
                      {
                        offset: 1,
                        color: "#fff", // 100% 处的颜色
                        transition: 2,
                      },
                    ],
                    opacity: 0.4,
                    globalCoord: false, // 缺省为 false
                  },
                },
                areaStyle: {
                  //覆盖区域的渐变色
                  normal: {
                    // color: '#6698FF', //改变区域颜色
                    color: new this.$echarts.graphic.LinearGradient(0, 0, 1, 0, [
                      {
                        offset: 1,
                        color: "#5986E4 ", // 60% 处的颜色
                      },
                      {
                        offset: 0.7,
                        color: "#8FC0FD ", // 30% 处的颜色
                      },
                      {
                        offset: 0,
                        color: "#5986E4", // 100% 处的颜色
                      },
                    ]), //背景渐变色
    
                    opacity: 1,
                  },
                },
    
                z: 22,
              },
              {
                name: "rightLabel—series",
                data: chartData.linedata,
                type: "line",
                xAxisIndex: 3,
                yAxisIndex: 3,
                animation: false,
                smooth: true,
                connectNulls: true,
                symbol: "none",
                lineStyle: {
                   0,
                },
                areaStyle: {
                  //覆盖区域的渐变色
                  normal: {
                    // color: '#6698FF', //改变区域颜色
    
                    opacity: 0,
                  },
                },
    
                z: 22,
              },
              {
                name: "检查井",
                type: "pictorialBar",
                barCategoryGap: "10%",
                xAxisIndex: 1,
                yAxisIndex: 1,
                symbol: `image://${this.imgtest}`,
                symbolSize: ["100%", "120%"],
                symbolOffset: [-26.5, 16],
                symbolMargin: "5%",
                // animationDelay: function (dataIndex, params) {
                //   return params.index * 30;
                // },
                itemStyle: {
                  opacity: 1,
                },
                emphasis: {
                  itemStyle: {
                    opacity: 1,
                    color: "#76DCF9",
                    fontSize: 30,
                  },
                },
    
                data: [100],
    
                z: 6,
              },
            ],
          });
        },
        sidebarResizeHandler(e) {
          if (e.propertyName === "width") {
            this.__resizeHandler();
          }
        },
        //窗口改变执行方法
        resetSizefun() {
          if (this.autoResize) {
            this.__resizeHandler = debounce(() => {
              if (this.chart) {
                this.chart.resize();
              }
            }, 100);
            window.addEventListener("resize", this.__resizeHandler);
          }
    
          // 监听侧边栏的变化
          this.sidebarElm = document.getElementsByClassName("sidebar-container")[0];
          this.sidebarElm &&
            this.sidebarElm.addEventListener(
              "transitionend",
              this.sidebarResizeHandler
            );
        },
      },
    };
    </script>
    <style lang="scss" scoped>
    .chart {
       375px;
      height: 428px;
    }
    </style>
    View Code

    echartscomponents.vue

    <template>
      <div class="echartscomponents">
        <div class="echartsbox">
          <echartsDemo class="echartsDemobox" />
       <!--    <div class="labeloutbox">
            <div v-for="(item, index) in 10" :key="index" class="itembox">
              {{ item * 10 }}%
            </div>
          </div> -->
        </div>
        <div class="Inputoutbox">
          <div class="Inputoutbox_max">
            <div class="Titlebox">最大值:</div>
            <div>
              <el-input
                v-model="MaxData"
                placeholder="请输入最大值"
                @change="maxfun"
              ></el-input>
            </div>
          </div>
          <div class="Inputoutbox_level">
            <div class="Titlebox">液位:</div>
            <div>
              <el-input
                v-model="LevelData"
                placeholder="请输入液位"
                @change="Levelfun"
              ></el-input>
            </div>
          </div>
          <div class="Inputoutbox_draw">
            <el-button type="primary" @click="InputDrawfun">画图</el-button>
          </div>
        </div>
        <!--  <div class="showdataStyle">showpddata——————{{ showpddata }}</div> -->
        <div @click="pausefun" class="pausefunclass">暂停动画</div>
      </div>
    </template>
    
    <script>
    import Bus from "@/utils/bus.js";
    import echartsDemo from "./echartsDemo";
    
    export default {
      name: "echartscomponents",
      components: {
        echartsDemo,
      },
      data() {
        return {
          fps: 60,
          pause: false,
          now: null,
          then: Date.now(),
          delta: null,
          /*  */
          showpddata: null,
          MaxData: "",
          LevelData: "",
        };
      },
      mounted() {},
      methods: {
        maxfun() {
          if (!!this.MaxData && !!this.LevelData) {
            this.InputDrawfun();
          }
        },
        Levelfun() {
          if (!!this.MaxData && !!this.LevelData) {
            this.InputDrawfun();
          }
        },
        InputDrawfun() {
          let newarr = new Array(4).fill(Number(this.LevelData));
          let newarr2 = [];
          let pddata = Number(this.LevelData);
          this.showpddata = pddata;
          for (var i = 0; i < 4; i++) {
            newarr2.push(pddata + Math.random() * (Number(this.MaxData) / 30));
          }
          Bus.$emit("ToEcharts2", newarr, newarr2, Number(this.MaxData));
    
          this.tick();
        },
        pausefun() {
          this.pause = !this.pause;
          if (!this.pause) {
            this.tick();
          }
        },
        tick() {
          var interval = 22000 / this.fps;
          window.requestAnimationFrame =
            window.requestAnimationFrame ||
            window.mozRequestAnimationFrame ||
            window.webkitRequestAnimationFrame ||
            window.msRequestAnimationFrame;
          if (this.pause) return;
          if (window.requestAnimationFrame) {
            requestAnimationFrame(this.tick);
            this.now = Date.now();
            this.delta = this.now - this.then;
            if (this.delta > interval) {
              // 这里不能简单then=now,否则还会出现上边简单做法的细微时间差问题。例如fps=10,每帧100ms,而现在每16ms(60fps)执行一次draw。16*7=112>100,需要7次才实际绘制一次。这个情况下,实际10帧需要112*10=1120ms>1000ms才绘制完成。
              this.then = this.now - (this.delta % interval);
              this.draw(); // ... Code for Drawing the Frame ...
            }
          } else {
            setTimeout(this.tick, interval);
            this.draw();
          }
        },
        draw() {
          let newarr = new Array(4).fill(Number(this.LevelData));
          let newarr2 = [];
          let pddata = Number(this.LevelData);
          this.showpddata = pddata;
          for (var i = 0; i < 4; i++) {
            newarr2.push(pddata + Math.random() * (Number(this.MaxData) / 30));
          }
          Bus.$emit("ToEcharts2", newarr, newarr2, Number(this.MaxData));
        },
      },
    };
    </script>
    
    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped lang="scss">
    .echartscomponents {
      display: flex;
      flex-flow: column;
      justify-content: flex-start;
      align-items: center;
       100%;
      height: 90vh;
      .echartsbox {
        display: flex;
        flex-flow: row nowrap;
        justify-content: center;
        align-items: center;
         100%;
        height: 460px;
        //background: #2c3e50;
        margin-top: 60px;
        position: relative;
        .echartsDemobox {
        }
    
        .labeloutbox {
          position: relative;
          top: 91px;
          right: 2.5%;
          .itembox {
            margin-bottom: 10px;
            font-size: 12px;
          }
        }
      }
      .Inputoutbox {
        display: flex;
        flex-flow: column;
        align-items: center;
    
         100%;
        .Inputoutbox_max {
          display: flex;
          flex-flow: row nowrap;
          justify-content: flex-start;
          align-items: center;
           288px;
          margin-top: 20px;
          .Titlebox {
            color: #2c3e50;
            font: normal 14px "微软雅黑";
            margin-right: 20px;
             60px;
          }
        }
        .Inputoutbox_level {
          display: flex;
          flex-flow: row nowrap;
          justify-content: flex-start;
          align-items: center;
           288px;
          margin-top: 20px;
          .Titlebox {
            color: #2c3e50;
            font: normal 14px "微软雅黑";
            margin-right: 20px;
             60px;
          }
        }
        .Inputoutbox_draw {
          display: flex;
          flex-flow: row nowrap;
          justify-content: center;
          align-items: center;
           288px;
          margin-top: 20px;
        }
      }
    
      .showdataStyle {
        display: flex;
        flex-flow: row nowrap;
        justify-content: center;
        align-items: center;
         288px;
        height: 120px;
        border: 1px solid #2c3e50;
    
        font: bold 24px "微软雅黑";
        margin-top: 60px;
      }
      .pausefunclass {
        display: flex;
        flex-flow: row nowrap;
        justify-content: center;
        align-items: center;
         210px;
        height: 60px;
        color: #fff;
        font: bold 24px "微软雅黑";
        background: #2c3e50;
        cursor: pointer;
        margin-top: 60px;
      }
    }
    </style>
    View Code
     
  • 相关阅读:
    centos7 启动mongodb时报错ERROR: child process failed, exited with error number 1
    liunxcentos7下 跟目录空间不足docker load镜像报错空间不足
    centos7下初始化硬盘挂载目录
    Jenkins打包出错
    CentOS 7 安装 Percona XtraDB Cluster 5.7
    Etcd集群搭建(证书通信)
    centos7下prometheus+grafana监控
    nginx代理
    装Centos7系统
    Dockerfile常用指令使用案例
  • 原文地址:https://www.cnblogs.com/volodya/p/14399082.html
Copyright © 2011-2022 走看看