Android-从动态返回数组的数据库函数填充微调器

Android-从动态返回数组的数据库函数填充微调器,android,arrays,sqlite,spinner,Android,Arrays,Sqlite,Spinner,我有一个数据库中填充了某些值,我想知道如何将它们放入微调器。我有一个名为SetSql的类,它保存了我所有的数据库函数,还有一个名为getProfiles()的函数,它返回一个字符串数组。现在,我的页面上还有一个id为spinner1的微调器,我想知道如何从getProfiles()函数中填充它 我还必须注意,数据库中的项目数未知,可能从0到几乎任何值 谢谢 我的努力 SetSql getprofiles = new SetSql(this); getprofiles.open(

我有一个
数据库
中填充了某些值,我想知道如何将它们放入
微调器
。我有一个名为
SetSql
的类,它保存了我所有的数据库函数,还有一个名为
getProfiles()
的函数,它返回一个
字符串数组。现在,我的页面上还有一个id为
spinner1
微调器,我想知道如何从
getProfiles()
函数中填充它

我还必须注意,数据库中的项目数未知,可能从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);
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;
}
请记住,此函数是类的一部分,因此一些变量(如keyxs和ourDatabase)不在这里

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

试试这样的方法:

String[] myArray = {"some","values"};

Spinner spin = (Spinner)findViewById(R.id.spinner1);

ArrayAdapter<String> adapter = new ArrayAdapter(this,android.R.layout.simple_spinner_dropdown_item,myArray);

spin.setAdapter(adapter);
String[]myArray={“一些”,“值”};
微调器旋转=(微调器)findViewById(R.id.spinner1);
ArrayAdapter=新的ArrayAdapter(这个,android.R.layout.simple\u spinner\u dropdown\u项目,myArray);
spin.setAdapter(适配器);

您也可以使用
列表
而不是
字符串[]

请查看我的源代码。你知道为什么会崩溃吗?只是在黑暗中拍摄,但是你初始化了“轮廓”微调器了吗?编辑:不管怎样,我建议调试你的应用程序,在你想要的地方添加一些断点。另外,尝试使用一个简单的数组删除DB部分,看看它是否崩溃。还尝试使用DB部分,不使用微调器,并查看它是否崩溃,等等。微调器已初始化,并且使用已填充的数组,就像您所做的那样,肯定可以工作。我将尝试调试,但请查看是否可以找到任何其他可能的错误:)使用调试器未显示任何异常。。再说一遍,我不熟悉这个调试器,也不知道如何使用它。您的SpinNerray为null。看看某个好心人帮我找到了答案,在这里: