数据可视化之大屏模板和自适应放大缩小方法

发布于:2022-12-25 ⋅ 阅读:(358) ⋅ 点赞:(0)

废话不多说直接上根据屏幕视口大小自动缩放的实现方法

方法一

通过js获取窗口宽高进行缩放建议配合vh,vw食用

<script>
    console.log(window.screen)
    let screenWidth = window.screen.width
    let screenHeight = window.screen.height

    let box = document.querySelector('.box')

    box.style.width = screenWidth + 'px'
    box.style.height = screenHeight + 'px'

    // window.innerWidth
    let pageWidth = window.innerWidth

    let scale = pageWidth / screenWidth

    document.body.style.transform = `scale(${scale})`


    window.onresize = function () {
      let pageWidth = window.innerWidth
      let scale = pageWidth / screenWidth

      document.body.style.transform = `scale(${scale})`

    }
  </script>

然后里面的echarts图表通过监听窗口变化实现自适应

pieChart1为你初始化的图表

window.onresize = function () {
        pieChart1.resize();
      };

效果图

 模板代码

css

 body {
        margin: 0;
      }

      .box {
        background: url(./img/bg.png) center center / cover;
        transform-origin: left top;
        position: relative;
      }

      .header {
        height: 80px;
      }

      .header h2 {
        text-align: center;
        color: #fff;
        font-size: 30px;
        font-weight: normal;
        margin: 0;
        line-height: 80px;
      }

      .main {
        height: calc(100vh - 80px);

        position: relative;
        /* top: 80px; */
        left: 0;
        bottom: 0;
        right: 0;
        display: flex;
      }

      .lt {
        position: absolute;
        left: 0;
        top: 0;
      }

      .rt {
        position: absolute;
        right: 0;
        top: 0;
        transform: rotateY(180deg);
      }

      .lb {
        position: absolute;
        bottom: 0;
        left: 0;
        transform: rotateX(180deg);
      }

      .rb {
        position: absolute;
        bottom: 0;
        right: 0;
        transform: rotateX(180deg) rotateY(180deg);
      }

      .left-container {
        width: 22%;
        position: relative;
        border: 5px solid #fff;
        margin: 20px;
      }

      .right-container {
        width: 78%;
        margin: 20px;
        display: flex;
        flex-direction: column;
        margin-left: 0;
      }

      .right-bottom-container {
        height: 35%;
        margin-top: 20px;
        border: 5px solid #fff;
      }

      .right-top-container {
        height: 65%;
        display: flex;
      }

      .right-top-left-container {
        border: 5px solid #fff;
        width: 65%;
        margin-right: 20px;
      }

      .right-top-right-container {
        width: 35%;
        display: flex;
        flex-direction: column;
      }

      .right-top-right-top-container {
        border: 5px solid #fff;
        height: 50%;
        margin-bottom: 10px;
      }

      .right-top-right-bottom-container {
        border: 5px solid #fff;
        height: 50%;
        margin-top: 10px;
      }

      .pie-1 {
        width: 100%;
        height: 30%;
      }
      .pie-2 {
        width: 100%;
        height: 100%;
      }

html

 <div class="box">
      <div class="header">
        <h2>机电设备电子档案</h2>
      </div>
      <div class="main">
        <svg class="lt" width="150" height="150">
          <polygon
            fill="#4fd2dd"
            points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;#4fd2dd"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#235fa7"
            points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
          >
            <animate
              attributeName="fill"
              values="#235fa7;#4fd2dd;#235fa7"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#4fd2dd"
            points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;transparent"
              dur="1s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
        </svg>
        <svg class="rt" width="150" height="150">
          <polygon
            fill="#4fd2dd"
            points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;#4fd2dd"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#235fa7"
            points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
          >
            <animate
              attributeName="fill"
              values="#235fa7;#4fd2dd;#235fa7"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#4fd2dd"
            points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;transparent"
              dur="1s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
        </svg>
        <svg class="rb" width="150" height="150">
          <polygon
            fill="#4fd2dd"
            points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;#4fd2dd"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#235fa7"
            points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
          >
            <animate
              attributeName="fill"
              values="#235fa7;#4fd2dd;#235fa7"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#4fd2dd"
            points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;transparent"
              dur="1s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
        </svg>
        <svg class="lb" width="150" height="150">
          <polygon
            fill="#4fd2dd"
            points="6,66 6,18 12,12 18,12 24,6 27,6 30,9 36,9 39,6 84,6 81,9 75,9 73.2,7 40.8,7 37.8,10.2 24,10.2 12,21 12,24 9,27 9,51 7.8,54 7.8,63"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;#4fd2dd"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#235fa7"
            points="27.599999999999998,4.8 38.4,4.8 35.4,7.8 30.599999999999998,7.8"
          >
            <animate
              attributeName="fill"
              values="#235fa7;#4fd2dd;#235fa7"
              dur="0.5s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
          <polygon
            fill="#4fd2dd"
            points="9,54 9,63 7.199999999999999,66 7.199999999999999,75 7.8,78 7.8,110 8.4,110 8.4,66 9.6,66 9.6,54"
          >
            <animate
              attributeName="fill"
              values="#4fd2dd;#235fa7;transparent"
              dur="1s"
              begin="0s"
              repeatCount="indefinite"
            ></animate>
          </polygon>
        </svg>

        <div class="left-container">
          <div class="pie-1"></div>
        </div>
        <div class="right-container">
          <div class="right-top-container">
            <div class="right-top-left-container">
              <div class="pie-2"></div>
            </div>
            <div class="right-top-right-container">
              <div class="right-top-right-top-container"></div>
              <div class="right-top-right-bottom-container"></div>
            </div>
          </div>
          <div class="right-bottom-container"></div>
        </div>
      </div>
    </div>

js

      // 第一个饼图
      let pieChart1 = echarts.init(document.querySelector(".pie-1"));
      let pieChart1Option = {
        color: ["#469f4b", "#00baff", "#3de7c9", "#ffffff", "#ffc530"],
        tooltip: {
          trigger: "item",
        },

        series: [
          {
            type: "pie",
            label: {
              color: "#fff",
              formatter: "{d}%\n{b}",
            },
            tooltip: {
              show: false,
            },
            emphasis: {
              disabled: true,
            },
            radius: ["30%", "40%"],
            data: [
              { value: 1048, name: "其他" },
              { value: 735, name: "收费系统" },
              { value: 580, name: "通信系统" },
              { value: 484, name: "监控系统" },
              { value: 300, name: "供配电系统" },
            ],
          },
        ],
      };
      pieChart1.setOption(pieChart1Option);
      window.onresize = function () {
        pieChart1.resize();
      };

bg图

相信到了这里剩下的图表数据啊排版啥的就不用我多说了吧,直接按部就班开发就好,有收获就点个关注吧

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行

csdn文章推荐受影响解决办法10个字10行