2

aSyncTask を繰り返し呼び出してグラフを継続的に更新するコードを書いています。しかし、グラフが圧縮されすぎないようにするために、ポイントを超えて最も古いエントリを削除/削除する予定です。現在、私のコードは次のとおりです。

int counter = 0;
private class UpdateLineGraphAsync extends AsyncTask<Void, Void, Void> {

    @Override
    protected Void doInBackground(Void... params) {
        // add the next series value
        series.add(counter, Math.sin((double) counter / 100));
        counter += 20;
        if (counter > 500)
            series.remove(0);
        return null;
    }

    @Override
    protected void onPostExecute(Void result) {
        // TODO Auto-generated method stub
        super.onPostExecute(result);
        ((GraphicalView) lineGraph).repaint(); // repaints the graph!
    }

}

しかし、このコードでは、 remove(0); を呼び出すと、ヌル ポイント例外が発生し続けます。関数 XYSeries.remove(index) の仕組みを説明できる人はいますか? LIFO構造だとどこかで読みました。これは本当ですか?このエラーを修正するにはどうすればよいですか? remove 関数を 1 回呼び出すだけでもエラーが発生します。

エラーコードは次のとおりです。

07-03 17:27:36.080: E/AndroidRuntime(1229): FATAL EXCEPTION: AsyncTask #2
07-03 17:27:36.080: E/AndroidRuntime(1229): java.lang.RuntimeException: An error occured while executing doInBackground()
07-03 17:27:36.080: E/AndroidRuntime(1229):     at android.os.AsyncTask$3.done(AsyncTask.java:200)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:274)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.FutureTask.setException(FutureTask.java:125)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:308)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.lang.Thread.run(Thread.java:1027)
07-03 17:27:36.080: E/AndroidRuntime(1229): Caused by: java.lang.NullPointerException
07-03 17:27:36.080: E/AndroidRuntime(1229):     at org.achartengine.model.XYSeries.getY(XYSeries.java:169)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at org.achartengine.model.XYSeries.initRange(XYSeries.java:83)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at org.achartengine.model.XYSeries.remove(XYSeries.java:140)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at com.clearbridgevitalsigns.cardioleaf.LiveView$UpdateLineGraphAsync.doInBackground(LiveView.java:121)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at com.clearbridgevitalsigns.cardioleaf.LiveView$UpdateLineGraphAsync.doInBackground(LiveView.java:1)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
07-03 17:27:36.080: E/AndroidRuntime(1229):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
07-03 17:27:36.080: E/AndroidRuntime(1229):     ... 4 more
4

3 に答える 3

2

私は以前同じ問題を抱えていました。理由はわかりませんでしたが、achartengineからの系列データへの同時アクセスが原因だと思います。シリーズ自体で作業せずに、renderer.setXAxisMinとrenderer.setXAxisMaxを使用して、別の方法でディスプレイを移動することで、この問題を回避することができました。

于 2012-10-30T09:56:37.170 に答える
0

この NullPointerException は series.remove(0) ステートメントによるものではないと思います。私のプロトタイプでは問題なく動作します。私の見解では、XYMultipleSeriesDataset に XYSeries を追加する必要があります。たとえば、このリンクを参照してください。

于 2012-07-03T10:20:52.990 に答える
0

コレクションが制限を超える場合は、最初に 0 番目の要素を削除してから、新しい要素を追加してみてください。

于 2012-07-03T09:23:13.343 に答える