继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

MPAndroidChart X坐标换行问题

霁雪清虹
关注TA
已关注
手记 33
粉丝 1万
获赞 137

MPAndroidChart 的X坐标点文案换行问题应该比较常见,但是墙内搜了一下,好像都不甚直接,有一个自定义改源码的,私以为小题大做,以下给出解决方案

效果图

图片描述>

重点核心

核心代码

mBarChart.setXAxisRenderer(CustomXAxisRenderer(mBarChart.viewPortHandler, mBarChart.xAxis, mBarChart.getTransformer(YAxis.AxisDependency.LEFT)))

其中mBarChart为BarChart 对象,
假设自定义x坐标的textSize为xAxis.textSize = 12f
需要设置底部额外控件提供换行的文字显示的空间 mBarChart.extraBottomOffset = 3 * 12f,其中12就是刚刚设置的xAxis.textSize 其中3表示我的X坐标文字有3行

/**图表X坐标文字换行解决方案 setExtraBottomOffset + 自定义 CustomXAxisRenderer
     * https://stackoverflow.com/questions/32509174/in-mpandroidchart-library-how-to-wrap-x-axis-labels-to-two-lines-when-long
     */
    class CustomXAxisRenderer(viewPortHandler: ViewPortHandler, xAxis: XAxis, trans: Transformer) : XAxisRenderer(viewPortHandler, xAxis, trans) {

        override fun drawLabel(c: Canvas, formattedLabel: String, x: Float, y: Float, anchor: MPPointF, angleDegrees: Float) {
            val lines = formattedLabel.split("\n")
            for (i in lines.indices) {
                val vOffset = i * mAxisLabelPaint.textSize
                Utils.drawXAxisValue(c, lines[i], x, y + vOffset, mAxisLabelPaint, anchor, angleDegrees)
            }
        }
    }

打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP