zoukankan      html  css  js  c++  java
  • bizcharts 修改legend样式

    实现如下图,Legend样式,并且能够点击切换chart

    let chartIns = null;
    const getG2Instance = chart => {
      chartIns = chart;
    };
    
    class Count extends React.Component {
        render(){
            return (
                <div>
                    <Chart
                      height={320}
                      padding={[30, 60, 30, 60]}
                      scale={zdscale}
                      data={zdNumDv}
                      onGetG2Instance={getG2Instance}
                      forceFit
                    >
                      <Legend
                        position="top-right"
                        custom={true}
                        allowAllCanceled={true}
                        items={[
                          {
                            value: "次数",
                            marker: {
                              symbol: "square",
                              fill: "#1292FF",
                              radius: 6
                            }
                          },
                          {
                            value: "人数",
                            marker: {
                              symbol: "square",
                              fill: "#FFAF11",
                              radius: 6,
                            }
                          }
                        ]}
                        onClick={ev => {
                          const item = ev.item;
                          const value = item.value;
                          const checked = ev.checked;
                          const geoms = chartIns.getAllGeoms();
                          for (let i = 0; i < geoms.length; i++) {
                            const geom = geoms[i];
                            if (geom.getYScale().field === value) {
                              if (checked) {
                                geom.show();
                              } else {
                                geom.hide();
                              }
                            }
                          }
                        }}
                      />
                      <Axis name="statDatetime" label={label} />
                      {/* <Axis name="liCount" label={label} /> */}
                      <Axis
                        name="armCount"
                        grid={null}
                        label={{
                          textStyle: {
                            fill: "#fdae6b",
                            fontSize: '12',
                          },
                          formatter(val) {
                            return val > 10000 ? val / 10000 + '' : val;
                          },
                        }}
                      />
                      <Tooltip />
                      <Geom type="interval" position="statDatetime*licount" color="l (90) 0:rgba(60, 174, 255, 1) 1:rgba(16, 107, 255, 1)" />
                      <Geom
                        type="line"
                        position="statDatetime*armCount"
                        color="#fdae6b"
                        size={3}
                        shape="smooth"
                      />
                    </Chart>
                </div>
            )
        }
    }

     另外, 需要注意,  如果数据使用的是英文, 而Legend 需要用中文, 点击事件需要做下处理, 如下:

                onClick={ev => {
                          const item = ev.item;
                          const value = item.value;
                          const checked = ev.checked;
                          const geoms = chartIns.getAllGeoms();
                          let valueEn = '';
                          if(value == '次数'){
                            valueEn = 'liCount';
                          }else{
                            valueEn = 'armCount';
                          }
                          for (let i = 0; i < geoms.length; i++) {
                            const geom = geoms[i];
                            if (geom.getYScale().field === valueEn) {
                              if (checked) {
                                geom.show();
                              } else {
                                geom.hide();
                              }
                            }
                          }
                        }}
                      />
  • 相关阅读:
    VMware虚拟机12安装linux系统
    PHP 底层的运行机制与原理
    分享10条PHP性能优化的小技巧,帮助你更好的用PHP开发
    MySQL wamp密码修改
    分布式之抉择分布式锁
    面试总结——Java高级工程师(三)
    面试总结——Java高级工程师(二)
    面试题总结——走向JAVA高级工程师
    浅谈Nginx之反向代理与负载均衡
    修复TortoiseGit文件夹和文件图标不显示
  • 原文地址:https://www.cnblogs.com/rachelch/p/14930205.html
Copyright © 2011-2022 走看看