画廊视图(Gallery)的功能和用法

画廊视图(Gallery)的功能和用法

2023年7月15日发(作者:)

画廊视图(Gallery)的功能和⽤法 Gallery与Spinner组件有共同的⽗类:AbsSpinner,表明Gallery和Spinner是同⼀个列表框。它们之间的区别是Spinner显⽰的垂直的列表选择框,⽽Gallery显⽰的是⼀个⽔平的列表选择框。Gallery和Spinner还有⼀个区别:Spinner的作⽤是供⽤户选择,⽽Gallery则允许⽤户通过拖动来查看上⼀个、下⼀个列表项。 Gallery本⾝的⽤法⾮常简单——基本上与Spinner的⽤法相似,只要为它提供⼀个内容Adapter即可,该Adapter的getView⽅法所返回的View将作为Gallery列表的列表项。如果程序要监控到Gallery列表项的改变,通过为Gallery添加OnItemSelectedListener监听器即可实现。 实例:“幻灯⽚”式图⽚查看器 本实例也是带预览的图⽚浏览器,但本实例的界⾯更加友好,因为本实例采⽤Gallery作为图⽚预览器,Gallery会⽣成⼀个“⽔平列表”,每个列表项就是⼀张图⽚预览,⽽且Gallery⽣成的“⽔平列表”可以让⽤户通过拖动来切换列表项。 下⾯是本实例的界⾯布局⽂件。上⾯的布局⽂件⾮常简单,仅仅定义了两个组件:ImageView和Gallery组件。接下来的主程序很简单:为Gallery传⼊⼀个Adapter对象,这样Gallery即可正常⼯作。为了让ImageView可显⽰Gallery中选中的图⽚,为Gallery绑定OnItemSelectedListener监听器即可。程序代码如下:package orld;import ;import ty;import rray;import ;import ;import oup;import .*;import SelectedListener;public class GalleryTest extends Activity { int[] imageIds=new int[]{ zi, yu, , eng, e, u, , ng, , g, , };

@SuppressWarnings("deprecation") Gallery gallery; ImageView imageView; @Override protected void onCreate(Bundle savedInstanceState) { te(savedInstanceState); setContentView(y_test); gallery=(Gallery)findViewById(y); //获取显⽰图⽚的ImageView对象 imageView=(ImageView)findViewById(iew); //创建⼀个BaseAdapter对象,该对象负责提供Gallery所显⽰的列表项 BaseAdapter adapter=new BaseAdapter() { @Override public int getCount() { // TODO Auto-generated method stub return ; } @Override public Object getItem(int position) { // TODO Auto-generated method stub return position; } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } @SuppressWarnings("deprecation") @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub //创建⼀个ImageView ImageView imageView=new ImageView(); geResource(imageIds[position]); //设置ImageView的缩放类型 leType(_XY); //为imageView设置布局参数 outParams(new Params( 175, 275)); //设置背景风格。Gallery背景风格定义在中

TypedArray typedArray=obtainStyledAttributes(y); kgroundResource(ourceId(y_android_galleryItemBackground, 1));

return imageView; } }; pter(adapter); temSelectedListener(new OnItemSelectedListener(){ //当Gallery选中项发⽣改变时触发该⽅法 @Override public void onItemSelected(AdapterView parent, View view, int position, long id) { // TODO Auto-generated method stub geResource(imageIds[position]); } @Override public void onNothingSelected(AdapterView arg0) { // TODO Auto-generated method stub

}

}); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(y_test, menu); return true; }}上⾯代码中使⽤了y资源,该资源是/res/values/⽂件,其布局⽂件如下:

上⾯的程序中粗体字代码创建了⼀个BaseAdapter对象,该Adapter将负责为Gallery提供列表项。运⾏上⾯的程序,将可以看到如下效果:

发布者:admin,转转请注明出处:http://www.yc00.com/xiaochengxu/1689427153a246399.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信