Android开发04—Android常用高级控件(上)

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
}
}
);
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值