简体   繁体   English

MP Android Chart - 如何修复折线图中X轴值的数量?

[英]MP Android Chart-How to fix the number of X-Axis values in the Line Chart?

private void plotchart(String s[], float[] f1) {
    chart.setBackgroundColor(Color.rgb(63, 81, 181));
    chart.setDescription("");
    // enable touch gestures
    chart.setTouchEnabled(true);
    chart.setScaleEnabled(false);
    chart.setPinchZoom(false);
    chart.setGridBackgroundColor(Color.rgb(30, 46, 141));
    chart.setDrawGridBackground(false);
    chart.getAxisRight().setEnabled(false);
    chart.setDrawMarkerViews(true);
    chart.setDragEnabled(true);
    chart.setViewPortOffsets(0f, 0f, 0f, 0f);

   // chart.setVisibleXRangeMaximum(4);


    chart.getLegend().setEnabled(false);

    XAxis x = chart.getXAxis();
    x.setEnabled(true);
    x.setDrawGridLines(false);
    x.setPosition(XAxis.XAxisPosition.BOTTOM_INSIDE);
    x.setTextColor(Color.rgb(128, 128, 255));
    x.isDrawLabelsEnabled();
    x.setAxisLineColor(Color.BLACK);
    x.setSpaceBetweenLabels(3);
    x.setAvoidFirstLastClipping(true);


    YAxis y = chart.getAxisLeft();
    y.setAxisLineColor(Color.BLACK);
    y.setTextColor(Color.BLACK);
    y.setEnabled(true);
    y.setAxisLineColor(Color.rgb(128, 128, 255));
    y.setPosition(YAxis.YAxisLabelPosition.INSIDE_CHART);
    y.setDrawGridLines(false);
    y.setLabelCount(5,true);
    y.setGridColor(Color.rgb(128, 128, 255));
    y.setDrawZeroLine(false);
    y.setDrawLimitLinesBehindData(true);
    y.setDrawGridLines(true);
    y.setDrawLimitLinesBehindData(true);
    y.setTextColor(Color.rgb(128, 128, 255));
//    chart.setExtraOffsets(20f,2f,20f,2f);

    ArrayList<com.github.mikephil.charting.data.Entry> entries= new ArrayList<>();
    for (int i = 0; i < f1.length; i++) {
        // Log.i("f1",f1[i]+"");
         entries.add(new com.github.mikephil.charting.data.Entry(f1[i], i));
    }

    MymarkerView mv =new MymarkerView(this,R.layout.custom_marker_view);
    chart.setMarkerView(mv);

    LineDataSet dataset = new LineDataSet(entries, "");
    dataset.isDrawCirclesEnabled();
    dataset.setCircleRadius(0f);
    dataset.setDrawFilled(true);
    dataset.setFillColor(Color.rgb(0, 0, 0));
    dataset.setLineWidth(0.2f);
    dataset.setValueTextSize(0f);

    dataset.setColor(Color.rgb(0, 0, 0));

  //  chart.setVisibleXRange(1, 5);
   // chart.setVisibleYRangeMaximum(5, YAxis.AxisDependency.LEFT);
  //  chart.setClickable(true);
    chart.invalidate();


    ArrayList<String> time = new ArrayList<String>();
    for (int i = 0; i < s.length; i++) {
        time.add(i, s[i]);
    }

    LineData data = new LineData(time, dataset);
    chart.setData(data);


}

I Have fixed the Y-Axis values by using setLabelCount() command.But how to fix the number of X-Axis values in my chart..For the above code i have the following chart formed. 我已经使用setLabelCount()命令修复了Y轴值。但是如何修复我的图表中的X轴值的数量。对于上面的代码,我形成了下面的图表。 Chart1 Chart2 ..These are the two charts formed for different arguments given to the plotchart(String [],float[]) method.In all these charts I am facing the problem that it is not showing the fixed number of x-axis values.Somewhere it is showing 9 values and somewhere it is showing 7 values..And one more issue I am facing is that my first and the last Y-Axis values are getting hidden in my display. Chart1 Chart2 ..这些是为plotchart(String [],float [])方法给出的不同参数形成的两个图表。在所有这些图表中,我面临的问题是它没有显示固定数量的x轴值在某个地方,它显示了9个值,某处显示了7个值。我面临的另一个问题是我的第一个和最后一个Y轴值隐藏在我的显示中。

If I understood your question well, it seems that you want to use the setVisibleXRangeMaximum method. 如果我理解你的问题,似乎你想使用setVisibleXRangeMaximum方法。

Restraining what's visible 抑制可见的东西

setVisibleXRangeMaximum(float maxXRange): Sets the size of the area (range on the x-axis) that should be maximum visible at once. setVisibleXRangeMaximum(float maxXRange):设置应该一次最大可见的区域大小(x轴上的范围)。 If this is eg set to 10, no more than 10 values on the x-axis can be viewed at once without scrolling. 如果这例如设置为10,则可以一次查看x轴上不超过10个值而无需滚动。

This method is documented in the Viewport part of the MPAndroidChart tutorial, which is linked here . 此方法记录在MPAndroidChart教程的Viewport部分中,该教程在此处链接

Of course, I think you will have to use the setVisibleXRangeMinimum if you want to fix an upper and a lower bounds for the number of X values. 当然,如果你想修复X值的上限下限,我认为你必须使用setVisibleXRangeMinimum

setLabelCount() property is there for xAxis too. setLabelCount()属性也适用于xAxis。

 XAxis xAxis = lineChart.getXAxis();
 xAxis.setLabelCount(5);

To set the X-axis values to a fixed number (10 for example): 要将X轴值设置为固定数字(例如10):

float minXRange = 10;
float maxXRange = 10;
chart.setVisibleXRange(minXRange, maxXRange); 

If the gap between your values on the X-axis is constant, it will also fix the scale for the X-axis. 如果X轴上的值之间的间隙是恒定的,它也将固定X轴的刻度。

To auto set the scale on the Y-Axis with 10% spacing according to your maximum and minimum values: 根据最大值和最小值,在Y轴上自动设置10%间距的比例:

YAxis y1 = chart.getAxisLeft();
float percent = 10;
y1.setSpaceTop(percent);
y1.setSpaceBottom(percent);

Set X-Axis values 设置X轴值

xAxis.setValueFormatter(new IAxisValueFormatter() {
        @Override
        public String getFormattedValue(float value, AxisBase axis) {
            return (int) value + "";
        }
    });

You can use IndexAxisValueFormatter method of library 您可以使用IndexAxisValueFormatter方法

ArrayList<String> xAxisLabel = new ArrayList<>();
        xAxisLabel.add("Mon");
        xAxisLabel.add("Tue");
        xAxisLabel.add("Wed");
        xAxisLabel.add("Thu");
        xAxisLabel.add("Fri");
        xAxisLabel.add("Sat");
        xAxisLabel.add("Sun");

chart.getXAxis().setValueFormatter(new IndexAxisValueFormatter(texts));

Current library version v3.0.3 当前库版本v3.0.3

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM