Android——(高階控制元件下拉框與搜尋框)
1. 高階控制元件與低階控制元件區別
是否使用介面卡
2. 介面卡種類和作用
2.1 種類
陣列介面卡 ArrayAdapter
new ArrayAdapter<String>(this,R.layout.actv_style, names);
簡單介面卡 SimpleAdapter
也叫“並不簡單的簡單介面卡”^_^
自定義介面卡
2.2 作用
橋樑
展示
3. 高階控制元件使用步驟
3.1 獲取資料
3.2 建立介面卡
3.3 繫結介面卡
4. 自動提示文字框
4.1 AutoCompleteTextView(單一提示)
android:completionThreshold="1"——設定多少字開始提示,預設為2.
4.2 MultiAutoCompleteTextView(多次提示)--作業
//設定多次提示時,設定分隔符方法
MultiAutoCompleteTextView.Tokenizer t = new MultiAutoCompleteTextView.CommaTokenizer();
mactv_main.setTokenizer(t);
4.3 兩種自動提示文字框的異同
AutoCompleteTextView:支援基本的自動完成功能,適用在各種搜尋功能中,並且可以根據自己的需求設定他的預設顯示資料
程式碼:
https://blog.csdn.net/waz929/article/details/83502582
MultiAutoCompleteTextView: 可支援選擇多個值(在多次輸入的情況下),分別用分隔符分開,並且在每個值選中的時候再次輸入值時會自動去匹配。
程式碼:
https://blog.csdn.net/waz929/article/details/83502737
可用在發簡訊,發郵件時選擇聯絡人這種型別當中。
5. 下拉框
Spinner
package com.example.android_06;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.MultiAutoCompleteTextView;
import android.widget.SimpleAdapter;
import android.widget.Spinner;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MainActivity extends AppCompatActivity {
// 高階控制元件下拉框
private List<Option> data2 = new ArrayList<>();
private ArrayAdapter adapter2;
private Spinner spinner_main_img;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
/**
* 高階控制元件下拉框
*/
// 初始化
loadData2();
adapter2 = new ArrayAdapter(this,R.layout.actv_main_item1,data2);
spinner_main_img.setAdapter(adapter2);
}
/**
* 高階控制元件下拉框
* 偽造資料
*/
private void loadData2() {
List<Map<String,String>> list=new ArrayList<>();
Map<String,String > map;
for (int i=0;i<6;i++){
map = new HashMap();
map.put("bookId",i+"");
map.put("bookName","傻逼"+i+"號");
list.add(map);
}
for (Map<String, String> map2 : list) {
data2.add(new Option(map2.get("bookId"),map2.get("bookName")));
}
}
/**
* 初始化
*/
public void initView(){
spinner_main_img = findViewById(R.id.spinner_main_img);
}
/**
* 獲取下拉框的值
* @param view
*/
public void getContext(View view) {
Option selectedItem = (Option) spinner_main_img.getSelectedItem();
Toast.makeText(this, selectedItem.getValue(), Toast.LENGTH_SHORT).show();
}
class Option {
private String value;
private String html;
public String getValue() {
return value;
}
public String getHtml() {
return html;
}
public void setValue(String value) {
this.value = value;
}
public void setHtml(String html) {
this.html = html;
}
@Override
public String toString() {
return html;
}
public Option(String value, String html) {
this.value = value;
this.html = html;
}
}
}
6.簡單控制元件
下拉框圖片加描述