Android   发布时间:2022-04-28  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了android中的自动完成功能无法使用动态数据大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我在 Android中面临自动完成的问题.我试图在匹配的每个按键上动态地从其他应用程序读取数据,而不是在Activity本身中对数据进行硬编码.请在下面找到我的程序,并建议我在哪里错了.

注意:在第一次按键时,结果将被填充.之后,如果我清除输入的文本并输入不同的字符,结果将不会显示自动完成下拉框中.我在每次按键时从其他应用程序获取,但没有填充在自动完成下拉框中.

我尝试使用textView.showDropDown();和adapter.setNotifyOnChange(true);选项.但没用.

package com.util;

import java.io.bufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

import org.apache.http.httpentity;
import org.apache.http.httpResponse;
import org.apache.http.StatusLine;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.httpClient;
import org.apache.http.client.methods.httpGet;
import org.apache.http.impl.client.DefaulthttpClient;
import org.json.JSONArray;
import org.json.JSONObject;

import android.app.Activity;
import android.os.bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.Log;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;

public class HelloAutoCompleteActivity extends Activity {
List countries = new ArrayList();
    String url = ""; //some application url
AutoCompleteTextView textView;
ArrayAdapter<String> adapter;

@Override
public void onCreate(Bundle savedInstanceStatE) {
    super.onCreate(savedInstanceStatE);
    setContentView(R.layout.main);
    textView = (AutoCompleteTextView) findViewById(R.id.autocomplete_country);
    textView.addTextChangedListener(new CostomTextWatcher());
    textView.setThreshold(1);
    adapter = new ArrayAdapter<String>(this,R.layout.list_item,countries);
    textView.setAdapter(adapter);
}

private class CostomTextWatcher implements TextWatcher {

    @Override
    public void afterTextChanged(Editable s) {
    }

    @Override
    public void beforeTextChanged(CharSequence s,int start,int count,int after) {
    }

    @Override
    public void ontextChanged(CharSequence s,int before,int count) {
        if (s.length() > 0) {
            countries.clear();
            String readTwitterFeed = readFeed(s.toString());
            System.out.println(readTwitterFeed);
            try {
                JSONObject menuObject = new JSONObject(readTwitterFeed);
                JSONArray menuitemArray = menuObject
                        .getJSONArray("objectNameList");
                for (int i = 0; i < menuitemArray.length(); i++) {
                    System.out.println(menuitemArray.get(i));
                    countries.add(menuitemArray.get(i).toString());
                }
                // adapter.notifyDataSetChanged();
                // adapter.setNotifyOnChange(true);
                // textView.setAdapter(adapter);
                // textView.setThreshold(1);
                // textView.setAdapter(adapter);
                // textView.showDropDown();
                // adapter.setNotifyOnChange(true);
            } catch (Exception E) {
                e.printStackTrace();
            }
        }
    }
}

public String readFeed(String val) {

    StringBuilder builder = new StringBuilder();
    httpClient client = new DefaulthttpClient();
    httpGet httpGet = new httpGet(
            url);
    try {
        httpResponse response = client.execute(httpGet);
        StatusLine statusLine = response.getStatusLine();
        int statusCode = statusLine.getStatusCode();
        if (statusCode == 200) {
            System.out.println("200");
            httpentity entity = response.getEntity();
            InputStream content = entity.getContent();
            BufferedReader reader = new BufferedReader(
                    new InputStreamReader(content));
            String line;
            while ((line = reader.readLine()) != null) {
                builder.append(linE);
            }
        } else {
            System.out.println("else block");
            Log.e(HelloAutoCompleteActivity.class.toString(),"Failed to download file");
        }
    } catch (ClientProtocolException E) {
        e.printStackTrace();
    } catch (IOException E) {
        e.printStackTrace();
    }
    return builder.toString();
}

}

解决方法

您也可以使用Filter接口来实现此功能.事实证明,Filter.performFiltering()仅在此类目的的情况下从UI线程调用.以下是我用来执行此操作的一些代码

Filter filter = new Filter() {

    @Override
    public CharSequence convertResultToString(Object resultvalue) {
        return resultValue.toString();
    }

    @Override
    protected FilterResults performFiltering(CharSequence charSequencE) {
        if( charSequence == null ) return null;
        try {
            // This call hits the server with the name I'm looking for and parses the JSON returned for the first 25 results
            PagedResult results = searchByName( charSequence.toString(),1,25,truE);
            FilterResults filterResults = new FilterResults();
            filterResults.values = results.getResults();
            filterResults.count = results.getResults().size();
            return filterResults;
        } catch (JSONException E) {
            return new FilterResults();
        }
    }

    @Override
    protected void publishResults(CharSequence charSequence,FilterResults filterResults) {
        if( filterResults != null ) {
            adapter.clear();
            adapter.addAll( (List<MyObject>)filterResults.values );
        }
    }
};

然后使用Filter:

private AutoCompleteTextView beveragename;
    ...

    beveragename = findViewById( R.id.beveragename );
    listadapter adapter = ...
    adapter.setFilter(filter);
    beveragename.setAdapter(adapter);

或者你也可以使用这个链接

http://www.grobmeier.de/android-autocomplete-with-json-data-served-by-struts-2-05122011.html

大佬总结

以上是大佬教程为你收集整理的android中的自动完成功能无法使用动态数据全部内容,希望文章能够帮你解决android中的自动完成功能无法使用动态数据所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。