Android开发04—Android常用高级控件(下)
Android开发04—Android常用高级控件(上)
Android开发04—Android常用高级控件(上)
1. 自动完成文本框
AutoCompleteTextView类继承自EditText类。自动完成文本框的外观与文本框没什么区别,只是当用户输入某些文字时,会自动出现下拉菜单显示与输入文字相关的信息。
自动完成文本框可以在XML文件中使用属性进行设置,也可以在Java代码中通过方法进行设置。
实例:
main.xml:
Activity:
2. 滚动视图
ScrollView类继承自FrameLayout类。ScrollView其实是一个帧布局,一般情况下,其中的控件是按照线性进行布局的,用户可以对其进行滚动。
ScrollView既可以在XML中配置也可在Java代码中进行配置。
ScrollView的使用方法比较简单,只需要将需要滚动的控件添加到ScrollView中即可。ScrollView同一时刻只能包含一个View。
具体方法:
3. 列表视图
ListView类是一种列表视图,将ListAdapter所提供的各个控件显示在一个垂直且可以滚动的列表中。
该类使用方法简单,只需要先初始化所需要得数据,然后创建适配器并将其设置给ListView,ListView便将信息以列表的形式显示到页面中。
使用案例:
string.xml
colors.xml
Activity:
GridView类同样位于android.widget包下。该视图将其空间以二维格式显示到表格中,而这些控件全部来自于ListAdapter适配器。
strings.xml
colors.xml
Android开发04—Android常用高级控件(上)
1. 自动完成文本框
AutoCompleteTextView类继承自EditText类。自动完成文本框的外观与文本框没什么区别,只是当用户输入某些文字时,会自动出现下拉菜单显示与输入文字相关的信息。
自动完成文本框可以在XML文件中使用属性进行设置,也可以在Java代码中通过方法进行设置。
实例:
main.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:id="@+id/linearLayout1"> <AutoCompleteTextView android:text="AutoCompleteTextView" android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/autoCompleteTextView1"></AutoCompleteTextView> </LinearLayout>
Activity:
package qijia.si; import android.app.Activity; import android.graphics.drawable.AnimationDrawable; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.ArrayAdapter; import android.widget.AutoCompleteTextView; import android.widget.Button; import android.widget.ImageView; public class MyAndroidProject extends Activity { private static final String[] myStr = new String[]{ "aaa","bbb","ccc","aab","aac","aad" }; //常量数组用于提示 /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); ArrayAdapter<String> aa = new ArrayAdapter<String>( this, android.R.layout.simple_dropdown_item_1line, myStr );//使用适配器 AutoCompleteTextView myAuto = (AutoCompleteTextView) findViewById(R.id.autoCompleteTextView1); myAuto.setAdapter(aa); myAuto.setThreshold(1); } }
2. 滚动视图
ScrollView类继承自FrameLayout类。ScrollView其实是一个帧布局,一般情况下,其中的控件是按照线性进行布局的,用户可以对其进行滚动。
ScrollView既可以在XML中配置也可在Java代码中进行配置。
ScrollView的使用方法比较简单,只需要将需要滚动的控件添加到ScrollView中即可。ScrollView同一时刻只能包含一个View。
具体方法:
package qijia.si; import android.app.Activity; import android.graphics.drawable.AnimationDrawable; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.ArrayAdapter; import android.widget.AutoCompleteTextView; import android.widget.Button; import android.widget.ImageView; import android.widget.ScrollView; import android.widget.TextView; public class MyAndroidProject extends Activity { ScrollView scrollView; String msg = "我是字符串,我很长很长!我是字符串,我很长很长!"; String str = ""; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); scrollView = new ScrollView(this); TextView tv = new TextView(this); tv.setTextSize(23); for(int i = 0;i<10;i++){ str = str + msg; } tv.setText(str); scrollView.addView(tv); setContentView(scrollView); } }
3. 列表视图
ListView类是一种列表视图,将ListAdapter所提供的各个控件显示在一个垂直且可以滚动的列表中。
该类使用方法简单,只需要先初始化所需要得数据,然后创建适配器并将其设置给ListView,ListView便将信息以列表的形式显示到页面中。
使用案例:
string.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="app_name">AbsoluteExample</string> <string name="hello">您选择了</string> <string name="andy">Andy Rubin \nAndroid的创造者之一</string> <string name="Bill">Bill Joy \nJava创造者之一</string> <string name="edgar">Edgar F. Codd \n关系数据库之父</string> <string name="torvalds">Linus Torvalds \nLinux之父</string> <string name="turing">Turing Alan \nIT的祖师爷</string> <string name="ys">您选择了</string> </resources>
colors.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <color name="white">#ffffff</color> <color name="red">#ff0000</color> <color name="black">#000000</color> <color name="green">#00ff00</color> <color name="gray">#050505</color> <color name="blue">#0000ff</color> </resources>main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:id="@+id/linearLayout1" android:layout_width="fill_parent" android:layout_height="fill_parent"> <TextView android:layout_height="wrap_content" android:id="@+id/textView1" android:layout_width="fill_parent" android:textSize="24dip" android:textColor="@color/white" android:text="@string/hello"></TextView> <ListView android:layout_height="wrap_content" android:layout_width="fill_parent" android:id="@+id/listView1" android:choiceMode="singleChoice"></ListView> </LinearLayout>
Activity:
package qijia.si; import android.app.Activity; import android.graphics.drawable.AnimationDrawable; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.AdapterView.OnItemSelectedListener; import android.widget.ArrayAdapter; import android.widget.AutoCompleteTextView; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.Gallery; import android.widget.ImageView; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.ScrollView; import android.widget.TextView; public class MyAndroidProject extends Activity { int[] drawableIds = {R.drawable.andy,R.drawable.bill,R.drawable.edgar,R.drawable.torvalds, R.drawable.turing}; int[] msgIds = {R.string.andy,R.string.Bill,R.string.edgar,R.string.torvalds,R.string.turing}; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); ListView lv = (ListView) findViewById(R.id.listView1); BaseAdapter ba = new BaseAdapter(){ public int getCount() {return 5;} public Object getItem(int arg0){return null;} public long getItemId(int arg0){return 0;} public View getView(int arg0,View arg1, ViewGroup arg2){ //动态生成每一个下拉项对应的View,每个下拉项View由LinearLayout //中包含一个ImageView及一个TextView,由代码动态生成 LinearLayout ll = new LinearLayout(MyAndroidProject.this); ll.setOrientation(LinearLayout.HORIZONTAL); ll.setPadding(5, 5, 5, 5); ImageView ii = new ImageView(MyAndroidProject.this); ii.setImageDrawable(getResources().getDrawable(drawableIds[arg0])); ii.setScaleType(ImageView.ScaleType.FIT_XY); ii.setLayoutParams(new Gallery.LayoutParams(100,98)); ll.addView(ii); TextView tv = new TextView(MyAndroidProject.this); tv.setText(getResources().getText(msgIds[arg0])); tv.setTextSize(24); tv.setTextColor(MyAndroidProject.this.getResources().getColor(R.color.white)); tv.setPadding(5, 5, 5, 5); ll.addView(tv); return ll; } }; lv.setAdapter(ba); lv.setOnItemSelectedListener(new OnItemSelectedListener(){ public void onItemSelected(AdapterView<?> arg0,View arg1, int arg2,long arg3){ TextView tv = (TextView) findViewById(R.id.textView1); LinearLayout ll = (LinearLayout)arg1; TextView tvn = (TextView)ll.getChildAt(1); StringBuilder sb = new StringBuilder(); sb.append(getResources().getText(R.string.ys)); sb.append(":"); sb.append(tvn.getText()); String stemp = sb.toString(); tv.setText(stemp.split("\\n")[0]); } public void onNothingSelected(AdapterView<?> arg0){} }); lv.setOnItemClickListener(new OnItemClickListener(){ public void onItemClick(AdapterView<?> arg0,View arg1,int arg2,long arg3){ TextView tv = (TextView) findViewById(R.id.textView1); LinearLayout ll =(LinearLayout) arg1; TextView tvn = (TextView)ll.getChildAt(1); StringBuilder sb = new StringBuilder(); sb.append(getResources().getText(R.string.ys)); sb.append(":"); sb.append(tvn.getText()); String stemp = sb.toString(); tv.setText(stemp.split("\\n")[0]); } }); } }4. 网络视图
GridView类同样位于android.widget包下。该视图将其空间以二维格式显示到表格中,而这些控件全部来自于ListAdapter适配器。
strings.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="hello">当前无选中选项</string> <string name="app_name">Sample_5_3</string> <string name="andy">Andy Rubin</string> <string name="bill">Bill Joy</string> <string name="edgar">Edgar F. Codd</string> <string name="torvalds">Linus Torvalds</string> <string name="turing">Turing Alan</string> <string name="andydis">Android的创造者</string> <string name="billdis">Java创造者之一</string> <string name="edgardis">关系数据库之父</string> <string name="torvaldsdis">Linux之父</string> <string name="turingdis">IT的祖师爷</string> </resources>
colors.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <color name="red">#fd8d8d</color> <color name="green">#9cfda3</color> <color name="blue">#8d9dfd</color> <color name="white">#FFFFFF</color> <color name="black">#000000</color> <color name="gray">#050505</color> </resources>main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <TextView android:id="@+id/TextView01" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello" android:textColor="@color/white" android:textSize="24dip"/> <GridView android:id="@+id/GridView01" android:layout_width="fill_parent" android:layout_height="fill_parent" android:verticalSpacing="5dip" android:horizontalSpacing="5dip" android:stretchMode="columnWidth"/> </LinearLayout>grid_row.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout android:id="@+id/LinearLayout01" android:layout_width="fill_parent" android:layout_height="wrap_content" android:orientation="horizontal" xmlns:android="http://schemas.android.com/apk/res/android"> <ImageView android:id="@+id/ImageView01" android:scaleType="fitXY" android:layout_width="100dip" android:layout_height="98dip"/> <TextView android:id="@+id/TextView02" android:layout_width="100dip" android:layout_height="wrap_content" android:textColor="@color/white" android:textSize="24dip" android:paddingLeft="5dip"/> <TextView android:id="@+id/TextView03" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textColor="@color/white" android:textSize="24dip" android:paddingLeft="5dip"/> </LinearLayout>Activity:
package qijia.si; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; import android.widget.GridView; import android.widget.LinearLayout; import android.widget.SimpleAdapter; import android.widget.TextView; import android.widget.AdapterView.OnItemClickListener; import android.widget.AdapterView.OnItemSelectedListener; public class GridDemo extends Activity { //所有资源图片(andy、bill、edgar、torvalds、turing)id的数组 int[] drawableIds= {R.drawable.andy,R.drawable.bill,R.drawable.edgar,R.drawable.torvalds,R.drawable.turing}; //所有资源字符串(andy、bill、edgar、torvalds、turing)id的数组 int[] nameIds= {R.string.andy,R.string.bill,R.string.edgar,R.string.torvalds,R.string.turing}; int[] msgIds= {R.string.andydis,R.string.billdis,R.string.edgardis, R.string.torvaldsdis,R.string.turingdis}; public List<? extends Map<String, ?>> generateDataList(){ ArrayList<Map<String,Object>> list=new ArrayList<Map<String,Object>>();; int rowCounter=drawableIds.length;//得到表格的行数 for(int i=0;i<rowCounter;i++){//循环生成每行的包含对应各个列数据的Map;col1、col2、col3为列名 HashMap<String,Object> hmap=new HashMap<String,Object>(); hmap.put("col1", drawableIds[i]); //第一列为图片 hmap.put("col2", this.getResources().getString(nameIds[i]));//第二例为姓名 hmap.put("col3", this.getResources().getString(msgIds[i]));//第三列为描述 list.add(hmap); } return list; } public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); GridView gv=(GridView)this.findViewById(R.id.GridView01); SimpleAdapter sca=new SimpleAdapter( this, generateDataList(), //数据List R.layout.grid_row, //行对应layout id new String[]{"col1","col2","col3"}, //列名列表 new int[]{R.id.ImageView01,R.id.TextView02,R.id.TextView03}//列对应控件id列表 ); gv.setAdapter(sca);//为GridView设置数据适配器 gv.setOnItemSelectedListener(//设置选项选中的监听器 new OnItemSelectedListener(){ public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2, long arg3) {//重写选项被选中事件的处理方法 TextView tv=(TextView)findViewById(R.id.TextView01);//获取主界面TextView LinearLayout ll=(LinearLayout)arg1;//获取当前选中选项对应的LinearLayout TextView tvn=(TextView)ll.getChildAt(1);//获取其中的TextView TextView tvnL=(TextView)ll.getChildAt(2);//获取其中的TextView StringBuilder sb=new StringBuilder(); sb.append(tvn.getText());//获取姓名信息 sb.append(" "); sb.append(tvnL.getText());//获取描述信息 tv.setText(sb.toString());//信息设置进主界面TextView } public void onNothingSelected(AdapterView<?> arg0){} } ); gv.setOnItemClickListener( //设置选项被单击的监听器 new OnItemClickListener(){ public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {//重写选项被单击事件的处理方法 TextView tv=(TextView)findViewById(R.id.TextView01);//获取主界面TextView LinearLayout ll=(LinearLayout)arg1;//获取当前选中选项对应的LinearLayout TextView tvn=(TextView)ll.getChildAt(1);//获取其中的TextView TextView tvnL=(TextView)ll.getChildAt(2);//获取其中的TextView StringBuilder sb=new StringBuilder(); sb.append(tvn.getText());//获取姓名信息 sb.append(" "); sb.append(tvnL.getText());//获取描述信息 tv.setText(sb.toString());//信息设置进主界面TextView } } ); } }