Clear up grouped bar example
This commit is contained in:
parent
d65ffb8871
commit
0fec2ef06b
2 changed files with 46 additions and 53 deletions
|
@ -35,7 +35,7 @@
|
|||
|
||||
<TextView
|
||||
android:id="@+id/tvXMax"
|
||||
android:layout_width="50dp"
|
||||
android:layout_width="60dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignBottom="@+id/seekBar1"
|
||||
android:layout_alignParentRight="true"
|
||||
|
@ -43,11 +43,11 @@
|
|||
android:layout_marginBottom="15dp"
|
||||
android:layout_marginRight="10dp"
|
||||
android:gravity="right"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium" />
|
||||
android:textAppearance="?android:attr/textAppearanceSmall" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tvYMax"
|
||||
android:layout_width="50dp"
|
||||
android:layout_width="60dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignBottom="@+id/seekBar2"
|
||||
android:layout_alignParentRight="true"
|
||||
|
@ -55,6 +55,6 @@
|
|||
android:layout_marginBottom="15dp"
|
||||
android:layout_marginRight="10dp"
|
||||
android:gravity="right"
|
||||
android:textAppearance="?android:attr/textAppearanceMedium" />
|
||||
android:textAppearance="?android:attr/textAppearanceSmall" />
|
||||
|
||||
</RelativeLayout>
|
||||
|
|
|
@ -14,7 +14,6 @@ import android.widget.TextView;
|
|||
import com.github.mikephil.charting.charts.BarChart;
|
||||
import com.github.mikephil.charting.components.AxisBase;
|
||||
import com.github.mikephil.charting.components.Legend;
|
||||
import com.github.mikephil.charting.components.Legend.LegendPosition;
|
||||
import com.github.mikephil.charting.components.XAxis;
|
||||
import com.github.mikephil.charting.components.YAxis;
|
||||
import com.github.mikephil.charting.data.BarData;
|
||||
|
@ -46,6 +45,7 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
setContentView(R.layout.activity_barchart);
|
||||
|
||||
tvX = (TextView) findViewById(R.id.tvXMax);
|
||||
tvX.setTextSize(10);
|
||||
tvY = (TextView) findViewById(R.id.tvYMax);
|
||||
|
||||
mSeekBarX = (SeekBar) findViewById(R.id.seekBar1);
|
||||
|
@ -59,7 +59,7 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
mChart.getDescription().setEnabled(false);
|
||||
|
||||
// mChart.setDrawBorders(true);
|
||||
|
||||
|
||||
// scaling can now only be done on x- and y-axis separately
|
||||
mChart.setPinchZoom(false);
|
||||
|
||||
|
@ -83,14 +83,15 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
l.setDrawInside(true);
|
||||
l.setTypeface(mTfLight);
|
||||
l.setYOffset(0f);
|
||||
l.setXOffset(10f);
|
||||
l.setYEntrySpace(0f);
|
||||
l.setTextSize(8f);
|
||||
|
||||
XAxis xl = mChart.getXAxis();
|
||||
xl.setTypeface(mTfLight);
|
||||
xl.setGranularity(1f);
|
||||
xl.setCenterAxisLabels(true);
|
||||
xl.setValueFormatter(new IAxisValueFormatter() {
|
||||
XAxis xAxis = mChart.getXAxis();
|
||||
xAxis.setTypeface(mTfLight);
|
||||
xAxis.setGranularity(1f);
|
||||
xAxis.setCenterAxisLabels(true);
|
||||
xAxis.setValueFormatter(new IAxisValueFormatter() {
|
||||
@Override
|
||||
public String getFormattedValue(float value, AxisBase axis) {
|
||||
return String.valueOf((int) value);
|
||||
|
@ -106,7 +107,7 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
leftAxis.setTypeface(mTfLight);
|
||||
leftAxis.setValueFormatter(new LargeValueFormatter());
|
||||
leftAxis.setDrawGridLines(false);
|
||||
leftAxis.setSpaceTop(30f);
|
||||
leftAxis.setSpaceTop(35f);
|
||||
leftAxis.setAxisMinimum(0f); // this replaces setStartAtZero(true)
|
||||
|
||||
mChart.getAxisRight().setEnabled(false);
|
||||
|
@ -145,13 +146,13 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
}
|
||||
case R.id.actionToggleBarBorders: {
|
||||
for (IBarDataSet set : mChart.getData().getDataSets())
|
||||
((BarDataSet)set).setBarBorderWidth(set.getBarBorderWidth() == 1.f ? 0.f : 1.f);
|
||||
((BarDataSet) set).setBarBorderWidth(set.getBarBorderWidth() == 1.f ? 0.f : 1.f);
|
||||
|
||||
mChart.invalidate();
|
||||
break;
|
||||
}
|
||||
case R.id.actionToggleHighlight: {
|
||||
if(mChart.getData() != null) {
|
||||
if (mChart.getData() != null) {
|
||||
mChart.getData().setHighlightEnabled(!mChart.getData().isHighlightEnabled());
|
||||
mChart.invalidate();
|
||||
}
|
||||
|
@ -171,7 +172,6 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
break;
|
||||
}
|
||||
case R.id.animateXY: {
|
||||
|
||||
mChart.animateXY(3000, 3000);
|
||||
break;
|
||||
}
|
||||
|
@ -182,78 +182,73 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
@Override
|
||||
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
|
||||
|
||||
float groupSpace = 0.04f;
|
||||
float barSpace = 0.02f; // x3 dataset
|
||||
float barWidth = 0.3f; // x3 dataset
|
||||
// (0.3 + 0.02) * 3 + 0.04 = 1.00 -> interval per "group"
|
||||
float groupSpace = 0.08f;
|
||||
float barSpace = 0.03f; // x4 DataSet
|
||||
float barWidth = 0.2f; // x4 DataSet
|
||||
// (0.2 + 0.03) * 4 + 0.08 = 1.00 -> interval per "group"
|
||||
|
||||
int groupCount = mSeekBarX.getProgress() + 1;
|
||||
int startYear = 1980;
|
||||
int endYear = startYear + mSeekBarX.getProgress();
|
||||
int endYear = startYear + groupCount;
|
||||
|
||||
tvX.setText(startYear + "\n-" + endYear);
|
||||
tvX.setText(startYear + "-" + endYear);
|
||||
tvY.setText("" + (mSeekBarY.getProgress()));
|
||||
|
||||
ArrayList<BarEntry> yVals1 = new ArrayList<BarEntry>();
|
||||
ArrayList<BarEntry> yVals2 = new ArrayList<BarEntry>();
|
||||
ArrayList<BarEntry> yVals3 = new ArrayList<BarEntry>();
|
||||
ArrayList<BarEntry> yVals4 = new ArrayList<BarEntry>();
|
||||
|
||||
float mult = mSeekBarY.getProgress() * 100000f;
|
||||
float randomMultiplier = mSeekBarY.getProgress() * 100000f;
|
||||
|
||||
for (int i = startYear; i < endYear; i++) {
|
||||
float val = (float) (Math.random() * mult) + 3;
|
||||
yVals1.add(new BarEntry(i, val));
|
||||
yVals1.add(new BarEntry(i, (float) (Math.random() * randomMultiplier)));
|
||||
yVals2.add(new BarEntry(i, (float) (Math.random() * randomMultiplier)));
|
||||
yVals3.add(new BarEntry(i, (float) (Math.random() * randomMultiplier)));
|
||||
yVals4.add(new BarEntry(i, (float) (Math.random() * randomMultiplier)));
|
||||
}
|
||||
|
||||
for (int i = startYear; i < endYear; i++) {
|
||||
float val = (float) (Math.random() * mult) + 3;
|
||||
yVals2.add(new BarEntry(i, val));
|
||||
}
|
||||
BarDataSet set1, set2, set3, set4;
|
||||
|
||||
for (int i = startYear; i < endYear; i++) {
|
||||
float val = (float) (Math.random() * mult) + 3;
|
||||
yVals3.add(new BarEntry(i, val));
|
||||
}
|
||||
if (mChart.getData() != null && mChart.getData().getDataSetCount() > 0) {
|
||||
|
||||
BarDataSet set1, set2, set3;
|
||||
|
||||
if (mChart.getData() != null &&
|
||||
mChart.getData().getDataSetCount() > 0) {
|
||||
set1 = (BarDataSet)mChart.getData().getDataSetByIndex(0);
|
||||
set2 = (BarDataSet)mChart.getData().getDataSetByIndex(1);
|
||||
set3 = (BarDataSet)mChart.getData().getDataSetByIndex(2);
|
||||
set1 = (BarDataSet) mChart.getData().getDataSetByIndex(0);
|
||||
set2 = (BarDataSet) mChart.getData().getDataSetByIndex(1);
|
||||
set3 = (BarDataSet) mChart.getData().getDataSetByIndex(2);
|
||||
set4 = (BarDataSet) mChart.getData().getDataSetByIndex(3);
|
||||
set1.setValues(yVals1);
|
||||
set2.setValues(yVals2);
|
||||
set3.setValues(yVals3);
|
||||
set4.setValues(yVals4);
|
||||
mChart.getData().notifyDataChanged();
|
||||
mChart.notifyDataSetChanged();
|
||||
|
||||
} else {
|
||||
// create 3 datasets with different types
|
||||
// create 4 DataSets
|
||||
set1 = new BarDataSet(yVals1, "Company A");
|
||||
// set1.setColors(ColorTemplate.createColors(getApplicationContext(),
|
||||
// ColorTemplate.FRESH_COLORS));
|
||||
set1.setColor(Color.rgb(104, 241, 175));
|
||||
set2 = new BarDataSet(yVals2, "Company B");
|
||||
set2.setColor(Color.rgb(164, 228, 251));
|
||||
set3 = new BarDataSet(yVals3, "Company C");
|
||||
set3.setColor(Color.rgb(242, 247, 158));
|
||||
set4 = new BarDataSet(yVals4, "Company D");
|
||||
set4.setColor(Color.rgb(255, 102, 0));
|
||||
|
||||
ArrayList<IBarDataSet> dataSets = new ArrayList<IBarDataSet>();
|
||||
dataSets.add(set1);
|
||||
dataSets.add(set2);
|
||||
dataSets.add(set3);
|
||||
|
||||
BarData data = new BarData(dataSets);
|
||||
BarData data = new BarData(set1, set2, set3, set4);
|
||||
data.setValueFormatter(new LargeValueFormatter());
|
||||
|
||||
// add space between the dataset groups in percent of bar-width
|
||||
data.setValueTypeface(mTfLight);
|
||||
|
||||
mChart.setData(data);
|
||||
}
|
||||
|
||||
// specify the width each bar should have
|
||||
mChart.getBarData().setBarWidth(barWidth);
|
||||
|
||||
// restrict the x-axis range
|
||||
mChart.getXAxis().setAxisMinimum(startYear);
|
||||
mChart.getXAxis().setAxisMaximum(mChart.getBarData().getGroupWidth(groupSpace, barSpace) * mSeekBarX.getProgress() + startYear);
|
||||
|
||||
// barData.getGroupWith(...) is a helper that calculates the width each group needs based on the provided parameters
|
||||
mChart.getXAxis().setAxisMaximum(startYear + mChart.getBarData().getGroupWidth(groupSpace, barSpace) * groupCount);
|
||||
mChart.groupBars(startYear, groupSpace, barSpace);
|
||||
mChart.invalidate();
|
||||
}
|
||||
|
@ -261,13 +256,11 @@ public class BarChartActivityMultiDataset extends DemoBase implements OnSeekBarC
|
|||
@Override
|
||||
public void onStartTrackingTouch(SeekBar seekBar) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStopTrackingTouch(SeekBar seekBar) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
Loading…
Add table
Reference in a new issue