我有一個database
充滿了某些值,我想知道我怎麼能把它們放在spinner
。我有一個名爲SetSql
的類,它包含我所有的數據庫函數,並在其中包含一個名爲getProfiles()
的函數,它返回String Array
。現在,我的頁面上還有一個spinner
,其ID爲spinner1
,我想知道如何從該getProfiles()
函數中填充它?Android - 從動態返回數組的數據庫函數填充微調器
另外我必須注意,數據庫中的項目數目是未知的,並且範圍從0到幾乎任何事物。
謝謝!
我的努力
SetSql getprofiles = new SetSql(this);
getprofiles.open();
if(getprofiles.getProfiles().length>0){
spinnerArray = new String[100];
spinnerArray = getprofiles.getProfiles();
}else{
spinnerArray = new String[1];
spinnerArray[0] = "No Profiles, Please Create One";
}
getprofiles.close();
ArrayAdapter<String> array = new ArrayAdapter<String>(UserActivity.this, android.R.layout.simple_spinner_item, spinnerArray);
array.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
profiles.setAdapter(array);
我getProfiles()
public String[] getProfiles() throws SQLException{
String[] columns = new String[]{KEY_USER};
Cursor c = ourDatabase.query(TABLE_USERS, columns, null, null, null, null, KEY_ROWID);
String[] result = new String[100];
int iName = c.getColumnIndex(KEY_USER);
int count = 0;
for(c.moveToFirst(); !c.isAfterLast(); c.moveToNext()){
result[count] = c.getString(iName);
count++;
}
return result;
}
請記住,這個函數是一個類的一部分,所以有些瓦爾像KEY_Xs和我們的數據庫不在這裏。
logcat的
03-07 23:03:25.691: E/AndroidRuntime(10791): FATAL EXCEPTION: main
03-07 23:03:25.691: E/AndroidRuntime(10791): java.lang.NullPointerException
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.ArrayAdapter.createViewFromResource(ArrayAdapter.java:355)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.ArrayAdapter.getView(ArrayAdapter.java:323)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.AbsSpinner.onMeasure(AbsSpinner.java:192)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.View.measure(View.java:8313)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3138)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1017)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.LinearLayout.measureVertical(LinearLayout.java:386)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.LinearLayout.onMeasure(LinearLayout.java:309)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.View.measure(View.java:8313)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3138)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.FrameLayout.onMeasure(FrameLayout.java:250)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.View.measure(View.java:8313)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3138)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.widget.FrameLayout.onMeasure(FrameLayout.java:250)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.View.measure(View.java:8313)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.ViewRoot.performTraversals(ViewRoot.java:839)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.view.ViewRoot.handleMessage(ViewRoot.java:1859)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.os.Handler.dispatchMessage(Handler.java:99)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.os.Looper.loop(Looper.java:130)
03-07 23:03:25.691: E/AndroidRuntime(10791): at android.app.ActivityThread.main(ActivityThread.java:3683)
03-07 23:03:25.691: E/AndroidRuntime(10791): at java.lang.reflect.Method.invokeNative(Native Method)
03-07 23:03:25.691: E/AndroidRuntime(10791): at java.lang.reflect.Method.invoke(Method.java:507)
03-07 23:03:25.691: E/AndroidRuntime(10791): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-07 23:03:25.691: E/AndroidRuntime(10791): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-07 23:03:25.691: E/AndroidRuntime(10791): at dalvik.system.NativeStart.main(Native Method)
如果你有任何想法,爲什麼這應該崩潰,我很想聽到:d
一些善良的人幫我找到答案,在這裏的線程: http://stackoverflow.com/questions/15272473/android-spinner-crashing-when-clicked-on?noredirect=1#comment21583370_15272473 – arielschon12 2013-03-08 17:27:57