欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3+echarts實(shí)現(xiàn)漸變色環(huán)形圖過(guò)程

 更新時(shí)間:2024年08月28日 14:24:54   作者:不吃辣椒不行  
這篇文章主要介紹了vue3+echarts實(shí)現(xiàn)漸變色環(huán)形圖過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue3 echarts實(shí)現(xiàn)漸變色環(huán)形圖

實(shí)現(xiàn)的效果大致是這樣

由于是公司的項(xiàng)目,指引線后標(biāo)注的內(nèi)容不展示了,大致是指引線上方是name,下邊是value+單位

1.定義圖表容器

<div class="chart" ref="chartRef" style="width: 610px; height: 260px;"></div>

2.我這邊所需要的數(shù)據(jù)形式大概是

const data = {
    equmentStatusEchart: [
    {name: '標(biāo)題1', value: 10}
    {name: '標(biāo)題2', value: 10}
    ]
}

通過(guò)接口拿到的數(shù)據(jù)類型一般是:[{} ,{}]這種類型的,寫(xiě)一個(gè)方法將其轉(zhuǎn)變?yōu)槲宜枰男问?/p>

const convertArrayToObject = (array) => {
  const convertedObject = {
    equmentStatusEchart: array.map(item => ({
      name: item.name,
      value: item.value
    }))
  };
  return convertedObject;
};

具體的代碼如下:

將接口轉(zhuǎn)換成自己的就好了,我這個(gè)是隨機(jī)生成的顏色漸變,如果有需求可以固定一個(gè)顏色數(shù)組

import * as echarts from 'echarts';
import { ref, onMounted, nextTick } from 'vue';
import { getPersonnel } from '@/api'
const chartRef = ref(null)
//重點(diǎn)人員
const rangArr = ref([]);
const distribution = ref([])
const distributionList = ref([])
const deflag = ref(1)
const angleArr = ref({})
const data = ref([])
//轉(zhuǎn)換成所需對(duì)象數(shù)組
const convertArrayToObject = (array) => {
  const convertedObject = {
    equmentStatusEchart: array.map(item => ({
      name: item.communityName,
      value: item.countSum,
      communityId: item.communityId
    }))
  };
  return convertedObject;
};
function getCoordinates(startArc, endArc) {
    const posi = [
      Math.sin(startArc),
      -Math.cos(startArc),
      Math.sin(endArc),
      -Math.cos(endArc)
    ];
    const dx = posi[2] - posi[0];
    const dy = posi[3] - posi[1];

    return getLocation(dx, dy);
  }

  function getLocation(dx, dy) {
    const tanV = dx / dy;
    const directSign = Math.abs(tanV) < 1;
    const t = directSign ? tanV : 1 / tanV;

    const sign1 = t > 0 ? 1 : -1;
    const sign2 = dx > 0 ? 1 : -1;
    const sign = directSign ? sign1 * sign2 : sign2;

    const group1 = [0.5 - sign * t / 2, 0.5 + sign * t / 2];
    const group2 = sign > 0 ? [0, 1] : [1, 0];
    const group = [...group1, ...group2];
    const keys = directSign ? ['x', 'x2', 'y', 'y2'] : ['y', 'y2', 'x', 'x2'];

    let res = {};
    keys.forEach((k, idx) => {
      res[k] = group[idx];
    });
    return res;
  }
