[索引页]
[×××]
作者:webabcd
介绍
在 Android 中使用各种控件(View)
1、TextSwitcher 的 Demo
textswitcher.xml
[×××]
系出名门Android(8) - 控件(View)之TextSwitcher, Gallery, ImageSwitcher, GridView, ListView, ExpandableList
作者:webabcd
介绍
在 Android 中使用各种控件(View)
- TextSwitcher - 文字转换器控件(改变文字时增加一些动画效果)
- Gallery - 缩略图浏览器控件
- ImageSwitcher - 图片转换器控件(改变图片时增加一些动画效果)
- GridView - 网格控件
- ListView - 列表控件
- ExpandableList - 支持展开/收缩功能的列表控件
1、TextSwitcher 的 Demo
textswitcher.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" >
< Button android:id ="@+id/btnChange" android:layout_width ="wrap_content"
android:layout_height ="wrap_content" android:text ="改变文字" />
< TextSwitcher android:id ="@+id/textSwitcher"
android:layout_width ="fill_parent" android:layout_height ="wrap_content" />
LinearLayout >
< LinearLayout xmlns:android ="http://schemas.android.com/apk/res/android"
android:orientation ="vertical" android:layout_width ="fill_parent"
android:layout_height ="fill_parent" >
< Button android:id ="@+id/btnChange" android:layout_width ="wrap_content"
android:layout_height ="wrap_content" android:text ="改变文字" />
< TextSwitcher android:id ="@+id/textSwitcher"
android:layout_width ="fill_parent" android:layout_height ="wrap_content" />
LinearLayout >
_TextSwitcher.java
package com.webabcd.view;
import java.util.Random;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.Button;
import android.widget.TextSwitcher;
import android.widget.TextView;
import android.widget.ViewSwitcher;
public class _TextSwitcher extends Activity implements ViewSwitcher.ViewFactory {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.textswithcer);
setTitle( "TextSwithcer");
final TextSwitcher switcher = (TextSwitcher) findViewById(R.id.textSwitcher);
// 指定转换器的 ViewSwitcher.ViewFactory
switcher.setFactory( this);
// 设置淡入和淡出的动画效果
Animation in = AnimationUtils.loadAnimation( this, android.R.anim.fade_in);
Animation out = AnimationUtils.loadAnimation( this, android.R.anim.fade_out);
switcher.setInAnimation(in);
switcher.setOutAnimation(out);
// 单击一次按钮改变一次文字
Button btnChange = (Button) this.findViewById(R.id.btnChange);
btnChange.setOnClickListener( new View.OnClickListener() {
@Override
public void onClick(View v) {
switcher.setText(String.valueOf( new Random().nextInt()));
}
});
}
// 重写 ViewSwitcher.ViewFactory 的 makeView(),返回一个 View
@Override
public View makeView() {
TextView textView = new TextView( this);
textView.setTextSize(36);
return textView;
}
}
import java.util.Random;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.Button;
import android.widget.TextSwitcher;
import android.widget.TextView;
import android.widget.ViewSwitcher;
public class _TextSwitcher extends Activity implements ViewSwitcher.ViewFactory {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.textswithcer);
setTitle( "TextSwithcer");
final TextSwitcher switcher = (TextSwitcher) findViewById(R.id.textSwitcher);
// 指定转换器的 ViewSwitcher.ViewFactory
switcher.setFactory( this);
// 设置淡入和淡出的动画效果
Animation in = AnimationUtils.loadAnimation( this, android.R.anim.fade_in);
Animation out = AnimationUtils.loadAnimation( this, android.R.anim.fade_out);
switcher.setInAnimation(in);
switcher.setOutAnimation(out);
// 单击一次按钮改变一次文字
Button btnChange = (Button) this.findViewById(R.id.btnChange);
btnChange.setOnClickListener( new View.OnClickListener() {
@Override
public void onClick(View v) {
switcher.setText(String.valueOf( new Random().nextInt()));
}
});
}
// 重写 ViewSwitcher.ViewFactory 的 makeView(),返回一个 View
@Override
public View makeView() {
TextView textView = new TextView( this);
textView.setTextSize(36);
return textView;
}
}
2、Gallery 的 Demo
gallery.xml
gallery.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" >
< Gallery android:id ="@+id/gallery" android:layout_width ="fill_parent"
android:layout_height ="wrap_content" android:spacing ="20px" />
LinearLayout >
< LinearLayout xmlns:android ="http://schemas.android.com/apk/res/android"
android:orientation ="vertical" android:layout_width ="fill_parent"
android:layout_height ="fill_parent" >
< Gallery android:id ="@+id/gallery" android:layout_width ="fill_parent"
android:layout_height ="wrap_content" android:spacing ="20px" />
LinearLayout >
_Gallery.java
package com.webabcd.view;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.Gallery.LayoutParams;
public class _Gallery extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.gallery);
setTitle( "Gallery");
Gallery gallery = (Gallery) findViewById(R.id.gallery);
// 为缩略图浏览器指定一个适配器
gallery.setAdapter( new ImageAdapter( this));
// 响应 在缩略图列表上选中某个缩略图后的 事件
gallery.setOnItemSelectedListener( new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView> parent, View v,
int position, long id) {
Toast.makeText(_Gallery. this, String.valueOf(position), Toast.LENGTH_SHORT).show();
}
@Override
public void onNothingSelected(AdapterView> arg0) {
}
});
}
// 继承 BaseAdapter 用以实现自定义的图片适配器
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context context) {
mContext = context;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem( int position) {
return position;
}
public long getItemId( int position) {
return position;
}
public View getView( int position, View convertView, ViewGroup parent) {
ImageView p_w_picpath = new ImageView(mContext);
p_w_picpath.setImageResource(mThumbIds[position]);
p_w_picpath.setAdjustViewBounds( true);
p_w_picpath.setLayoutParams( new Gallery.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
return p_w_picpath;
}
}
// 需要显示的图片集合
private Integer[] mThumbIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
}
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.Gallery.LayoutParams;
public class _Gallery extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.gallery);
setTitle( "Gallery");
Gallery gallery = (Gallery) findViewById(R.id.gallery);
// 为缩略图浏览器指定一个适配器
gallery.setAdapter( new ImageAdapter( this));
// 响应 在缩略图列表上选中某个缩略图后的 事件
gallery.setOnItemSelectedListener( new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView> parent, View v,
int position, long id) {
Toast.makeText(_Gallery. this, String.valueOf(position), Toast.LENGTH_SHORT).show();
}
@Override
public void onNothingSelected(AdapterView> arg0) {
}
});
}
// 继承 BaseAdapter 用以实现自定义的图片适配器
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context context) {
mContext = context;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem( int position) {
return position;
}
public long getItemId( int position) {
return position;
}
public View getView( int position, View convertView, ViewGroup parent) {
ImageView p_w_picpath = new ImageView(mContext);
p_w_picpath.setImageResource(mThumbIds[position]);
p_w_picpath.setAdjustViewBounds( true);
p_w_picpath.setLayoutParams( new Gallery.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
return p_w_picpath;
}
}
// 需要显示的图片集合
private Integer[] mThumbIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
}
3、ImageSwitcher 的 Demo
p_w_picpathswitcher.xml
p_w_picpathswitcher.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" >
< Gallery android:id ="@+id/gallery" android:layout_width ="fill_parent"
android:layout_height ="wrap_content" android:spacing ="20px" />
< ImageSwitcher android:id ="@+id/p_w_picpathSwitcher"
android:layout_width ="fill_parent" android:layout_height ="wrap_content" />
LinearLayout >
< LinearLayout xmlns:android ="http://schemas.android.com/apk/res/android"
android:orientation ="vertical" android:layout_width ="fill_parent"
android:layout_height ="fill_parent" >
< Gallery android:id ="@+id/gallery" android:layout_width ="fill_parent"
android:layout_height ="wrap_content" android:spacing ="20px" />
< ImageSwitcher android:id ="@+id/p_w_picpathSwitcher"
android:layout_width ="fill_parent" android:layout_height ="wrap_content" />
LinearLayout >
_ImageSwitcher.java
package com.webabcd.view;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AnimationUtils;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.ViewSwitcher;
import android.widget.Gallery.LayoutParams;
// 图片转换器的使用基本同文字转换器
// 以下是一个用 ImageSwitcher + Gallery 实现的经典的图片浏览器的 Demo
public class _ImageSwitcher extends Activity implements
ViewSwitcher.ViewFactory {
private ImageSwitcher mSwitcher;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.p_w_picpathswithcer);
setTitle( "ImageSwithcer");
mSwitcher = (ImageSwitcher) findViewById(R.id.p_w_picpathSwitcher);
mSwitcher.setFactory( this);
mSwitcher.setInAnimation(AnimationUtils.loadAnimation( this,
android.R.anim.fade_in));
mSwitcher.setOutAnimation(AnimationUtils.loadAnimation( this,
android.R.anim.fade_out));
Gallery gallery = (Gallery) findViewById(R.id.gallery);
gallery.setAdapter( new ImageAdapter( this));
gallery.setOnItemSelectedListener( new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView> parent, View v,
int position, long id) {
mSwitcher.setImageResource(mImageIds[position]);
}
@Override
public void onNothingSelected(AdapterView> arg0) {
}
});
}
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context context) {
mContext = context;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem( int position) {
return position;
}
public long getItemId( int position) {
return position;
}
public View getView( int position, View convertView, ViewGroup parent) {
ImageView p_w_picpath = new ImageView(mContext);
p_w_picpath.setImageResource(mThumbIds[position]);
p_w_picpath.setAdjustViewBounds( true);
p_w_picpath.setLayoutParams( new Gallery.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
return p_w_picpath;
}
}
private Integer[] mThumbIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
private Integer[] mImageIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
@Override
public View makeView() {
ImageView p_w_picpath = new ImageView( this);
p_w_picpath.setMinimumHeight(200);
p_w_picpath.setMinimumWidth(200);
p_w_picpath.setScaleType(ImageView.ScaleType.FIT_CENTER);
p_w_picpath.setLayoutParams( new ImageSwitcher.LayoutParams(
LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
return p_w_picpath;
}
}
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AnimationUtils;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Gallery;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.ViewSwitcher;
import android.widget.Gallery.LayoutParams;
// 图片转换器的使用基本同文字转换器
// 以下是一个用 ImageSwitcher + Gallery 实现的经典的图片浏览器的 Demo
public class _ImageSwitcher extends Activity implements
ViewSwitcher.ViewFactory {
private ImageSwitcher mSwitcher;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.p_w_picpathswithcer);
setTitle( "ImageSwithcer");
mSwitcher = (ImageSwitcher) findViewById(R.id.p_w_picpathSwitcher);
mSwitcher.setFactory( this);
mSwitcher.setInAnimation(AnimationUtils.loadAnimation( this,
android.R.anim.fade_in));
mSwitcher.setOutAnimation(AnimationUtils.loadAnimation( this,
android.R.anim.fade_out));
Gallery gallery = (Gallery) findViewById(R.id.gallery);
gallery.setAdapter( new ImageAdapter( this));
gallery.setOnItemSelectedListener( new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView> parent, View v,
int position, long id) {
mSwitcher.setImageResource(mImageIds[position]);
}
@Override
public void onNothingSelected(AdapterView> arg0) {
}
});
}
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context context) {
mContext = context;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem( int position) {
return position;
}
public long getItemId( int position) {
return position;
}
public View getView( int position, View convertView, ViewGroup parent) {
ImageView p_w_picpath = new ImageView(mContext);
p_w_picpath.setImageResource(mThumbIds[position]);
p_w_picpath.setAdjustViewBounds( true);
p_w_picpath.setLayoutParams( new Gallery.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
return p_w_picpath;
}
}
private Integer[] mThumbIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
private Integer[] mImageIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
@Override
public View makeView() {
ImageView p_w_picpath = new ImageView( this);
p_w_picpath.setMinimumHeight(200);
p_w_picpath.setMinimumWidth(200);
p_w_picpath.setScaleType(ImageView.ScaleType.FIT_CENTER);
p_w_picpath.setLayoutParams( new ImageSwitcher.LayoutParams(
LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
return p_w_picpath;
}
}
4、GridView 的 Demo
gridview.xml
gridview.xml
xml
version
="1.0"
encoding
="utf-8"
?>
< GridView xmlns:android ="http://schemas.android.com/apk/res/android"
android:id ="@+id/gridView" android:layout_width ="fill_parent"
android:layout_height ="fill_parent" android:padding ="10px"
android:verticalSpacing ="10px" android:horizontalSpacing ="10px"
android:numColumns ="auto_fit" android:columnWidth ="60px"
android:stretchMode ="columnWidth" android:gravity ="center" >
GridView >
< GridView xmlns:android ="http://schemas.android.com/apk/res/android"
android:id ="@+id/gridView" android:layout_width ="fill_parent"
android:layout_height ="fill_parent" android:padding ="10px"
android:verticalSpacing ="10px" android:horizontalSpacing ="10px"
android:numColumns ="auto_fit" android:columnWidth ="60px"
android:stretchMode ="columnWidth" android:gravity ="center" >
GridView >
_GridView.java
package com.webabcd.view;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class _GridView extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.gridview);
setTitle( "GridView");
GridView gridView = (GridView) findViewById(R.id.gridView);
// 指定网格控件的适配器为自定义的图片适配器
gridView.setAdapter( new ImageAdapter( this));
}
// 自定义的图片适配器
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context context) {
mContext = context;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem( int position) {
return position;
}
public long getItemId( int position) {
return position;
}
public View getView( int position, View convertView, ViewGroup parent) {
ImageView p_w_picpathView;
if (convertView == null) {
p_w_picpathView = new ImageView(mContext);
p_w_picpathView.setLayoutParams( new GridView.LayoutParams(48, 48));
p_w_picpathView.setAdjustViewBounds( false);
p_w_picpathView.setScaleType(ImageView.ScaleType.CENTER_CROP);
p_w_picpathView.setPadding(5, 5, 5, 5);
} else {
p_w_picpathView = (ImageView) convertView;
}
p_w_picpathView.setImageResource(mThumbIds[position]);
return p_w_picpathView;
}
// 网格控件所需图片数据的数据源
private Integer[] mThumbIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
}
}
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class _GridView extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
this.setContentView(R.layout.gridview);
setTitle( "GridView");
GridView gridView = (GridView) findViewById(R.id.gridView);
// 指定网格控件的适配器为自定义的图片适配器
gridView.setAdapter( new ImageAdapter( this));
}
// 自定义的图片适配器
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context context) {
mContext = context;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem( int position) {
return position;
}
public long getItemId( int position) {
return position;
}
public View getView( int position, View convertView, ViewGroup parent) {
ImageView p_w_picpathView;
if (convertView == null) {
p_w_picpathView = new ImageView(mContext);
p_w_picpathView.setLayoutParams( new GridView.LayoutParams(48, 48));
p_w_picpathView.setAdjustViewBounds( false);
p_w_picpathView.setScaleType(ImageView.ScaleType.CENTER_CROP);
p_w_picpathView.setPadding(5, 5, 5, 5);
} else {
p_w_picpathView = (ImageView) convertView;
}
p_w_picpathView.setImageResource(mThumbIds[position]);
return p_w_picpathView;
}
// 网格控件所需图片数据的数据源
private Integer[] mThumbIds = { R.drawable.icon01, R.drawable.icon02,
R.drawable.icon03, R.drawable.icon04, R.drawable.icon05 };
}
}
未完待续>>
OK
[×××]
[×××]