首页 > web前端 > js教程 > echarts仪表盘设置图文实例

echarts仪表盘设置图文实例

零下一度
发布: 2017-06-26 10:06:59
原创
6345 人浏览过

echarts 图表中经常需要对不同的颜色设置图例标识不同的意义,而仪表盘的指针只存在一个值,如何表示不同颜色的意义,官网配置项并未给出该功能;

不同段的颜色是通过axisLine->lineStyle->color来设置的;

搜索了很多的资料都没有找到用来标识各颜色段的图例;

反复琢磨,可不可以使用有图例的图来强制加上这个图例呢?

这里熟悉echarts的童鞋可能想到解决方法了;

那我们就来使用一招“移花接木”大法;

主要思想:使用柱状图的legend图例,然后设置柱状图和仪表图的层级,然后再隐藏柱状图,禁用legend的点击事件;

注意点:

  1.series中既有type为‘gauge’的配置项,也有type为‘bar’的配置项,而'bar'类型的配置项只要关注其legend的颜色即可;

  2.对于柱状图要隐藏的项较多,必须全部设置成不显示,其中包括轴线和分割线等;

  3.防止奇怪的体验最好将legend的点击事件禁用掉;

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

  var  option = {

                 legend: {     //配置legend,这里的data,要对应type为‘bar’的series数据项的‘name’名称,作为图例的说明 data:['预热期','导入期','成长期','成熟期','衰退期'],

                     selectedMode:false,  //图例禁止点击 top:20,

                     itemWidth:23,

                     itemHeight:6,

                     textStyle: {

                         color: '#707070',

                         fontStyle: 'normal',

                         fontWeight: 'normal',

                         fontFamily: 'sans-serif',

                         fontSize: 11,

                     },

                 },

                 grid: { 

                     z:1,    //grid作为柱状图的坐标系,其层级要和仪表图层级不同,同时隐藏 show:false,

                     left: '-30%',

                     right: '4%',

                     bottom: '3%',

                     containLabel: true,

                     splitLine:{

                         show: false    //隐藏分割线                     },

 

                 },

                 xAxis : [   //这里有很多的show,必须都设置成不显示                     {

                         type : 'category',

                         data : [],

                         axisLine: {

                             show: false },

                         splitLine:{

                             show: false },

                         splitArea: {

                             interval: 'auto',

                             show: false }

                     }

                 ],

                 yAxis : [ //这里有很多的show,必须都设置成不显示                     {

                         type : 'value',

                         axisLine: {

                             show: false },

                         splitLine:{

                             show: false },

                     }

                 ],

                 toolbox: {   

                    show: false,

                 },

                series : [   

                         {

                        name:'刻度盘',

                        type: 'gauge',

                        startAngle: 180,

                        endAngle: 0,"center": ["50%""80%"], //整体的位置设置z: 3,

                        min: min,

                        max: max+min,

                        splitNumber: max,

                        radius: '110%',

                        axisLine: {            // 坐标轴线lineStyle: {       // 属性lineStyle控制线条样式width: 10,

                                color:optionUsedColors

                            }

                        },

                        axisTick: {            // 坐标轴小标记length: 19,        // 属性length控制线长splitNumber: 2,

                            lineStyle: {       // 属性lineStyle控制线条样式color: '#cdcdcd'}

                        },

                        splitLine: {           // 分隔线 length: 20,         // 属性length控制线长 lineStyle: {       // 属性lineStyle(详见lineStyle)控制线条样式 color: 'auto' }

                        },

                        axisLabel: {

                            textStyle: {

                                color:'#454A57'}

                        },

                        pointer: {

                            show: true,

                            length: '70%',

                            width: 5,

                        },

                        itemStyle:{

                            normal:{

                                color:'#454A57',

                                borderWidth:0}

                        },

                        title: {   //仪表盘标题show: true,

                            offsetCenter: ['0''20'],

                            textStyle: {

                                color: '#444A56',

                                fontSize: 12,

                                fontFamily: 'Microsoft YaHei'}

                        },

                        detail: {

                            textStyle: {

                                fontSize: 12,

                                color: '#707070'},

                            offsetCenter: offsetConfig,

                            formatter: function(){return '上市时间\n'+time;

                            }

                        },

                        data:[{value: (status/100*max || 0), name: '当前阶段'}]                    },

                         {

                        name: '灰色内圈',

                        type: 'gauge',

                        z:2,

                        radius: '110%',

                        startAngle: 180,

                        endAngle: 0,"center": ["50%""80%"], //整体的位置设置splitNumber: 4,

                        axisLine: { // 坐标轴线lineStyle: { // 属性lineStyle控制线条样式                                color: [

                                    [1, '#F2F4F8']

                                ],

                                width: 24,

                                opacity: 1,

                            }

 

                        },

                        splitLine: { //分隔线样式show: false,

                        },

                        axisLabel: { //刻度标签show: false,

                        },

                        axisTick: { //刻度样式show: false,

                        },

                        detail : {

                            show:false,

                            textStyle: {       // 其余属性默认使用全局文本样式,详见TEXTSTYLEfontWeight: 'bolder',

                                fontSize:12}

                        },

                    },

                         {

                             name:'预热期',

                             type:'bar',

                             barWidth: '60%',  //不显示,可以随便设置 data:[0],

                             itemStyle: {

                                 normal: {

                                     color: '#41C468',  //这里的图例要注意,颜色设置和仪表盘的颜色对应起来                                 }

                             }

                         },

                         {

                             name:'导入期',

                             type:'bar',

                             barWidth: '60%',

                             data:[0],

                             itemStyle: {

                                 normal: {

                                     color: '#70C1B3',

                                 }

                             }

                         },

                         {

                            name:'成长期',

                            type:'bar',

                            barWidth: '60%',

                            data:[0],

                            itemStyle: {

                                normal: {

                                    color: '#00A1E9',

                                }

                            }

                        },

                         {

                             name:'成熟期',

                             type:'bar',

                             barWidth: '60%',

                             data:[0],

                             itemStyle: {

                                 normal: {

                                     color: '#EE4444',

                                 }

                             }

                         },

                         {

                             name:'衰退期',

                             type:'bar',

                             barWidth: '60%',

                             data:[0],

                             itemStyle: {

                                 normal: {

                                     color: '#DCF2C4',

                                 }

                             }

                         }

                ]

            }

登录后复制

最终的效果图如下,是不是很简单呢。

 

以上是echarts仪表盘设置图文实例的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
javascript - react中如何使用echarts-gl???
来自于 1970-01-01 08:00:00
0
0
0
javascript - 一个echarts+bootstrap模态框的小坑。
来自于 1970-01-01 08:00:00
0
0
0
javascript - 百度echarts图表如何修改
来自于 1970-01-01 08:00:00
0
0
0
javascript - echarts柱状图渐变色的问题
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板