0

これは、Android プロジェクト用です。私はすべて正常に動作するスピナーを構築するために配列を使用しています。ただし、ページの読み込み時にオプションが選択されないように、配列の先頭にレコードを追加しようとしています。

myarray.add("---")タイプのものを使用しようとしていますが、次のエラーで失敗します:

11-05 10:50:36.995: D/AndroidRuntime(16763): Shutting down VM
11-05 10:50:36.995: W/dalvikvm(16763): threadid=1: thread exiting with uncaught exception (group=0x412b42a0)
11-05 10:50:37.000: E/AndroidRuntime(16763): FATAL EXCEPTION: main
11-05 10:50:37.000: E/AndroidRuntime(16763): java.lang.NullPointerException
11-05 10:50:37.000: E/AndroidRuntime(16763):    at com.directenquiries.assessment.tool.AddAsset.updateLocalDesc(AddAsset.java:461)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at com.directenquiries.assessment.tool.AddAsset$3.onItemSelected(AddAsset.java:262)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.widget.AdapterView.fireOnSelected(AdapterView.java:892)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.widget.AdapterView.access$200(AdapterView.java:49)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.widget.AdapterView$SelectionNotifier.run(AdapterView.java:860)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.os.Handler.handleCallback(Handler.java:615)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.os.Handler.dispatchMessage(Handler.java:92)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.os.Looper.loop(Looper.java:137)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at android.app.ActivityThread.main(ActivityThread.java:4898)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at java.lang.reflect.Method.invokeNative(Native Method)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at java.lang.reflect.Method.invoke(Method.java:511)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
11-05 10:50:37.000: E/AndroidRuntime(16763):    at dalvik.system.NativeStart.main(Native Method)
11-05 10:50:37.020: D/dalvikvm(16763): GC_CONCURRENT freed 243K, 7% free 12989K/13831K, paused 1ms+3ms, total 25ms

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

 public void setupAssetType(Boolean beenSet){
         Log.e("CamDebug", "Loading asset type");
           Cursor c = db.rawQuery("select * from AssetTypes", null);  
           Log.e("Error Tracking", "Loading AssetTypes");
           if(c.getCount() != 0) {
             c.moveToFirst();
             final ArrayList<String> mAssetType = new ArrayList<String>();
             final ArrayList<String> mTypeID= new ArrayList<String>();


               c.moveToFirst();
               mAssetType.add("TEST");
               mTypeID.add("TEST");
               while(!c.isAfterLast()) {
                    mAssetType.add(c.getString(c.getColumnIndex("AssetType")));
                    mTypeID.add(c.getString(c.getColumnIndex("AssetTypeID")));
                    c.moveToNext();
               }

                ArrayAdapter<String> spinnerArrayAdapter = new ArrayAdapter<String>(this,   android.R.layout.simple_spinner_item, mAssetType);
                spinnerArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); 
                spnAssetType.setAdapter(spinnerArrayAdapter);
                int count = 0;
                if(beenSet == true) {
                    for (String mID : mTypeID) {

                        Log.e("Set asset type", mID);
                        if(mID.equals(orAssetTypeID)){
                            spnAssetType.setSelection(count);
                            Log.e("Set asset type FOUND", mID);
                            break;
                        }
                        count++;
                        }   
                    }
                    c.close();            
                spnAssetType.setOnItemSelectedListener(new OnItemSelectedListener() {

                    @Override
                public void onItemSelected(AdapterView<?> parentView, View selectedItemView, int position, long id) {
                     Log.e("CamDebug", "Selected asset type");
                        if(mAssetType.size() > 0){
                            setupGroup(mTypeID.get(position), false);   
                            AssetType = mTypeID.get(position);
                            updateLocalDesc();
                            Log.e("Error Tracking", "Before Asset Type set");
                            if(mTypeID.get(position) != null) {
                                AssetTypeID = mTypeID.get(position);
                                } else {
                                    AssetTypeID = "";
                                }
                            Log.e("Error Tracking", "After As");
                        }   
                }

                @Override
                public void onNothingSelected(AdapterView<?> parentView) {

                }

            });

           }
    }

ご覧のとおり、次のように追加しました。

mAssetType.add("TEST");
mTypeID.add("TEST");

テストする。しかし、それは機能していません。どんなアイデアでも大歓迎です。

編集: 461 行目は次のとおりです。 AssetGroup = spnAssetGroup.getSelectedItem().toString();

EDIT 2 - 理由を言わずに反対票を投じないでください。それは決して生産的ではありません

編集 3エラーが発生しているようです。このブロックには 461 のようなものが含まれており、テキスト スピナーから 1 行にテキストを作成するために使用されます。

public void updateLocalDesc(){

    AssetType = spnAssetType.getSelectedItem().toString();
    AssetGroup = spnAssetGroup.getSelectedItem().toString();

   if(spnAssetSubGroup.getSelectedItem() != null && !spnAssetSubGroup.getSelectedItem().toString().equals("")){
       AssetSubGroup = spnAssetSubGroup.getSelectedItem().toString();
       tbLongDescription.setText(AssetType + "-" + AssetGroup + "-" + AssetSubGroup);
   } else
   {
       tbLongDescription.setText(AssetType + "-" + AssetGroup);
   }

}
4

2 に答える 2

0

461行目は

mAssetType.add(c.getString(c.getColumnIndex("AssetType")));

NullPointerはから来ている必要があります

c.getString()

カーソルのAndroid javadocsを確認してください

列が見つからない場合、c.getColumnIndex("AssetType") は -1 を返すため、c.getString() は NullPointerException をスローします。

その行を 3 行に分割してデバッグし、問題を正確に見つける必要があります。

于 2012-11-05T11:08:00.970 に答える
0

私はそれを解決しました。配列に何も渡していないとき、2 番目のカーソルは 0 として戻ってきました。そのため、説明領域のテキストを設定しようとすると、null で空でした。

public void updateLocalDesc(){

    if(spnAssetType.getSelectedItem() != null){
          AssetType = spnAssetType.getSelectedItem().toString(); 
    } else {
        AssetType = " ";
    }

    if(spnAssetGroup.getSelectedItem() != null){
        AssetGroup = spnAssetGroup.getSelectedItem().toString();
    } else {
        AssetGroup = " ";
    }
   AssetType = spnAssetType.getSelectedItem().toString();     


       if(spnAssetSubGroup.getSelectedItem() != null && !spnAssetSubGroup.getSelectedItem().toString().equals("")){
           AssetSubGroup = spnAssetSubGroup.getSelectedItem().toString();
           tbLongDescription.setText(AssetType + "-" + AssetGroup + "-" + AssetSubGroup);
       } else
       {
           tbLongDescription.setText(AssetType + "-" + AssetGroup);
       }

}

修正しました

于 2012-11-05T13:12:29.737 に答える