# chart开发指导 chart为图表组件,用于呈现线形图、柱状图和量规图界面。具体用法请参考[chart](../reference/arkui-js/js-components-basic-chart.md)。 ## 创建chart组件 在pages/index目录下的hml文件中创建一个chart组件。 ```html
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } .chart-data { width: 700px; height: 600px; } ``` ```js // xxx.js export default { data: { lineData: [ { data: [763, 550, 551, 554, 731, 654, 525, 696, 595, 628, 791, 505, 613, 575, 475, 553, 491, 680, 657, 716] } ], lineOps: { xAxis: { min: 0, max: 20, display: false, }, yAxis: { min: 0, max: 1000, display: false, }, series: { lineStyle: { width: 15, }, } }, } } ``` ![zh-cn_image_0000001181974568](figures/zh-cn_image_0000001181974568.png) ## 设置图表类型 chart组件通过设置type属性定义图表t类型,如将图表设置为柱状图。 ```html
{{ title }}
线形图 柱状图 量规图
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; justify-content: center; background-color: #F1F3F5; } .tab-bar{ background-color: #F1F3F5; } .chart-data { width: 700px; height: 600px; } .title{ margin-left: 50px; margin-top: 50px; font-size: 50px; } .line-block{ align-items: center; justify-content: center; } .bar-block{ align-items: center; justify-content: center; } .chart-block{ width: 90%; margin-left: 30px; } ``` ```js // xxx.js export default { data: { title: "类型展示", barData: [ { fillColor: '#3848e8', data: [763, 550, 551, 554, 731, 654, 525, 696, 595], } ], lineData: [ { strokeColor: '#0081ff', fillColor: '#cce5ff', data: [763, 550, 551, 554, 731, 654, 525, 696, 595, 628, 791, 505, 613, 575, 475, 553, 491, 680, 657, 716], gradient: true, } ], lineOps: { xAxis: { min: 0, max: 20, display: false, }, yAxis: { min: 0, max: 1000, display: false, }, series:{ lineStyle: { width: "5px", smooth: true, }, headPoint: { shape:"circle", size: 20, strokeWidth: 5, fillColor: '#ffffff', strokeColor: '#007aff', display: true, }, loop:{ margin: 2, gradient: true } }, }, barOps: { xAxis: { min: 0, max: 20, display: false, axisTick: 10, }, yAxis: { min: 0, max: 1000, }, }, }, } ``` ![zh-cn_image_0000001227423251](figures/zh-cn_image_0000001227423251.gif) > **说明:** > chart不支持显示每个点的值。 ## 设置图表属性 chart组件在options属性中设置对x轴、y轴和数据序列参数的设置,在datasets属性里添加对线条颜色、填充颜色、填充渐变颜色和绘制点集的设置。 ```html
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } .chart-data { width: 700px; height: 600px; } ``` ```js // xxx.js export default { data: { //线形图数据 lineData: [ { strokeColor: '#0081ff', fillColor: '#cce5ff', //填充色 data: [463, 250, 251, 254, 431, 354, 225, 396, 295, 328, 491, 205, 313, 275, 475, 553, 491, 380, 357, 416], gradient: true, } ], lineOps: { //x轴参数设置 xAxis: { min: 0, max: 20, display: false, }, //y轴参数设置 yAxis: { min: 0, max: 1000, display: false, }, //数据序列参数设置 series: { //线样式设置 lineStyle: { width: "5px", smooth: true, }, //线最前端位置白点的样式和大小 headPoint: { shape: "circle", size: 20, strokeWidth: 5, fillColor: '#ffffff', strokeColor: '#007aff', display: true, }, //设置屏幕显示满时,是否需要重头开始绘制 loop: { margin: 2, gradient: true } } }, }, } ``` > **说明:** > - options只支持柱状图和线形图设置参数,量规图不生效。 > > - datasets只支持柱状图和线形图设置数据集合,量规图不生效。 > > - series只有线形图支持。 ## 添加数据 通过chart组件的append方法,实现动态添加数据。 ```html
``` ```css /* xxx.css */ .container { flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } .chart-region { height: 400px; width: 700px; } .chart-data { width: 700px; height: 600px; } button { width: 100%; height: 50px; background-color: #F4F2F1; text-color: #0C81F3; margin-top: 30px; } ``` ```js // xxx.js export default { data: { lineData: [ { strokeColor: '#de0b6e', fillColor: '#bb09a3', data: [763, 550, 551, 554, 731, 654, 525, 696, 595, 628, 791, 505, 613, 575, 475, 553, 491, 680, 657, 716], gradient: true, } ], lineOps: { xAxis: { min: 0, max: 20, display: false, }, yAxis: { min: 0, max: 1000, display: false, }, series: { lineStyle: { width: "5px", smooth: true, }, headPoint: { shape: "circle", size: 20, strokeWidth: 5, fillColor: '#ffffff', strokeColor: '#f8145c', display: true, }, loop: { margin: 2, gradient: true, } } }, }, addData() { this.$refs.linechart.append({ serial: 0, data: [Math.floor(Math.random() * 400) + 200] }) } } ``` ![zh-cn_image_0000001221913395](figures/zh-cn_image_0000001221913395.gif) ## 场景示例 开发者可以根据开关Switch的状态来选择数据展示的状态,当Switch状态为true时,通过定时器来实现数据的动态展示。 ```html
{{ title }}
{{ $item.data }} {{ $item.value }}
``` ```css /* xxx.css */ .container{ display:flex; flex-direction:column; background-color: #F1F3F5; } .line-class{ display: flex; flex-direction: column; } .title{ font-size: 40px; margin-left: 40px; } .switch-block { margin-top: 30px; width: 98%; height: 80px; display: flex; justify-content: space-between; } .switch{ font-size: 40px; } .bar-block { margin-top: 80px; margin-left: 40px; position: relative; width: 90%; border-radius: 10px; background-color: #25FAB27B; height: 40%; justify-content: center; } ``` ```js // xxx.js export default { data: { interval: null, title: "数据展示", allowScale: true, dataLength: 30, barGroup: 3, lineData: null, lineOps: { xAxis: { min: 0, max: 5 }, yAxis: { min: 0, max: 100 }, series: { lineStyle: { width: '1px', }, headPoint: { shape: 'circle', size: 10, strokeWidth: 2, fillColor: '#ffffff', strokeColor: '#8477DF' }, loop: { margin: 2 } } }, barData: [ { fillColor: '#97CF0A2C', data: [20, 20,40, 56] }, { fillColor: '#6D0A7ACF', data: [52, 40, 2, 67] }, { fillColor: '#6A0ACFA1', data: [56, 2, 77, 40] } ], barOps: { xAxis: { min: 0, max: 20, axisTick: 5 }, yAxis: { min: 0, max: 100 } } }, onInit() { this.changeLine(); }, change(e) { if (e.checked) { this.interval = setInterval(() => { this.changeLine(); this.changeBar(); }, 1000) } else { clearInterval(this.interval); } }, changeLine() { var dataArray = []; for (var i = 0; i < this.dataLength; i++) { var nowValue = Math.floor(Math.random() * 99 + 1); var obj = { "value": nowValue, "description": nowValue + "", "textLocation": "top", "textColor": "#CDCACA", "pointStyle": { "shape": "circle", "size": 5, "fillColor": "#CF0A2C", "strokeColor": "#CF0A2C" } }; dataArray.push(obj); } this.lineData = [ { strokeColor: '#0081ff', fillColor: '#FF07CDC4', data: dataArray, gradient: true, } ] }, changeBar() { for (var i = 0;i < this.barGroup; i++) { var dataArray = this.barData[i].data; for (var j = 0;j < 4; j++) { dataArray[j] = Math.floor(Math.random() * 99 + 1); } } this.barData = this.barData.splice(0, this.barGroup + 1); }, changes(e) { console.log("Tab index: " + e.index); }, } ``` ![zh-cn_image_0000001179018876](figures/zh-cn_image_0000001179018876.gif)