ArrayList
似乎填充得很好,但无论我使用什么方法,我似乎都无法让适配器填充数据。我已经尝试添加到ArrayList
,也添加到ArrayAdapter
. 无论哪种方式,我都无法在该AutoCompleteTextView
级别或ArrayAdapter
本身上得到响应(当然,AutoCompleteTextView
它什么也没做)。任何人都可以看到有什么问题吗?
public class MainActivity extends Activity implements TextWatcher {
// private AutoCompleteView autoComplete;
public String TAG = new String("MAINACTIVITY");
public ArrayAdapter<String> autoCompleteAdapter;
public AutoCompleteTextView autoComplete;
public InputStream inputStream;
public List<String> data;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
data = new ArrayList<String>();
autoCompleteAdapter = new ArrayAdapter<String>(this,android.R.layout.simple_dropdown_item_1line, data);
autoCompleteAdapter.setNotifyOnChange(true);
autoComplete = (AutoCompleteTextView) findViewById(R.id.acsayt);
autoComplete.setHint(R.string.search_hint);
autoComplete.setThreshold(2);
autoComplete.addTextChangedListener(this);
autoComplete.setAdapter(autoCompleteAdapter);
}
// uphold TextWatcher interface methods
public void afterTextChanged(Editable s) {
}
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
public void onTextChanged(CharSequence s, int start, int before, int count) {
Log.d(TAG, "I detected a text change " + s.toString());
data.clear();
queryWebService();
}
private void queryWebService() {
new Thread(new Runnable() {
public void run() {
Log.d(TAG, "spawned thread");
// Code in here to set up http connection, query webservice ...
// parse the JSON response & add items to adapter
try {
JSONArray jArray = new JSONArray(resultString);
int length = jArray.length();
int countedValues, capturedValues;
Log.d(TAG, "response had " + length + " items");
int i = 0;
while (i < length) {
JSONObject internalObject = jArray.getJSONObject(i);
String vehicleName = internalObject.getString("name").toString();
Log.d(TAG, "vehicle name is " + vehicleName);
try {
data.add(vehicleName);
autoCompleteAdapter.add(vehicleName); // not working
} catch (Exception e) {
e.printStackTrace();
}
countedValues = data.size(); // correctly reports 20 values
capturedValues = autoCompleteAdapter.getCount(); // is zero
Log.d(TAG, "array list holds " + countedValues + " values");
Log.d(TAG, "array adapter holds " + capturedValues + " values");
i++;
}
} catch (Exception e) {
Log.d(TAG, "JSON manipulation err: " + e.toString());
}
}
}).start();
}
}
LogCat 显示来自 data.size() 的预期值数量,但来自 autoCompleteAdapter.getCount() 的值为零。