const getPersonnelList = async() => {
  distribution.value = await getPersonnel(deflag.value)
  distributionList.value = distribution.value.data
  const obj = convertArrayToObject(distributionList.value)
  console.log(obj)
  const totalValue = ref(obj.equmentStatusEchart.reduce((total, value) => total + value.value, 0));
  let cacheNum = 0;
  for (let i = 0; i < obj.equmentStatusEchart.length; i++) {
    const endNum = cacheNum + obj.equmentStatusEchart[i].value;
    rangArr.value.push([cacheNum, endNum]);
    cacheNum = endNum;
  }
  const angleArr = ref(rangArr.value.map(arr => arr.map(num => (num / totalValue.value) * Math.PI * 2)));
  data.value = obj.equmentStatusEchart.map((item, index) => {
    const range = getCoordinates(angleArr.value[index][0], angleArr.value[index][1]);
    const startColor = `rgb(${Math.floor(Math.random() * 256)}, ${Math.floor(Math.random() * 256)}, ${Math.floor(Math.random() * 256)})`;
    const color = {
      type: 'linear',
      x: range.x,
      x2: range.x2,
      y: range.y,
      y2: range.y2,
      colorStops: [{
        offset: 0, color: startColor // 起始顏色
      }, {
        offset: 1, color: `${startColor.substring(0, startColor.length - 1)}, 0)` // 終點(diǎn)顏色
      }],
      global: false
    };

    return {
      name: item.name,
      value: item.value,
      itemStyle: {
        color: color
      }
    };
  })
}
 
  const getChart = async() => {
    await getPersonnelList()
    const option = {
      tooltip: {
        trigger: 'item',
        backgroundColor: 'rgba(0, 0 , 0, .6)',
        borderColor: "rgba(147, 235, 248, .8)",
        textStyle: {
          color: "#fff"
        },
      },
      series: [
        {
          type: 'pie',
          radius: ['65%', '75%'],
          center: ['50%', '50%'],
          avoidLabelOverlap: false,
          itemStyle: {
          },
          label: {
            show: true,
            position: 'outer',
            align: 'left',
            height: 50,
            lineHeight: 10,
            formatter: function(params) {
            return (
              '{a|' + params.data.name + '}\n' +
              '{b|' + params.data.value  + ' } ' +
              '{value| 人}'
            );
            },
            borderWidth: 10,
            padding: [0, -60],
            rich: {
            a: {
              fontSize: 14,
              color: '#fff',
              fontWeight: 400,
              lineHeight: 35
            },
            b: {
              color: '#fff', 
              fontSize: 18,
              fontWeight: 600,
              lineHeight: 10
            },
            value: {
              color: '#fff',
              fontSize: 14,
              fontWeight: 400,
            }
          }
          },
        labelLine: {
          show: true,
          length: 20,
          length2: 160,
          smooth: 0,
          lineStyle: {
            color: 'white'
          }
        },
          emphasis: {
            itemStyle:{
              shadowBlur: 10,
              shadowOffsetX: 0,
              shadowColor: 'rgba(0, 0, 0, 0.2)'
            }
          },
          data: data.value
        },

      ],
    };
    nextTick(() => {
      const chartDom = chartRef.value;
      const myChart = echarts.init(chartDom);
      myChart.setOption(option)
    })
  }


onMounted(() => {
  getChart()
  
})

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue3清空reactive的四種方式

    vue3清空reactive的四種方式

    本文主要介紹了vue3清空reactive的四種方式,包含使用?Object.assign,使用?Object.keys?和?for...in?循環(huán),使用?delete?操作符和重新賦值4種,感興趣的可以了解一下
    2024-03-03
  • 詳解Vue 全局變量,局部變量

    詳解Vue 全局變量,局部變量

    這篇文章主要介紹了Vue全局變量局部變量,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue實(shí)現(xiàn)自定義全局右鍵菜單

    vue實(shí)現(xiàn)自定義全局右鍵菜單

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)自定義全局右鍵菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue前后分離調(diào)起微信支付

    vue前后分離調(diào)起微信支付

    這篇文章主要為大家詳細(xì)介紹了vue前后分離調(diào)起微信支付,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • vue中Form 表單的 resetFields() 失效原因及問(wèn)題解決

    vue中Form 表單的 resetFields() 失效原因及問(wèn)題解決

    在Vue項(xiàng)目中,使用formRef.value.resetFields()方法重置表單時(shí)可能遇到不起作用的問(wèn)題,下面就來(lái)介紹一下如何解決,感興趣的可以了解一下
    2024-09-09
  • vue實(shí)現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例

    vue實(shí)現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例

    這篇文章主要介紹了vue實(shí)現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-11-11
  • element-ui點(diǎn)擊查看大圖的方法示例

    element-ui點(diǎn)擊查看大圖的方法示例

    這篇文章主要介紹了element-ui查看大圖的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 優(yōu)雅的處理vue項(xiàng)目異常實(shí)戰(zhàn)記錄

    優(yōu)雅的處理vue項(xiàng)目異常實(shí)戰(zhàn)記錄

    這篇文章主要給大家介紹了關(guān)于如何優(yōu)雅的處理vue項(xiàng)目異常的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 講解vue-router之什么是嵌套路由

    講解vue-router之什么是嵌套路由

    這篇文章主要介紹了講解vue-router之什么是嵌套路由,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • 詳解VUE前端按鈕權(quán)限控制

    詳解VUE前端按鈕權(quán)限控制

    這篇文章主要介紹了VUE前端按鈕權(quán)限控制,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論