栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

[Android] AAChart组件使用(合并数据、不同颜色柱状图、属性配置)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

[Android] AAChart组件使用(合并数据、不同颜色柱状图、属性配置)

最近公司举办减肥比赛.
答应了帮HRBP的做一个积分计算器.
最终涉及到了排名,就需要一个数据展示.
评估了时间,决定采用图表的形式进行数据展示,
时间关系不准备自定义View自己画表格了,直接用现成的.

这图表处理还是花了一点时间,做一下记录,不管是帮助他人还是以后自己回顾都行

诉求
  1. 能够支持 柱状图数据展示
  2. 能够支持 基于不同条件下 不同颜色进行展示
  3. 拓展性足够高,能够进行足够的自定义
  4. 足够稳定,不会有太多BUG等待修复.
  5. 支持Java 或 Kotlin

最终 选择AAChart组件, 我个人使用的是 Kotlin版本.


具体使用

按照demo说明,
啪的一下,很快啊~
把效果弄出来了

不过这效果,emmmm…

这红框标注的地方,都是啥?

  • 手指头移动到哪里,都有一个tips,不需要
  • X轴这显示刻度 多少K多少K,还带省略号,不需要+1
  • X轴Values是啥? 不需要+2
  • Series 1 又是啥? 不需要+3
  • 柱状图怎么这么密,我希望能够大一些,而且能够滑动,现在不行

且容我这个靓仔康康Wiki里面的使用说明,
结果发现并没有详细描述,只能翻代码

 

以上是AAChartModel的配置字段注释说明.
我自己按照注释进行了设置.
最终效果

现在就很清爽了.
没有不必要的说明,没有手指滑动的TIPS,也可以进行上下滑动.
NICE.
这是我抽取的函数,可以参考一下,注释都写上了.

    fun setChartParams(
        title: String,
        categories: MutableList,
        data: Array,
        height: Int = 3200
    ): AAChartModel {
        return AAChartModel()
            .chartType(AAChartType.Bar)
            .title(title)
            .categories(categories.toTypedArray())
            .backgroundColor("#ffffff")
            .series(data)
            //要不要在柱状图上面显示一个数字
            .dataLabelsEnabled(true)
            //去掉横向的轴的轴体表示
            .yAxisLabelsEnabled(false)
            //去掉横向的哪个 Values 显示
            .yAxisVisible(false)
            //不需要每点一个数据,展示一个小tip
            .tooltipEnabled(false)
            //不要垂直的一条一条的线
            .yAxisGridLineWidth(0f)
            //不需要颜色说明的哪个东西,也就是那个Series1
            .legendEnabled(false)
            .scrollablePlotArea(
                AAScrollablePlotArea()
                    //图表的高度,设置的比屏幕高,就可以滑动
                    .minHeight(height)
                    //起始,是在最顶部(0f)还是最底部(1f)
                    .scrollPositionY(0f)
            )
    }
更进一步 - 柱状图不同颜色显示

现在只差最后一步.
我希望柱状图的颜色,能够基于状态,能够有不同颜色的显示.
Wiki里面示例图有这个效果.
翻遍了代码说明,翻遍了demo就是没找到.
最后我成功的在 其他语言的组件的ISSUES里面找到了一份 Object-C的代码说明
太不容易了!!!
贴上实现这种效果的关键代码

private var step = mutableListOf()
//使用AADataElement对象
step.add(AADataElement().color("#FFDF00").y(it.step.toFloat()))

使用AADataElement对象对数据源进行封装,传入自定义的颜色即可.注意实际数据只支持Float,记得抓换.

最后效果:

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/351206.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号