如何使用android中的achartengine库在同一布局中显示两个图形

时间:2013-08-08 07:34:47

标签: java android achartengine

我正面临使用achartengine库显示图形的问题。我有两个菜单按钮,例如 A B 按钮。现在,当您单击 A 菜单时,会显示按钮折线图,当您单击 B 菜单按钮时,将显示饼图。我面临的问题是,当我再次点击 A 菜单按钮以显示未显示任何图表的行时, B 菜单按钮会发生相同的情况。

这是我的主要活动课程:

import org.achartengine.ChartFactory;
import org.achartengine.GraphicalView;
import org.achartengine.chart.PointStyle;
import org.achartengine.model.CategorySeries;
import org.achartengine.model.SeriesSelection;
import org.achartengine.model.TimeSeries;
import org.achartengine.model.XYMultipleSeriesDataset;
import org.achartengine.renderer.DefaultRenderer;
import org.achartengine.renderer.SimpleSeriesRenderer;
import org.achartengine.renderer.XYMultipleSeriesRenderer;
import org.achartengine.renderer.XYSeriesRenderer;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Toast;

import com.capricorn.RayMenu;

public class MainActivity extends Activity {

    private static final int[] ITEM_DRAWABLES = { R.drawable.ic_1,
            R.drawable.ic_2, R.drawable.ic_3, R.drawable.ic_4, R.drawable.ic_5,
            R.drawable.ic_6 };

    private GraphicalView mChartView;
    private GraphicalView pieChartView;
    private CategorySeries pieSeries = new CategorySeries("Pie Chart");
    private DefaultRenderer pieRenderer = new DefaultRenderer();
    private TimeSeries series = new TimeSeries("Line1");
    private XYMultipleSeriesDataset dataSet = new XYMultipleSeriesDataset();
    private XYMultipleSeriesRenderer multiRenderer = new XYMultipleSeriesRenderer();
    private XYSeriesRenderer renderer = new XYSeriesRenderer();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        final int itemCount = ITEM_DRAWABLES.length;

        RayMenu rayMenu = (RayMenu) findViewById(R.id.ray_menu);
        for (int i = 0; i < itemCount; i++) {
            ImageView item = new ImageView(this);
            item.setImageResource(ITEM_DRAWABLES[i]);

            final int position = i;
            rayMenu.addItem(item, new OnClickListener() {

                @Override
                public void onClick(View v) {
                    action(position);
                }
            });// Add a menu item
        }

    }

    public void lineGraph() {
        int[] X = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
        int[] Y = { 30, 34, 45, 57, 77, 89, 100, 111, 123, 145 };
        for (int i = 0; i < X.length; i++) {
            series.add(X[i], Y[i]);
        }

        dataSet.addSeries(series);
        renderer.setColor(Color.RED);
        renderer.setPointStyle(PointStyle.CIRCLE);
        renderer.setFillPoints(true);
        multiRenderer.setApplyBackgroundColor(true);
        multiRenderer.setBackgroundColor(Color.WHITE);
        multiRenderer.setMarginsColor(Color.WHITE);
        multiRenderer.setAxesColor(Color.BLACK);
        multiRenderer.setLabelsTextSize(20);
        multiRenderer.setXLabelsColor(Color.BLACK);
        multiRenderer.setYLabelsColor(0, Color.BLACK);
        multiRenderer.addSeriesRenderer(renderer);
    }

    public void pieGraph() {
        int[] values = { 25, 15, 20, 40 };
        int k =0;
        for(int value : values){
            pieSeries.add("Section" + ++k, value);
        }
        int[] COLORS = new int[] { Color.GREEN, Color.BLUE,
                Color.MAGENTA, Color.CYAN };
        for(int colors : COLORS){
            SimpleSeriesRenderer simple = new SimpleSeriesRenderer();
            simple.setColor(colors);
            pieRenderer.addSeriesRenderer(simple);
        }

    }

    public void action(int id) {
        LinearLayout layout = (LinearLayout) findViewById(R.id.chart);

        if (id == 0) {
            layout.removeView(pieChartView);

            lineGraph();

            if (mChartView == null) {

                mChartView = ChartFactory.getLineChartView(this, dataSet,
                        multiRenderer);

                multiRenderer.setClickEnabled(true);
                multiRenderer.setSelectableBuffer(10);
                mChartView.setOnClickListener(new View.OnClickListener() {
                    public void onClick(View v) {

                        SeriesSelection seriesSelection = mChartView
                                .getCurrentSeriesAndPoint();
                        if (seriesSelection == null) {
                            Toast.makeText(MainActivity.this,
                                    "No chart element", Toast.LENGTH_SHORT)
                                    .show();
                        } else {

                            Toast.makeText(
                                    MainActivity.this,
                                    "Chart element in series index "
                                            + seriesSelection.getSeriesIndex()
                                            + " data point index "
                                            + seriesSelection.getPointIndex()
                                            + " was clicked"
                                            + " closest point value X="
                                            + seriesSelection.getXValue()
                                            + ", Y="
                                            + seriesSelection.getValue(),
                                    Toast.LENGTH_SHORT).show();
                        }
                    }
                });
                layout.addView(mChartView, new LayoutParams(
                        LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));

            } else {
                mChartView.repaint();
            }
        } else if (id == 1) {
            layout.removeView(mChartView);
            pieGraph();
            if (pieChartView == null) {

                pieChartView = ChartFactory.getPieChartView(this, pieSeries,
                        pieRenderer);
                pieRenderer.setClickEnabled(true);
                pieChartView.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View v) {
                        SeriesSelection seriesSelection = pieChartView
                                .getCurrentSeriesAndPoint();
                        if (seriesSelection == null) {
                            Toast.makeText(MainActivity.this,
                                    "No chart element selected",
                                    Toast.LENGTH_SHORT).show();
                        } else {
                            for (int i = 0; i < pieSeries.getItemCount(); i++) {
                                pieRenderer.getSeriesRendererAt(i)
                                        .setHighlighted(
                                                i == seriesSelection
                                                        .getPointIndex());
                            }

                            Toast.makeText(
                                    MainActivity.this,
                                    "Chart data point index "
                                            + seriesSelection.getPointIndex()
                                            + " selected" + " point value="
                                            + seriesSelection.getValue(),
                                    Toast.LENGTH_SHORT).show();
                        }
                    }
                });
                layout.addView(pieChartView, new LayoutParams(
                        LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
            } else {
                pieChartView.repaint();
            }
        } else if (id == 2) {

        } else if (id == 3) {

        } else if (id == 4) {

        } else if (id == 5) {

        }
    }

}

从上面的代码中我可以看到我使用layout.removeView从布局中删除GraphicalView然后我第一次点击按钮时可以查看一次但是当你点击按钮时看不到第二次。请帮助我,我在过去2天遇到这个问题。

0 个答案:

没有答案