一、自定义显示
XAxis xAxis = chart.getXAxis();//获取设置X轴
ValueFormatter valueFormatter = new ValueFormatter() {
private final String[] xLableList = new String[]{"110\n报警", "120\n报警", "119\n报警", "110\n报警", "120\n报警",
"119\n报警", "110\n报警", "120\n报警", "119\n报警"};
@Override
public String getFormattedValue(float value) {
if (value >= 0) {
return mActivities[(int) value % xLableList.length];
} else {
return "";
}
}
};
xAxis.setValueFormatter(valueFormatter);//设置自定义格式,在绘制之前动态调整x的值。
二、显示不全
xAxis.setGranularity(1)
设置 后 value是从0开始的,每次加1
xAxis.setLabelCount(xLableList.size());
根据X轴显示个数,设置标签数
三、X轴坐标换行显示
解决方案 setExtraBottomOffset + 自定义 CustomXAxisRenderer
假设自定义x坐标的textSize为xAxis.textSize = 9f
需要设置底部额外控件提供换行的文字显示的空间 chart.extraBottomOffset = 3 * 9f
,其中9就是刚刚设置的xAxis.textSize
其中2表示我的X坐标文字有2行
chart.setExtraBottomOffset(2 * 9f);
xAxis.setTextSize(9);
重写类XAxisRenderer
public class CustomXAxisRenderer extends XAxisRenderer {
public CustomXAxisRenderer(ViewPortHandler viewPortHandler, XAxis xAxis, Transformer trans) {
super(viewPortHandler, xAxis, trans);
}
@Override
protected void drawLabel(Canvas c, String formattedLabel, float x, float y, MPPointF anchor, float angleDegrees) {
// super.drawLabel(c, formattedLabel, x, y, anchor, angleDegrees);//注释掉这个,否则坐标标签复写两次
String[] lines = formattedLabel.split("\n");
for (int i = 0; i < lines.length; i++) {
float vOffset = i * mAxisLabelPaint.getTextSize();
Utils.drawXAxisValue(c, lines[i], x, y + vOffset, mAxisLabelPaint, anchor, angleDegrees);
}
}
}
表格设置这条属性
chart.setXAxisRenderer(new CustomXAxisRenderer(chart.getViewPortHandler(), chart.getXAxis(), chart.getTransformer(YAxis.AxisDependency.LEFT)));
第三条需要自定义X轴坐标显示,集合添加对象 \n ,例:第一条