Android开发适配器系列:Spinner使用自定义适配器
2013-10-10 10:14
591 查看
1、说在前面的话
上一篇博文《Android开发适配器系列:Spinner绑定ArrayAdapter适配器》我们实现了Spinner使用ArrayAdapter适配器解决了最基本的数组显示。在这篇博文中,我们将实现如何使用自定义的适配器来实现下列菜单中Item选项包含多个控件。
2、自定义适配器中LayoutInflater的使用
在实际开发中LayoutInflater这个类还是非常有用的,它的作用类似于findViewById()。不同点是LayoutInflater是用来找res/layout/下的xml布局文件,并且实例化;而findViewById()是找xml布局文件下的具体widget控件(如Button、TextView等)。
具体作用:
1、对于一个没有被载入或者想要动态载入的界面,都需要使用LayoutInflater.inflate()来载入;
2、对于一个已经载入的界面,就可以使用Activiyt.findViewById()方法来获得其中的界面元素。
使用LayoutInflater有两种方法:
方法一:
方法一:
3、效果图
![](https://oscdn.geek-share.com/Uploads/Images/Content/201908/20/641dd63c3d0b0587497ba4987dc908a6)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201908/20/806b3171163887d70d3a8c1df4792c83)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201908/20/64fd3e1e242e36ed0592601d03c2af9d)
4、实例源码
main.xml布局文件
item.xml布局文件
item.xml布局文件实现了控件两端对齐:实现两端对齐,我们采用中间增加一个控件的方式实现,并设置属性weight=1。
movie.java
MyAdapter.java
MainActivity.java
5、参考:
关于LayoutInflater使用部分参考:Android LayoutInflater详解
上一篇博文《Android开发适配器系列:Spinner绑定ArrayAdapter适配器》我们实现了Spinner使用ArrayAdapter适配器解决了最基本的数组显示。在这篇博文中,我们将实现如何使用自定义的适配器来实现下列菜单中Item选项包含多个控件。
2、自定义适配器中LayoutInflater的使用
在实际开发中LayoutInflater这个类还是非常有用的,它的作用类似于findViewById()。不同点是LayoutInflater是用来找res/layout/下的xml布局文件,并且实例化;而findViewById()是找xml布局文件下的具体widget控件(如Button、TextView等)。
具体作用:
1、对于一个没有被载入或者想要动态载入的界面,都需要使用LayoutInflater.inflate()来载入;
2、对于一个已经载入的界面,就可以使用Activiyt.findViewById()方法来获得其中的界面元素。
使用LayoutInflater有两种方法:
方法一:
private LayoutInflater listContainer ; // 视图容器 listContainer = LayoutInflater. from (context); // 创建视图容器并设置上下文 convertView = listContainer .inflate(R.layout. list_item , null ); // 获取list_item布局文件的视图
方法一:
private LayoutInflater inflater ; inflater = (LayoutInflater) context.getSystemService(Context. LAYOUT_INFLATER_SERVICE ); convertView = inflater .inflate( R.layout. list_item , null ); //生成条目界面对象
3、效果图
4、实例源码
main.xml布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" android:orientation="vertical"> <TextView android:id="@+id/selectTextview" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/hello_world" /> <Spinner android:layout_width="fill_parent" android:layout_height="wrap_content" android:id="@+id/spinner" /> </LinearLayout>
item.xml布局文件
item.xml布局文件实现了控件两端对齐:实现两端对齐,我们采用中间增加一个控件的方式实现,并设置属性weight=1。
<?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="wrap_content" android:orientation="horizontal" > <TextView android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="TextView" android:textSize="20sp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="1" /> <TextView android:id="@+id/textView2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="TextView" android:textSize="20sp" /> </LinearLayout>
movie.java
package com.andieguo.myspinnerdemo; public class Movie { private String imageName; private String name; private Double time; public Movie(String name, Double time) { super(); this.name = name; this.time = time; } public String getImageName() { return imageName; } public void setImageName(String imageName) { this.imageName = imageName; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Double getTime() { return time; } public void setTime(Double time) { this.time = time; } }
MyAdapter.java
package com.andieguo.myspinnerdemo; import java.util.List; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.TextView; public class MyAdapter extends BaseAdapter { private List<Movie> list; private Context context;// 上下文 public MyAdapter(List<Movie> list, Context context) { super(); this.list = list; this.context = context; } public final class ListItemView {//缓存的价值 public TextView textView1; public TextView textView2; } @Override public int getCount() { // TODO Auto-generated method stub return list.size(); } @Override public Object getItem(int position) { // TODO Auto-generated method stub return list.get(position); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } // getView什么时候执行 @Override public View getView(int position, View convertView, ViewGroup parent) { // TODO Auto-generated method stub LayoutInflater layoutInflater = LayoutInflater.from(context);// //创建视图容器工厂并设置上下文 ListItemView listView = null; if (convertView == null) { convertView = layoutInflater.inflate(R.layout.item, null); // 创建list_item.xml布局文件的视图 listView = new ListItemView(); listView.textView1 = (TextView) convertView.findViewById(R.id.textView1); listView.textView2 = (TextView) convertView.findViewById(R.id.textView2); convertView.setTag(listView); } else { listView = (ListItemView) convertView.getTag(); } listView.textView1.setText(list.get(position).getName()); listView.textView2.setText(list.get(position).getTime() + "min"); return convertView; } }
MainActivity.java
package com.andieguo.myspinnerdemo; import java.util.ArrayList; import java.util.List; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.View; import android.widget.AdapterView; import android.widget.AdapterView.OnItemSelectedListener; import android.widget.Spinner; import android.widget.TextView; public class MainActivity extends Activity { private Spinner spinner = null; private TextView selectTextview = null; private MyAdapter myAdapter = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); spinner = (Spinner) findViewById(R.id.spinner); selectTextview = (TextView) findViewById(R.id.selectTextview); List<Movie> movies = new ArrayList<Movie>(); for(int i=0;i<2;i++){//添加数据 movies.add(new Movie("当幸福来敲门",120.0)); movies.add(new Movie("海贼王", 60.0)); } myAdapter = new MyAdapter(movies,this); spinner.setAdapter(myAdapter); spinner.setOnItemSelectedListener(new OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { // TODO Auto-generated method stub selectTextview.setText("你选择的电影是:" + ((Movie)myAdapter.getItem(position)).getName()); } @Override public void onNothingSelected(AdapterView<?> parent) { // 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(R.menu.main, menu); return true; } }
5、参考:
关于LayoutInflater使用部分参考:Android LayoutInflater详解
相关文章推荐
- Android开发适配器系列:ListView使用自定义适配器(显示所有的联系人)
- Android开发适配器系列:Spinner绑定ArrayAdapter适配器
- Android开发:自定义Spinner适配器
- 【Android开发】自定义ListView,使用通用适配器,并实现ListView上的每一项和每一项上的按钮等控件同时监听
- Android官方开发文档Training系列课程中文版:后台加载数据之使用CursorLoader进行查询
- Android 快速开发系列 打造万能的ListView GridView 适配器
- Android 快速开发系列 打造万能的ListView GridView 适配器
- Android 程式开发:(二十)内容提供者 —— 20.6 自定义ContentProvider的使用
- React-Native系列Android——自定义View组件开发
- Android中Spinner下拉列表(使用ArrayAdapter和自定义Adapter实现) .
- Android 开发 AutoCompleteTextView结合自定义的适配器,查询数据库
- Android 快速开发系列 打造万能的ListView GridView 适配器
- Android中Spinner下拉列表(使用ArrayAdapter和自定义Adapter实现)
- Android 快速开发系列 打造万能的ListView GridView 适配器
- Android 快速开发系列 打造万能的ListView GridView 适配器
- android开发(26) 和其他应用交换数据方式一,使用intent指定自定义action调用其他程序里的activity,并获得其返回的结果
- Android 对Layout_weight属性完全解析以及使用ListView来实现表格(自定义适配器)
- android 开发零起步学习笔记(十七):自定义android用户控件,使用回调函数实现自定义事件
- Android中自定义适配器的使用
- Android官方开发文档Training系列课程中文版:打印内容之自定义文档打印