int 値の配列を作成しました。これらの int 値は、次のような描画可能な画像へのパス ID です。
int[] picItems = {R.drawable.pic_one, R.drawable.pic_two, R.drawable.pic_three};
ただし、picItem 配列は null です。次のように、インデックスから値を取得して背景として使用できるようにしたいと考えています。
relative.setBackgroundResource(picItems[index]);
たとえば、上記のコードを使用してパラメーター フィールドを R.drawable.pic_one に設定すると、機能します。しかし、int 配列 picItems を宣言してインスタンス化するたびに、nullpointerexception が発生します。私は何かを見て単純な間違いを犯しているに違いありませんが、もしそうなら、遠慮なく指摘してください。どんな助けにも感謝します、ありがとう!
編集:配列を宣言してインスタンス化するさまざまな方法を試しました。また、配列はインスタンス化した後でもnullですが、使用しようとするとエラーが発生します(ifステートメントを使用してキャッチしました)。もう少しコードがあります:
public class Snow extends Activity{
int[] picItems;
RelativeLayout relative;
SharedPreferences sp;
int checkedItem = 0;
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
picItems = new int[]{R.drawable.pic_one, R.drawable.pic_two, R.drawable.pic_three};
sp = getPreferences(MODE_PRIVATE);
checkedItem = sp.getInt("picture", 0);
if (!(picItems == null) || !(picItems.equals(null))){
Toast.makeText(getApplicationContext(), "Array is null for some reason", Toast.LENGTH_SHORT).show();
}else{
relative.setBackgroundResource(picItems[checkedItem]);
}//end of if
...} ...}
Logcat の出力は次のとおりです。
11-20 19:00:27.363: E/AndroidRuntime(18311): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.app.Snow/com.app.snow.Snow}: java.lang.NullPointerException
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1821)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1842)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.ActivityThread.access$1500(ActivityThread.java:132)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1038)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.os.Handler.dispatchMessage(Handler.java:99)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.os.Looper.loop(Looper.java:150)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.ActivityThread.main(ActivityThread.java:4263)
11-20 19:00:27.363: E/AndroidRuntime(18311): at java.lang.reflect.Method.invokeNative(Native Method)
11-20 19:00:27.363: E/AndroidRuntime(18311): at java.lang.reflect.Method.invoke(Method.java:507)
11-20 19:00:27.363: E/AndroidRuntime(18311): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
11-20 19:00:27.363: E/AndroidRuntime(18311): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
11-20 19:00:27.363: E/AndroidRuntime(18311): at dalvik.system.NativeStart.main(Native Method)
11-20 19:00:27.363: E/AndroidRuntime(18311): Caused by: java.lang.NullPointerException
11-20 19:00:27.363: E/AndroidRuntime(18311): at com.app.snow.Snow.onCreate(Snow.java:54)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1072)
11-20 19:00:27.363: E/AndroidRuntime(18311): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1785)