如何在android中将新数据上传到条形图?

如何在android中将新数据上传到条形图?,android,sqlite,Android,Sqlite,我已经创建了一个动态条形图。但我无法刷新条形图,以便它从数据库中获取新值(如果有),并使用新值再次绘制条形图。我正在使用sqlite创建数据库。我使用achartengine创建了条形图。我创建了custon chartbar。 创建dbHelper以使用SQLite DB import android.content.ContentValues; import android.content.Context; import android.database.Cursor;

我已经创建了一个动态条形图。但我无法刷新条形图,以便它从数据库中获取新值(如果有),并使用新值再次绘制条形图。我正在使用sqlite创建数据库。我使用achartengine创建了条形图。

我创建了custon chartbar。 创建dbHelper以使用SQLite DB

import android.content.ContentValues;
    import android.content.Context;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteOpenHelper;
    import android.provider.BaseColumns;
public class DBHelper extends SQLiteOpenHelper {
public static interface DESTINATION extends BaseColumns {
            String TABLE_NAME = "destination";
            String NAME = "name";
        }
private static final String CREATE_TABLE = "CREATE TABLE IF NOT EXISTS ";
private static final String CREATE_TABLE_DESTINATION = CREATE_TABLE + DESTINATION.TABLE_NAME + " (" 
                + DESTINATION._ID + " INTEGER PRIMARY KEY, " + DESTINATION.NAME + " TEXT );";
private static final String DATABASE_NAME = "TravelCompany";
        private static final int DATABASE_VERSION = 1;
public DBHelper(Context context) {
            super(context, DATABASE_NAME, null, DATABASE_VERSION);
        }
@Override
        public void onCreate(SQLiteDatabase db) {
            db.execSQL(CREATE_TABLE_DESTINATION);
        }
@Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            db.execSQL("DROP TABLE IF EXISTS " + DESTINATION.TABLE_NAME);
            onCreate(db);
        }
public void insertDestination(String destinationName) {
            ContentValues values = new ContentValues();
            values.put(DESTINATION.NAME, destinationName);
            getWritableDatabase().insert(DESTINATION.TABLE_NAME, null, values);
        }
public Cursor getTop10Destinations() {
            return getReadableDatabase().query(true, DESTINATION.TABLE_NAME,
                    new String[] { DESTINATION.NAME, "COUNT(" + DESTINATION.NAME + ") AS counter" }, null, null,
                    DESTINATION.NAME, null, "counter DESC", "10");
        }
    }
然后使用buttom创建第一个活动:

import android.app.Activity; <p>
import android.content.Intent; <p>
import android.os.Bundle; <p>
import android.view.View;
import android.view.View.OnClickListener;<p> 
import android.widget.Button;<p> 
import android.widget.LinearLayout;<p>

public class MainActivity extends Activity {
@Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            Button a = new Button(this);
            a.setText("!DRAW CHART!");
            this.addContentView(a, new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,
                    LinearLayout.LayoutParams.FILL_PARENT));
            a.setOnClickListener(new OnClickListener() {
@Override
                public void onClick(View v) {
                    Intent b = new Intent(MainActivity.this, ChartActivity.class);
                    startActivity(b);
}
            });
}
}
导入android.app.Activity
导入android.content.Intent
导入android.os.Bundle
导入android.view.view;
导入android.view.view.OnClickListener
导入android.widget.Button
导入android.widget.LinearLayout
公共类MainActivity扩展了活动{
@凌驾
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
按钮a=新按钮(此按钮);
a、 setText(“!绘制图表!”);
此.addContentView(a,新的LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL\U父级,
LinearLayout.LayoutParams.FILL_PARENT);
a、 setOnClickListener(新的OnClickListener(){
@凌驾
公共void onClick(视图v){
意图b=新意图(MainActivity.this、ChartActivity.class);
星触觉(b);
}
});
}
}
在按钮上单击“创建图表”活动,按类别使用自定义条形图绘制条形图:

package com.example.teaorcofee;
import java.util.Iterator;
    import java.util.LinkedHashMap;
    import java.util.Random;
import android.app.Activity;
    import android.content.Context;
    import android.database.Cursor;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.Paint;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.view.ViewGroup.LayoutParams;
    public class ChartActivity extends Activity {
    private DBHelper dbHelper = new DBHelper(this);
            private String[] desinationList = new String[] { "Australia", "Germaty", "China", "Russia", "France",
                    "UK", "USA", "Ukraine", "Moldova", "Greece", "Poland", "Brazil" };
@Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_chart);
            for (int i = 0; i < 100; i++) {
                dbHelper.insertDestination(desinationList[(int) (Math.random() * desinationList.length)]);
            }
            BarChart barChart = new BarChart(this, dbHelper.getTop10Destinations());
            addContentView(barChart, new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
        }
