1. 程式人生 > >控制元件以及介面卡

控制元件以及介面卡

MultiAutoCompleteTextView是Android中的自動提示文字框,可以多次提示,提示之間用分隔符隔開,控制元件預設的分隔符為逗號,有時我們需要根據實際來指定其他分隔符。

    AutoCompleteTextView(單一提示)與MultiAutoCompleteTextView(多次提示)的異同: AutoCompleteTextView:支援基本的自動完成功能,適用在各種搜尋功能中,並且可以根據自己的需求設定他的預設顯示資料;MultiAutoCompleteTextView: 可支援選擇多個值(在多次輸入的情況下),分別用分隔符分開,並且在每個值選中的時候再次輸入值時會自動去匹配。可用在發簡訊,發郵件時選擇聯絡人這種型別當中。

activity_main.xml裡的程式碼(佈局)如下:

<?xml version="1.0" encoding="utf-8"?>
<MultiAutoCompleteTextView
    android:id="@+id/mact_main_content"
    android:layout_width="match_parent"
    android:completionThreshold="1"
    android:layout_height="wrap_content" />
注:android:completionThreshold="1"的意思是從輸入第一個字就開始提示

MainActivity裡的程式碼如下: public class MainActivity extends AppCompatActivity { private String[] data1;//資料來源 private ArrayAdapter adapter1;//陣列介面卡 private MultiAutoCompleteTextView mact_main_content;//自動提示文字框

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    //根據ID獲取到自動提示文字框並賦值給mact_main_content
    mact_main_content=findViewById(R.id.mact_main_content);

    MultiAutoCompleteTextView.Tokenizer t = new MultiAutoCompleteTextView.CommaTokenizer();
    mact_main_content.setTokenizer(t);
    //呼叫SemicolonTokenizer的構造方法給自動提示文字框指定分隔符
    mact_main_content.setTokenizer(new SemicolonTokenizer(';'));

// 1、獲取資料 data1=new String[]{ “憤怒的小鳥”, “湯姆貓”, “落湯雞”, “牛牛”, “哈巴狗”, “神龍”, “烤鴨”,“小象”, “美人魚”, “九尾狐” }; // 2、建立介面卡 adapter1=new ArrayAdapter(this,R.layout.act_main_item ,data1); // 3、繫結介面卡 mact_main_content.setAdapter(adapter1);

} 給自動提示文字框指定分隔符還需要新建一個SemicolonTokenizer類,程式碼如下:

public class SemicolonTokenizer implements MultiAutoCompleteTextView.Tokenizer { private char charS; private String mSTring;

//構造方法
public SemicolonTokenizer(char charS) {
    this.charS = charS;
    mSTring = String.valueOf(charS);
}

public int findTokenStart(CharSequence text, int cursor) {
    int i = cursor;
    while (i > 0 && text.charAt(i - 1) != charS) {
        i--;
    }
    while (i < cursor && text.charAt(i) == ' ') {
        i++;
    }
    return i;
}

public int findTokenEnd(CharSequence text, int cursor) {
    int i = cursor;
    int len = text.length();
    while (i < len) {
        if (text.charAt(i) == charS) {
            return i;
        } else {
            i++;
        }
    }
    return len;
}

public CharSequence terminateToken(CharSequence text) {
    int i = text.length();
    while (i > 0 && text.charAt(i - 1) == ' ') {
        i--;
    }

    if (i > 0 && text.charAt(i - 1) == charS) {
        return text;
    } else {
        if (text instanceof Spanned) {
            SpannableString sp = new SpannableString(text + mSTring);
            TextUtils.copySpansFrom((Spanned) text, 0, text.length(), Object.class, sp, 0);
            return sp;
        } else {
            return text + mSTring;
        }
    }
}

}