Bootstrap

Echarts的研究(二)

在移动端想要做一个温度计功能的需求,且需要有个当前值指到相应的位置。在手机端还要能达到每个屏幕的适配,需要考虑的细节挺多的。项目是采用的vue框架,百度了网上一些jQuery插件,但是都达不到想要的效果,最后还是采用了使用echarts中的柱状图改编 ,毕竟echarts已经做好了适配,这块不用在考虑。

那采用vue框架,当然就是组件化开发喽。

初始化echarts实例方法:

 initTemper:function () {
                let that = this;
                this.temperChart = echarts.init(document.getElementById(this.temperSet.id));
                // 指定图表的配置项和数据
                var  value=that.currentTemp;//代表当前值
                console.log(value);
                var  offset=40;//代表温度计最小刻度,模拟往下移动多少
                this.option  =  {
                    grid:  {
                        left:0,
                        right: '40%',
                        bottom:'60',
                        top:'10%',
                        containLabel:  true
                    },
                    xAxis:  {
                        show:false,
                        type  :  'category',
                        splitLine:  {show:false},
                        data  :    1
                    },
                    yAxis:  [
                        {
                            max:130,
                            min:0,
                            axisLabel:{
                                formatter:  function  (value,  index)  {
                                    return  value-offset;
                                }
                            },
                            axisLine:{
                                lineStyle:{
                                    color:'#0bc36c',//Y轴颜色
                                    width:2
                                }
                            },
                            splitLine:  {show:false},
                            type  :  'value',
                            minInterval:  1,
                            interval:15
                        },
                        {
                            max:130,
                            min:0,
                            axisLabel:{
                                formatter:  function  (value,  index)  {
                                    return  value-offset;
                                }
                            },
                            axisLine:{
                                lineStyle:{
                                    color:'#0bc36c',//Y轴颜色
                                    width:2
                                }
                            },
                            splitLine:  {show:false},
                            type  :  'value',
                            minInterval:  1,
                            interval:15
                        }
                    ],
                    series:  [
                        {
                            data:  [offset+(value)],
                            label:{
                                normal:{
                                    show:true,
                                    formatter:  function  (v){
                                        return  v.value-offset;
                                    },
                                    textStyle:{color:'#fff',fontSize:'24'},
                                    position:'inside',
                                    offset:[17,-4]
                                }
                            },
                            symbol:'image://asserts/img/temperature/tipsRight.png',
                            //symbol:'path://<path  d="M  100  100  L  300  100  L  200  300  z"/>',
                            //symbol:'path://M275,175  v-150  a150,150  0  0,0  -150,150  z',
//                            symbol:'path://M275,175  v-150  a150,150  0  0,0  -150,150  z"',
                            symbolSize:[80,46],
                            symbolOffset:[55,2],
                            type:  'scatter'
                        },
                        {
                            type:  'bar',
                            barWidth:'70%',
                            label:  {
                                normal:  {
                                    show:  true,
                                    position:  'bottom',
                                    formatter:  function  (v){
                                        return  v.value-offset;
                                    }
                                }
                            },
                            itemStyle: {//柱状图颜色
                                normal: {
//                                    barBorderColor: '#0bc36c',
                                    color: '#0bc36c'
                                }
                            },
                            data:  [offset+(value)]
                        },
                        {
                            type:  'custom',
                            renderItem:  function  renderItem(params,  api)  {
                                console.group(3);
                                console.log(api.value(0));
                                var  ddd  =  api.coord([0,0]);
                                console.log(ddd);
                                console.groupEnd();
                                var  style  =  api.style({
                                    stroke: api.visual('color'),
                                    image: "
;