缩放X轴MPAndroid图表

时间:2018-07-16 10:41:51

标签: android mpandroidchart

我有一个简单的折线图。我不知道如何使x轴值像y轴值那样正确缩放。无论我输入到图表中的值如何,x值之间的距离始终是等距的。

通过添加整个折线图代码进行编辑。

Five Hundred "and" .......

这是XAxisValueFormatted类,可能是问题的根源:

    setData();

    Legend l = mChart.getLegend();


    l.setForm(Legend.LegendForm.LINE);

    mChart.setDragEnabled(true);
    mChart.setScaleEnabled(true);

    YAxis leftAxis = mChart.getAxisLeft();
    leftAxis.removeAllLimitLines(); 

    leftAxis.enableGridDashedLine(10f, 10f, 0f);
    leftAxis.setDrawZeroLine(false);


    leftAxis.setDrawLimitLinesBehindData(true);

    mChart.getAxisRight().setEnabled(false);

    mChart.animateX(2000, Easing.EasingOption.EaseInOutQuart);


    mChart.invalidate();

    return view;
}

private ArrayList<String> setXAxisValues(){
    ArrayList<String> xVals = new ArrayList<String>();
    xVals.add(String.valueOf(x1));

    xVals.add(String.valueOf(x2));
    xVals.add(String.valueOf(x3));
    return xVals;
}

private ArrayList<Entry> setYAxisValues(){
    ArrayList<Entry> yVals = new ArrayList<Entry>();
    yVals.add(new Entry(0, y1));
    yVals.add(new Entry(1, y2));
    yVals.add(new Entry(2, y3));

    return yVals;
}

private void setData() {
    ArrayList<String> xVals = setXAxisValues();

    ArrayList<Entry> yVals = setYAxisValues();

    LineDataSet set1;

    set1 = new LineDataSet(yVals, yTitle);

    set1.setFillAlpha(110);

    ArrayList<ILineDataSet> dataSets = new ArrayList<ILineDataSet>();
    dataSets.add(set1); // add the datasets
    LineData data = new LineData(dataSets);


    String[] values = new String[] {String.valueOf(x1), String.valueOf(x2), String.valueOf(x3)};
    XAxis xAxis = mChart.getXAxis();
   xAxis.setGranularity(1f);
    mChart.setScaleEnabled(true);

    xAxis.setValueFormatter(new MyXAxisValueFormatted(values));

    mChart.getLegend().setTextColor(Color.WHITE);
    mChart.getXAxis().setTextColor(Color.WHITE);
    mChart.getAxisLeft().setTextColor(Color.WHITE);
    mChart.getXAxis().setPosition(XAxis.XAxisPosition.BOTTOM);
    mChart.setData(data);

}

enter image description here

1 个答案:

答案 0 :(得分:1)

这是解决方法,但首先要说明:

您的x轴值都不知道“ 3”,“ 9”和“ 100”,因为它们都是字符串。但它从这里知道0 1和2(x值):

 yVals.add(new Entry(0, y1));
 yVals.add(new Entry(1, y2));
 yVals.add(new Entry(2, y3));

这些值具有相同的间隔,这就是为什么格式化程序在字符串3、9和100之间给出相同的分隔符(空格)。

解决方案非常简单,忘记(删除类)有关值IAxisValueFormatter,只需像这样初始化Entry-

    yVals.add(new Entry(3, 2));
    yVals.add(new Entry(9, 1));
    yVals.add(new Entry(100f, -90f));

一切都会自动完成,这是我从您的代码和值中得到的:

enter image description here