1、Android图表库MPAndroidChart十三简约的底部柱状图Android图表库MPAndroidChart(十三)简约的底部柱状图我们继续上一讲,今天还是说下柱状图,这个图的话应该是用的比较多的,所有拿出来溜溜,先看下效果我们还是来看下基本实现一.基本实现大家猜下,我们用哪个View来做比较好? 继续用BarChart,那我们来做初始化的动作 mBarChart.getDescription().setEnabled(false); mBarChart.setMaxVisibleValueCount(60); mBarChart.setPinchZoom(false); mBarCh
2、art.setDrawBarShadow(false); mBarChart.setDrawGridBackground(false); XAxis xAxis = mBarChart.getXAxis(); xAxis.setPosition(XAxis.XAxisPosition.BOTTOM); xAxis.setDrawGridLines(false); mBarChart.getAxisLeft().setDrawGridLines(false); mBarChart.animateY(2500); mBarChart.getLegend().setEnabled(false);这个
3、初始化我实际上并没有设置什么特殊的属性,然后设置数据 /设置数据 private void setData() ArrayList yVals1 = new ArrayList(); for (int i = 0; i 0) set1 = (BarDataSet) mBarChart.getData().getDataSetByIndex(0); set1.setValues(yVals1); mBarChart.getData().notifyDataChanged(); mBarChart.notifyDataSetChanged(); else set1 = new BarDataSet
4、(yVals1, 日期设置); /设置多彩 也可以单一颜色 set1.setColors(ColorTemplate.VORDIPLOM_COLORS); set1.setDrawValues(false); ArrayList dataSets = new ArrayList(); dataSets.add(set1); BarData data = new BarData(dataSets); mBarChart.setData(data); mBarChart.setFitBars(true); mBarChart.invalidate();在设置数据方面我也只是设置了多彩的颜色,这样就
5、能实现我们上图的效果了,这个也算是一个比较简单的图表了二.显示顶点值好,基本功能都差不多,那我们来看下全部代码activity_another.xml AnotherBarActivitypublic class AnotherBarActivity extends BaseActivity implements View.OnClickListener private BarChart mBarChart; /显示顶点值 private Button btn_show_values; /x轴动画 private Button btn_anim_x; /y轴动画 private Button
6、btn_anim_y; /xy轴动画 private Button btn_anim_xy; /保存到sd卡 private Button btn_save_pic; /切换自动最大最小值 private Button btn_auto_mix_max; /高亮显示 private Button btn_actionToggleHighlight; /显示边框 private Button btn_show_border; Override protected void onCreate(Bundle savedInstanceState) super.onCreate(savedInstan
7、ceState); setContentView(R.layout.activity_another); initView(); /初始化 private void initView() /基本控件 btn_show_values = (Button) findViewById(R.id.btn_show_values); btn_show_values.setOnClickListener(this); btn_anim_x = (Button) findViewById(R.id.btn_anim_x); btn_anim_x.setOnClickListener(this); btn_a
8、nim_y = (Button) findViewById(R.id.btn_anim_y); btn_anim_y.setOnClickListener(this); btn_anim_xy = (Button) findViewById(R.id.btn_anim_xy); btn_anim_xy.setOnClickListener(this); btn_save_pic = (Button) findViewById(R.id.btn_save_pic); btn_save_pic.setOnClickListener(this); btn_auto_mix_max = (Button
9、) findViewById(R.id.btn_auto_mix_max); btn_auto_mix_max.setOnClickListener(this); btn_actionToggleHighlight = (Button) findViewById(R.id.btn_actionToggleHighlight); btn_actionToggleHighlight.setOnClickListener(this); btn_show_border = (Button) findViewById(R.id.btn_show_border); btn_show_border.setO
10、nClickListener(this); mBarChart = (BarChart) findViewById(R.id.mBarChart); mBarChart.getDescription().setEnabled(false); mBarChart.setMaxVisibleValueCount(60); mBarChart.setPnchZoom(false); mBarChart.setDrawBarShadow(false); mBarChart.setDrawGridBackground(false); XAxis xAxis = mBarChart.getXAxis();
11、 xAxis.setPosition(XAxis.XAxisPosition.BOTTOM); xAxis.setDrawGridLines(false); mBarChart.getAxisLeft().setDrawGridLines(false); mBarChart.animateY(2500); mBarChart.getLegend().setEnabled(false); setData(); /设置数据 private void setData() ArrayList yVals1 = new ArrayList(); for (int i = 0; i 0) set1 = (
12、BarDataSet) mBarChart.getData().getDataSetByIndex(0); set1.setValues(yVals1); mBarChart.getData().notifyDataChanged(); mBarChart.notifyDataSetChanged(); else set1 = new BarDataSet(yVals1, 日期设置); /设置多彩 也可以单一颜色 set1.setColors(ColorTemplate.VORDIPLOM_COLORS); set1.setDrawValues(false); ArrayList dataSe
13、ts = new ArrayList(); dataSets.add(set1); BarData data = new BarData(dataSets); mBarChart.setData(data); mBarChart.setFitBars(true); mBarChart.invalidate(); Override public void onClick(View v) switch (v.getId() /显示顶点值 case R.id.btn_show_values: for (IDataSet set : mBarChart.getData().getDataSets()
14、set.setDrawValues(!set.isDrawValuesEnabled(); mBarChart.invalidate(); break; /x轴动画 case R.id.btn_anim_x: mBarChart.animateX(3000); break; /y轴动画 case R.id.btn_anim_y: mBarChart.animateY(3000); break; /xy轴动画 case R.id.btn_anim_xy: mBarChart.animateXY(3000, 3000); break; /保存到sd卡 case R.id.btn_save_pic:
15、 if (mBarChart.saveToGallery(title + System.currentTimeMillis(), 50) Toast.makeText(getApplicationContext(), 保存成功, Toast.LENGTH_SHORT).show(); else Toast.makeText(getApplicationContext(), 保存失败, Toast.LENGTH_SHORT).show(); break; /切换自动最大最小值 case R.id.btn_auto_mix_max: mBarChart.setAutoScaleMinMaxEnab
16、led(!mBarChart.isAutoScaleMinMaxEnabled(); mBarChart.notifyDataSetChanged(); break; /高亮显示 case R.id.btn_actionToggleHighlight: if (mBarChart.getData() != null) mBarChart.getData().setHighlightEnabled( !mBarChart.getData().isHighlightEnabled(); mBarChart.invalidate(); break; /显示边框 case R.id.btn_show_border: for (IBarDataSet set : mBarChart.getData().getDataSets() (BarDataSet) set).setBarBorderWidth(set.getBarBorderWidth() = 1.f ? 0.f : 1.f); mBarChart.invalidate(); break; OK,这样这个图表就大功告成了
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1