private static class BarChart extends View {
            private static int THING_COUNT = 10;
            private LinkedHashMap&lt;String, Integer&gt; countArray = new LinkedHashMap&lt;String, Integer&gt;();
            private Integer maxAmout = 0;
            private static final int DISTANCE_BETWEEN_SIDE_AND_Y_AXIS = 30;
            private static int DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS;
            private static final int CHART_BG_COLOR = Color.BLACK;
            private Random rnd = new Random();
public BarChart(Context context, Cursor destinationList) {
                super(context);
                for (int i = 0; i < THING_COUNT; i++) {
                    if (destinationList.moveToNext()) {
                        countArray.put(destinationList.getString(0), destinationList.getInt(1));
                        if (maxAmout < destinationList.getInt(1)) {
                            maxAmout = destinationList.getInt(1);
                        }
                    } else {
                        break;
                    }
                }
                // countArray = sortByComparator(countArray);
            }
@Override
            protected void onDraw(Canvas canvas) {
                DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS = canvas.getHeight() -70;
//set chart BG color
                canvas.drawColor(CHART_BG_COLOR);
                Paint bgPaint = new Paint();
//draw white lines of X and Y axises of 2px width
                bgPaint.setColor(0xFFFFFFFF);
                bgPaint.setStrokeWidth(2);
                canvas.drawLine(DISTANCE_BETWEEN_SIDE_AND_Y_AXIS, 0, DISTANCE_BETWEEN_SIDE_AND_Y_AXIS, canvas.getHeight(), bgPaint);
                canvas.drawLine(0, DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS, canvas.getWidth(), DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS, bgPaint);
//calulate next to max value number round number
                //for example if max value is 683, than we will get 700
                maxAmout = (int) (((int) (maxAmout / Math.pow(10, maxAmout.toString().length() - 1) + 1)) * Math
                        .pow(10, maxAmout.toString().length() - 1));
//get iterator on set of keys 
                Iterator&lt;String&gt; iterator = countArray.keySet().iterator();
                for (double i = 0; i < THING_COUNT; i++) {
//set white color
                    bgPaint.setColor(0xFFFFFFFF);
//draw text on Y axis with numbers between 0 and rounded max value - maxAmount
                    canvas.drawText("" + (int) (maxAmout * i / THING_COUNT),
                            25 - ("" + (int) (maxAmout * i / THING_COUNT)).length() * 7,
                            (int) ((DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS) * (1 - i / THING_COUNT)) + 15, bgPaint);
//get name of current item
                    String itemName = iterator.next();
//draw name of current item under its column
                    canvas.drawText(itemName.length()>3?itemName.substring(0, 3):itemName, (float) (30 + i * 28) + 5, DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS+10,
                            bgPaint);
//get random color for current item column
                    bgPaint.setARGB(255, rnd.nextInt(256), rnd.nextInt(256), rnd.nextInt(256));
//draw column of current item
                    canvas.drawRect((float) (DISTANCE_BETWEEN_SIDE_AND_Y_AXIS + i * 28) + 5, DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS,
                            (float) (DISTANCE_BETWEEN_SIDE_AND_Y_AXIS + (i + 1) * 28),
                            (int) ((DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS) * (1 - (double) countArray.get(itemName) / maxAmout)),
                            bgPaint);
                }
//draw lines parallel to X axis
                for (double i = 0; i < 10; i++) {
                    bgPaint.setStrokeWidth(1);
                    bgPaint.setColor(0x44444444);
                    canvas.drawLine(0, (int) ((DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS) * (1 - i / 10)), canvas.getWidth(),
                            (int) ((DISTANCE_BETWEEN_BOTTOM_AND_X_AXIS) * (1 - i / 10)), bgPaint);
                }
}
}
}
package com.example.teaorcofee;
导入java.util.Iterator;
导入java.util.LinkedHashMap;
导入java.util.Random;
导入android.app.Activity;
导入android.content.Context;
导入android.database.Cursor;
导入android.graphics.Canvas;
导入android.graphics.Color;
导入android.graphics.Paint;
导入android.os.Bundle;
导入android.util.Log;
导入android.view.view;
导入android.view.ViewGroup.LayoutParams;
公共类活动扩展了活动{
私有DBHelper DBHelper=newdbhelper(this);
私有字符串[]设计列表=新字符串[]{“澳大利亚”、“德国”、“中国”、“俄罗斯”、“法国”,
“英国”、“美国”、“乌克兰”、“摩尔多瓦”、“希腊”、“波兰”、“巴西”};
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_图表);
对于(int i=0;i<100;i++){
dbHelper.insertDestination(desinationList[(int)(Math.random()*desinationList.length)];
}
BarChart BarChart=新的BarChart(这个,dbHelper.getTop10Destinations());
addContentView(条形图,新的LayoutParams(LayoutParams.FILL\u父级,LayoutParams.FILL\u父级));
}
私有静态类条形图扩展视图{
私有静态整数计数=10;
私有LinkedHashMapString,Integer countArray=新LinkedHashMapString,Integer();
私有整数maxAmout=0;
_侧_和_Y_轴之间的专用静态最终整数距离_=30;
_底部_和_X_轴之间的私有静态int距离_;
私有静态最终整数图表\u BG\u COLOR=COLOR.BLACK;
私有随机rnd=新随机();
公共条形图(上下文,光标目标列表){
超级(上下文);
for(int i=0;i3?itemName.substring(0,3):itemName,(float)(30+i*28)+5,底部和X轴之间的距离+10,
bg(油漆);
//获取当前项目列的随机颜色
bgPaint.setARGB(255,rnd.nextInt(256),rnd.nextInt(256),rnd.nextInt(256));
//绘制当前项的列
帆布