[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里面的使用说明,
结果发现并没有详细描述,只能翻代码

/**
 * @param animationType 动画类型
 * @param animationDuration 动画时间
 * @param title 标题内容
 * @param titleStyle 标题文本风格样式
 * @param subtitle 副标题内容
 * @param subtitleAlign
 * @param subtitleStyle 副标题文本风格样式
 * @param axesTextColor x 轴和 y 轴文字颜色
 * @param chartType 图表类型
 * @param stacking 堆积样式
 * @param markerRadius 折线连接点的半径长度,如果值设置为0,这样就相当于不显示了
 * @param markerSymbol 折线曲线连接点的类型:"circle", "square", "diamond", "triangle","triangle-down",默认是"circle"
 * @param markerSymbolStyle
 * @param zoomType 缩放类型 AAChartZoomTypeX表示可沿着 x 轴进行手势缩放
 * @param inverted x 轴是否翻转(垂直)
 * @param xAxisReversed x 轴翻转
 * @param yAxisReversed y 轴翻转
 * @param tooltipEnabled 是否显示浮动提示框(默认显示)
 * @param tooltipValueSuffix 浮动提示框单位后缀
 * @param gradientColorEnable 是否要为渐变色
 * @param polar 是否极化图形(变为雷达图)
 * @param margin 图表外边缘和绘图区域之间的边距
 * @param dataLabelsEnabled 是否显示数据
 * @param dataLabelsStyle
 * @param xAxisLabelsEnabled x轴是否显示数据
 * @param xAxisTickInterval
 * @param categories x轴是否显示数据
 * @param xAxisGridLineWidth x轴网格线的宽度
 * @param xAxisVisible x 轴是否显示
 * @param yAxisVisible y 轴是否显示
 * @param yAxisLabelsEnabled y轴是否显示数据
 * @param yAxisTitle y轴标题
 * @param yAxisLineWidth y 轴轴线的宽度
 * @param yAxisMin
 * @param yAxisMax
 * @param yAxisAllowDecimals
 * @param yAxisGridLineWidth y轴网格线的宽度
 * @param colorsTheme 图表主题颜色数组
 * @param legendEnabled 是否显示图例
 * @param backgroundColor 图表背景色
 * @param borderRadius 柱状图长条图头部圆角半径(可用于设置头部的形状,仅对条形图,柱状图有效,设置为1000时,柱形图或者条形图头部为楔形)
 * @param series
 * @param touchEventEnabled 是否支持用户触摸事件
 * @param scrollablePlotArea
 */

以上是AAChartModel的配置字段注释说明.
我自己按照注释进行了设置.
最终效果
调整设置后结果
现在就很清爽了.
没有不必要的说明,没有手指滑动的TIPS,也可以进行上下滑动.
NICE.
这是我抽取的函数,可以参考一下,注释都写上了.

/**
     * @param title 标题
     * @param categories 左侧每条数据的说明
     * @param data 数据源
     * @param height 图表设定高度,会影响到 是否可滑动,柱状图的高度
     */
    fun setChartParams(
        title: String,
        categories: MutableList<String>,
        data: Array<AASeriesElement>,
        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>()
//使用AADataElement对象
step.add(AADataElement().color("#FFDF00").y(it.step.toFloat()))

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

最后效果:
最终效果
Yes

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Python中绘制柱状图时,可以使用Matplotlib库实现。对于不同颜色对应不同数据的需求,可以通过在绘图函数中使用不同颜色参数来实现。具体实现步骤如下: 1. 导入Matplotlib库:首先需要导入绘图库Matplotlib,以便使用其提供的函数。 2. 准备数据:准备好需要绘制柱状图数据进行处理,例如将数据存储在一个列表中。 3. 设置颜色参数:使用颜色参数可以在柱状图中设置不同颜色对应不同数据。设置颜色参数需要使用RGB颜色表示法,可以使用Matplotlib提供的color参数进行设置。 4. 绘制柱状图使用Matplotlib提供的bar函数进行柱状图绘制。bar函数中需要传入x轴数据、y轴数据以及颜色参数。 5. 显示图像:使用Matplotlib提供的show函数将绘制好的柱状图显示出来。 例如,以下代码实现了对不同数据对应不同颜色柱状图绘制: ```python import matplotlib.pyplot as plt # 准备数据 data = [10, 20, 30, 40, 50] # 设置颜色参数 colors = ['r', 'g', 'b', 'y', 'm'] # 绘制柱状图 plt.bar(range(5), data, color=colors) # 显示图像 plt.show() ``` 在以上代码中,我们使用了一个包含5个数据的列表作为柱状图的y轴数据。然后,我们定义了5种不同颜色,分别对应不同数据。在绘制柱状图时,我们通过color参数将颜色参数传递给plot函数,从而实现了不同颜色对应不同数据的需求。最后使用show函数将绘制好的柱状图显示出来。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值