环境搭建参考:
大屏开源项目go-view二次开发1----环境搭建(C#)-CSDN博客
要做的半环形控件最终效果如下图:
data:image/s3,"s3://crabby-images/b46c7/b46c7c3ef70b98f606bdca7aa16038dc8d619918" alt=""
步骤如下:
1 在go-view前端项目的\src\packages\components\Charts目录下新增Others目录,并在Others目录下新增PieExt2目录,并把src\packages\components\Charts\Pies\PieCommon目录下的5个文件拷贝到新增PieExt2目录下(因为要做的半环形控件和PieCommon长得最像,拷贝它的过来修改是改动量最小的),接着在Others目录下新增index.ts文件,(由于我已经新增了好几个自定义控件,所以你还会看到BarExt1、PictorialBar、PieExt1目录),最终的目录结构如下图:
data:image/s3,"s3://crabby-images/991a8/991a84a8ddb58ed1fa74f22a576ea08f1dadc57a" alt=""
2 接着在src\packages\components\Charts目录下的index.d.ts文件和index.ts文件分别添加内容如下:
data:image/s3,"s3://crabby-images/04820/04820a3090f5b6d437d3e3ed284173ed95a789ea" alt=""
data:image/s3,"s3://crabby-images/f5138/f5138eca4c3912cb5d1be147acb7ce491ed18f51" alt=""
3 编辑PieExt2目录下的config.ts的文件如下:
javascript
import { echartOptionProfixHandle, PublicConfigClass } from '@/packages/public'
import { PieExt2 } from './index'
import { CreateComponentType } from '@/packages/index.d'
import cloneDeep from 'lodash/cloneDeep'
import dataJson from './data.json'
import { fontFamily } from 'html2canvas/dist/types/css/property-descriptors/font-family'
import { height } from 'dom-helpers'
export const includes = ['legend']
// 其它配置
const otherConfig = {
// 轮播动画
isCarousel: false,
}
export const seriesItem={
name: 'Access From',
type: 'pie',
radius: ['40%', '70%'],
center: ['50%', '70%'],
// adjust the start and end angle
startAngle: 180,
endAngle: 360,
label: {
formatter: '{b}: {d}',
fontSize: 20, // 设置字体大小
fontWeight: 'normal',
textBorderColor: '#ffffff',
color:'#ffffff',
textBorderWidth: 0
},
labelLine: {
normal: {
length: 40, // 调整引出线的长度
lineStyle: {
width: 3 // 设置引出线的宽度
}
}
}
}
const option = {
tooltip: {
trigger: 'item',
formatter: '{b}:{d}'
},
legend: {
selectedMode: false
},
dataset: { ...dataJson },
series: [
seriesItem
]
}
export default class Config extends PublicConfigClass implements CreateComponentType {
public key: string = PieExt2.key
public chartConfig = cloneDeep(PieExt2)
// 图表配置项
public option = echartOptionProfixHandle(option, includes)
}
4 编辑PieExt2目录下的config.vue的文件如下:
javascript
<template>
<!-- Echarts 全局设置 -->
<global-setting :optionData="optionData"></global-setting>
<CollapseItem name="扩展2饼图配置" :expanded="true">
<SettingItemBox name="字体">
<setting-item name="格式化">
<n-input v-model:value="optionData.series[0].label.formatter" size="small"></n-input>
</setting-item>
<setting-item name="大小">
<n-input-number
v-model:value="optionData.series[0].label.fontSize"
size="small"
:min="1"
></n-input-number>
</setting-item>
</SettingItemBox>
<SettingItemBox name="引出线条">
<setting-item name="长度">
<n-input v-model:value="optionData.series[0].labelLine.normal.length" size="small"></n-input>
</setting-item>
<setting-item name="宽度">
<n-input-number
v-model:value="optionData.series[0].labelLine.normal.lineStyle.width"
size="small"
:min="1"
></n-input-number>
</setting-item>
</SettingItemBox>
</CollapseItem>
</template>
<script setup lang="ts">
import { PropType, watch } from 'vue'
import { GlobalThemeJsonType } from '@/settings/chartThemes/index'
import { GlobalSetting, CollapseItem, SettingItemBox, SettingItem } from '@/components/Pages/ChartItemSetting'
const props = defineProps({
optionData: {
type: Object as PropType<GlobalThemeJsonType>,
required: true
}
})
</script>
5 编辑PieExt2目录下的data.json的文件如下:
javascript
{
"dimensions": ["product", "data1"],
"source": [
{
"product": "Mon",
"data1": 120
},
{
"product": "Tue",
"data1": 200
},
{
"product": "Wed",
"data1": 150
},
{
"product": "Thu",
"data1": 80
},
{
"product": "Fri",
"data1": 70
},
{
"product": "Sat",
"data1": 110
},
{
"product": "Sun",
"data1": 130
}
]
}
6 编辑PieExt2目录下的index.ts的文件如下:
javascript
import { ConfigType, PackagesCategoryEnum, ChartFrameEnum } from '@/packages/index.d'
import { ChatCategoryEnum, ChatCategoryEnumName } from '../../index.d'
export const PieExt2: ConfigType = {
key: 'PieExt2',
chartKey: 'VPieExt2',
conKey: 'VCPieExt2',
title: '饼图扩展2',
category: ChatCategoryEnum.OTHERCHART,
categoryName: ChatCategoryEnumName.OTHERCHART,
package: PackagesCategoryEnum.CHARTS,
chartFrame: ChartFrameEnum.ECHARTS,
image: 'PieExt2.png'
}
注意:
key: 'PieExt2',
chartKey: 'VPieExt2',
conKey: 'VCPieExt2',
这三个玩意有特定的命名规则,key要与前面新增的目录名PieExt2保持一致,chartKey要在PieExt2前面加V变成VPieExt2,conKey要在PieExt2前面加上VC变成VCPieExt2
接着把这个图
data:image/s3,"s3://crabby-images/554d6/554d6ac03ed5b5ae8799e0d4bd0bbfab52499120" alt=""
下载后,修改名称为PieExt2.png,并放到src\assets\images\chart\charts目录下:
data:image/s3,"s3://crabby-images/2b29e/2b29e7e5f7d52677c858408d196581e75beab0a8" alt=""
7 编辑PieExt2目录下的index.vue的文件如下:
javascript
<template>
<v-chart
ref="vChartRef"
:init-options="initOptions"
:theme="themeColor"
:option="option"
:update-options="{
replaceMerge: replaceMergeArr
}"
autoresize
></v-chart>
</template>
<script setup lang="ts">
import { ref, nextTick, computed, watch, PropType } from 'vue'
import VChart from 'vue-echarts'
import { useCanvasInitOptions } from '@/hooks/useCanvasInitOptions.hook'
import { use } from 'echarts/core'
import { CanvasRenderer } from 'echarts/renderers'
import { PieChart } from 'echarts/charts'
import { mergeTheme } from '@/packages/public/chart'
import config, { includes, seriesItem } from './config'
import { useChartDataFetch } from '@/hooks'
import { useChartEditStore } from '@/store/modules/chartEditStore/chartEditStore'
import { DatasetComponent, GridComponent, TooltipComponent, LegendComponent } from 'echarts/components'
import isObject from 'lodash/isObject'
import cloneDeep from 'lodash/cloneDeep'
const props = defineProps({
themeSetting: {
type: Object,
required: true
},
themeColor: {
type: Object,
required: true
},
chartConfig: {
type: Object as PropType<config>,
required: true
}
})
const initOptions = useCanvasInitOptions(props.chartConfig.option, props.themeSetting)
use([DatasetComponent, CanvasRenderer, PieChart, GridComponent, TooltipComponent, LegendComponent])
const replaceMergeArr = ref<string[]>()
const option = computed(() => {
return mergeTheme(props.chartConfig.option, props.themeSetting, includes)
})
// dataset 无法变更条数的补丁
watch(
() => props.chartConfig.option.dataset,
(newData: { dimensions: any }, oldData) => {
try {
if (!isObject(newData) || !('dimensions' in newData)) return
if (Array.isArray(newData?.dimensions)) {
const seriesArr = []
for (let i = 0; i < newData.dimensions.length - 1; i++) {
seriesArr.push(cloneDeep(seriesItem))
}
replaceMergeArr.value = ['series']
props.chartConfig.option.series = seriesArr
nextTick(() => {
replaceMergeArr.value = []
})
}
} catch (error) {
console.log(error)
}
},
{
deep: false
}
)
const { vChartRef } = useChartDataFetch(props.chartConfig, useChartEditStore, (newData: any) => {
props.chartConfig.option.dataset = newData
})
</script>
8 编辑\src\packages\components\Charts目录下的index.ts文件如下:
data:image/s3,"s3://crabby-images/2b35e/2b35ec9401c26149e50cb554cb07bf32f5f0ca19" alt=""
9 先运行C#后端程序(参考文章最前面给的链接),接着利用npm run dev运行go-view程序,最终效果如下:
data:image/s3,"s3://crabby-images/9c61a/9c61a8bbd216224825634bcd4742175d3a0f4a70" alt=""
完整代码可以如下链接获取:
下面讲解一下PieExt2目录下这5个文件config.ts、config.vue、data.json、index.ts、index.vue的功能:
config.ts文件
option和series是比较重要的,决定了控件的外观,如下图:
data:image/s3,"s3://crabby-images/2cb1e/2cb1edbeb020e80c88036f26da1aadf4e9cddd60" alt=""
上面的option我是从这里抄来的,我对vue也是半吊子:
data:image/s3,"s3://crabby-images/fe0b0/fe0b00557819ce19c80ca0007a9115676f760696" alt=""
这里的资源Examples - Apache ECharts确实是多,option几乎都不用自己写,拿过来改改就能用了
data:image/s3,"s3://crabby-images/370dd/370dd953c0edfcb35b9afb3a08781c190bf2fa24" alt=""
拿过来后,要把带data部分删除:
data:image/s3,"s3://crabby-images/aef1b/aef1bde15090a477fe239ade4065227174ceb642" alt=""
换成 dataset: { ...dataJson },
data:image/s3,"s3://crabby-images/2cba7/2cba7a5d6adfbc10fcb696b66e56ca2763ebd95d" alt=""
然后根据需要修改series的内容
config.vue
要与config.ts结合来看,主要是能让控件在被拖拽出来后,能给人修改控件样式,如下图:
data:image/s3,"s3://crabby-images/91a2a/91a2a1545bbc9baacb9bdf214dd58b6d0a3b90ee" alt=""
配置关系如下图:
data:image/s3,"s3://crabby-images/e9f60/e9f607b2577c491720f82ba0dc2323d49f449b25" alt=""
data.json
配置控件的最初数据,后面可以通过界面上传json文件导入覆盖或者通过后端接口api动态获取覆盖:
data:image/s3,"s3://crabby-images/29de3/29de356944e8ac520c861a696452758f40d68e00" alt=""
index.ts
配置控件的名称,框架加载控件的路径,控件样式图片等配置
data:image/s3,"s3://crabby-images/4e95f/4e95ff19d5bb2676519cf04a3e320c4570260eb4" alt=""
data:image/s3,"s3://crabby-images/bd5f8/bd5f87702470f4b201030a7f36def235dd22d54d" alt=""
index.vue
控件样式布局及javascript逻辑控制:
data:image/s3,"s3://crabby-images/9417e/9417ecd1ba7f228c836e46aa68d3c190b4858e9f" alt=""
data:image/s3,"s3://crabby-images/8f51b/8f51b2b7db9f960b06cd8fcdb54704eb0ab8bb5b" alt=""
这个watch函数是获取到接口数据或者导入json文件后,会自动执行该函数,我这里就没有动它(但在做堆叠柱状图的时候就修改了它),你看一下go-view自带的控件,index.vue的内容几乎一样,主要的功能是根据数据更新series的值,从而达到控制控件的目的
好了,本文到此结束,如果本文对你有帮助,资助2毛钱作为鼓励呗,穷逼一个,就当筹个网费吧
data:image/s3,"s3://crabby-images/ccf6d/ccf6df0683af25020ca1c07eb1c96ebe3d88059c" alt=""