尝试将背景颜色设置为一个特定行时,ListView上的NPE。

时间:2013-09-23 04:57:07

标签: android android-listview

我有一个listView和一个处理程序以及一个媒体播放器。列表视图由String数组支持,该数组包含歌词的经文。现在随着歌曲的进展,我希望当时的特定行与歌词成为列表中的第一个视图并突出显示。我在处理程序中有以下代码:

public void run(){
                        int X = mediaPlayer.getCurrentPosition();
                        S1.setText(""+X);
                        setProgressText();
                        seek_bar.setProgress(mediaPlayer.getCurrentPosition());
                            if(mediaPlayer.getCurrentPosition()/1000 > 0 && mediaPlayer.getCurrentPosition()/1000 < 20){
                            listView.smoothScrollToPosition(3);
                            View element = listView.getChildAt(3);
                            element.setBackgroundColor(Color.YELLOW);

                        }else if(mediaPlayer.getCurrentPosition()/1000 > 20 && mediaPlayer.getCurrentPosition()/1000 < 54){
                            listView.smoothScrollToPosition(4);
                            View element = listView.getChildAt(4);
                            element.setBackgroundColor(Color.YELLOW);


                System.out.println("2 if");

第一个if条件执行得非常好,但是在第二个if条件下我得到一个NPE。

这是我的Log Cat:

09-23 10:13:22.237: E/AndroidRuntime(307): FATAL EXCEPTION: main
09-23 10:13:22.237: E/AndroidRuntime(307): java.lang.NullPointerException
09-23 10:13:22.237: E/AndroidRuntime(307):  at com.mobiligent.stotram.MainActivity$1$2.run(MainActivity.java:183)
09-23 10:13:22.237: E/AndroidRuntime(307):  at android.os.Handler.handleCallback(Handler.java:587)
09-23 10:13:22.237: E/AndroidRuntime(307):  at android.os.Handler.dispatchMessage(Handler.java:92)
09-23 10:13:22.237: E/AndroidRuntime(307):  at android.os.Looper.loop(Looper.java:123)
09-23 10:13:22.237: E/AndroidRuntime(307):  at android.app.ActivityThread.main(ActivityThread.java:4627)
09-23 10:13:22.237: E/AndroidRuntime(307):  at java.lang.reflect.Method.invokeNative(Native Method)
09-23 10:13:22.237: E/AndroidRuntime(307):  at java.lang.reflect.Method.invoke(Method.java:521)
09-23 10:13:22.237: E/AndroidRuntime(307):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
09-23 10:13:22.237: E/AndroidRuntime(307):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
09-23 10:13:22.237: E/AndroidRuntime(307):  at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分:0)

getChildAt(4)返回null,因为getChildCount()返回&lt; = 4,检查出来