6

MPAndroidChart ライブラリリリース v2を使用しています。データベースから取得したデータを使用して、3 つのバーを表示しようとしています。残念ながら、データを含む 3 本のバーを表示する代わりに、同じ結果でそれらを表示します。スクリーンショットを参照してください。ご協力いただきありがとうございます。

int [] x = {1,2,3};
Cursor c = db.rawQuery(sql, null);
        int count = c.getCount();

        float value1 ;
        float value2 ;
        float value3 ;
        String[] mesi = new String[count];

        for(int n=0; n<count; n++) {
            c.moveToNext();     
            mesi[n]= c.getString(0);              
            value1 = c.getFloat(1);
            value2 = c.getFloat(2);
            value3 = c.getFloat(3);

            ArrayList<String> xVals = new ArrayList<String>();
            for (int i = 0; i <x.length; i++) {
                 xVals.add(x.length + " " + mChart.getUnit());              
            }

            ArrayList<BarEntry> yVals1 = new ArrayList<BarEntry>();
            ArrayList<BarEntry> yVals2 = new ArrayList<BarEntry>();
            ArrayList<BarEntry> yVals3 = new ArrayList<BarEntry>();

            for (int i = 0; i < x.length; i++) {                  
                yVals1.add(new BarEntry(value1, i));
            }

            for (int i = 0; i < x.length; i++) {                
                yVals2.add(new BarEntry(value2, i));
            }

            for (int i = 0; i < x.length; i++) {                  
                yVals3.add(new BarEntry(value3, i));
            }

         // create 3 datasets with different types
            BarDataSet set1 = new BarDataSet(yVals1, "Company A");
            set1.setColor(Color.rgb(104, 241, 175));
            BarDataSet set2 = new BarDataSet(yVals2, "Company B");
            set2.setColor(Color.rgb(164, 228, 251));
            BarDataSet set3 = new BarDataSet(yVals3, "Company C");
            set3.setColor(Color.rgb(242, 247, 158));

            ArrayList<BarDataSet> dataSets = new ArrayList<BarDataSet>();
            dataSets.add(set1);
            dataSets.add(set2);
            dataSets.add(set3);

            BarData data = new BarData(xVals, dataSets);

            // add space between the dataset groups in percent of bar-width
            data.setGroupSpace(0);

            mChart.setData(data);
            mChart.invalidate();

}               
        c.close();  
    db.close();

}

結果ここに画像の説明を入力

4

1 に答える 1

4

グラフに表示される値の logcat 出力を作成しましたか? データベースに正しく保存されていない可能性があります。

あなたのコードは私には正しいようです。

また、すべてのバーに 50 などの定義済みの値を指定するだけでテストし、正しくプロットされるかどうかを確認することもできます。

カラー コールを変更するには:

BarDataSet.setColor(...);

更新BarCharts:リリース v3.0.0 に基づいて、ライブラリの公式 GitHub ページで利用可能なグループ化を作成する方法に関する非常に詳細なチュートリアルが現在あります: グループ化された棒グラフのチュートリアル

于 2014-11-12T14:28:54.413 に答える