Android 的自定义Spinner组件实现方式

一、Android的API方式默认实现的方式

1.layout下编辑main_activity.xml

<RelativeLayout 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" >

    <Spinner
        android:id="@+id/spinner01"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:entries="@array/citys" />

    <Spinner
        android:id="@+id/spinner02"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@id/spinner01" />

      <Spinner
        android:id="@+id/spinner03"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@id/spinner02" />

</RelativeLayout>

  2.string.xml代码

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="app_name">Android_015</string>
    <string name="action_settings">Settings</string>
    <string name="hello_world">Hello world!</string>

    <string-array name="citys">
        <item>北京</item>
        <item>上海</item>
        <item>广州</item>
        <item>深圳</item>
        <item>珠海</item>
        <item>湖州</item>
    </string-array>

    <string name="tv">TextView</string>
</resources>

  3.layout下面的自定义的下拉选项样式 Spinner_layout.xml和me_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/text1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    style="?android:attr/spinnerDropDownItemStyle"
    android:ellipsize="marquee"
    android:drawableLeft="@drawable/ic_launcher"
    android:textColor="#00ff00"
   />

me_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:drawableLeft="@drawable/ic_launcher"
        android:paddingRight="8dip"
        android:paddingTop="8dip"
        android:text="@string/tv"
        android:textSize="25sp" />

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingLeft="8dip"
        android:paddingTop="8dip"
        android:text="@string/tv"
        android:textSize="25sp" />

</LinearLayout>

  4.Java后台代码

package com.example.android_015;

import java.util.ArrayList;
import java.util.List;

import com.example.android_015.entity.Person;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.Toast;

public class MainActivity extends Activity implements OnItemSelectedListener{

	private Spinner spinner,spinner03;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		spinner = (Spinner) findViewById(R.id.spinner02);
		spinner.setOnItemSelectedListener(this);

		// 获取string.xml的资源文件的数组
		String[] citys = getResources().getStringArray(R.array.citys);

		// 数组适配器的创建
		// 1.实例化的方式创建适配器
		ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
				android.R.layout.simple_spinner_item, citys);
		// 2.API建议的方式创建adapt
		ArrayAdapter<CharSequence> adapter1 = ArrayAdapter.createFromResource(
				this, R.array.citys, android.R.layout.simple_spinner_item);
		adapter.setDropDownViewResource(R.layout.spinner_layout);
		//设置下拉试图的样式
		//adapter1.setDropDownViewResource(android.R.layout.simple_list_item_checked);

		spinner.setAdapter(adapter);

		//自定义的适配器下垃选项
		spinner03 = (Spinner) findViewById(R.id.spinner03);
		// 建立数据源
		List<Person>  persons=new ArrayList<Person>();
		persons.add(new Person("张三", "上海 "));
		persons.add(new Person("李四", "上海 "));
		persons.add(new Person("王五", "北京" ));
		persons.add(new Person("赵六", "广州 "));
		//  建立Adapter绑定数据源
		MyAdapter _MyAdapter=new MyAdapter(this, persons);
		//绑定Adapter
		spinner03.setAdapter(_MyAdapter);

	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

	//选中按钮的实现方法
	@Override
	public void onItemSelected(AdapterView<?> parent, View view, int position,long id) {
		System.out.println("parent:"+parent.getClass()); //父组件 spinner
		System.out.println("view:"+view.getClass()); //加载的下拉列表 xml类型 TextView
		System.out.println("position="+position);
		System.out.println("id="+id);
		//spinner.getSelectedItem().toString() 被选中的下拉列表值
		//spinner.getSelectedView() 被选中的 下垃组件属性
		//spinner.getSelectedItemPosition()  被选中的位置
		//spinner.getSelectedItemId() 被选中的id
		String str=parent.getItemAtPosition(position).toString();

		Toast.makeText(this, "你点击选中的是:"+str, 2000).show();
	}

	//未选中的实现方法
	@Override
	public void onNothingSelected(AdapterView<?> parent) {

	}

}

  5.Person类

package com.example.android_015.entity;

/**
 * 用户对象
 * @author hbj403
 */
public class Person {
	private String personName;
	private String personAddress;

	public Person(String personName,String personAddress) {
		super();
		this.personName=personName;
		this.personAddress=personAddress;
	}

	public String getPersonName() {
		return personName;
	}

	public void setPersonName(String personName) {
		this.personName = personName;
	}

	public String getPersonAddress() {
		return personAddress;
	}

	public void setPersonAddress(String personAddress) {
		this.personAddress = personAddress;
	}

}

  6、自定义MyAdapter适配器类

package com.example.android_015;

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;

import com.example.android_015.entity.Person;

/**
 * 自定义的适配器类
 * @author hbj403
 */
public class MyAdapter extends BaseAdapter {

	private List<Person> mList;
    private Context mContext;

    public MyAdapter(Context pContext,List<Person> pList) {
    	this.mContext=pContext;
    	this.mList=pList;
	}

	@Override
	public int getCount() {
		return mList.size();
	}

	@Override
	public Object getItem(int position) {
		return mList.get(position);
	}

	@Override
	public long getItemId(int position) {
		return position;
	}

	//最主要代码
	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		LayoutInflater _LayoutInflater=LayoutInflater.from(mContext);
		convertView=_LayoutInflater.inflate(R.layout.me_layout, null);

		if(convertView!=null){
			TextView _TextView1=(TextView)convertView.findViewById(R.id.textView1);
			TextView _TextView2=(TextView)convertView.findViewById(R.id.textView2);
			_TextView1.setText(mList.get(position).getPersonName());
			_TextView2.setText(mList.get(position).getPersonAddress());
		}
		return convertView;
	}
}

  二、运行方式截图

监听事件和第一种方法相同:

部分链接文档来自:转自:http://blog.csdn.net/jiangqq781931404/article/details/7285623

时间: 2024-10-07 10:53:12

Android 的自定义Spinner组件实现方式的相关文章

Android 实现自定义Spinner

有时候因为项目的界面风格 很多控件如果使用原生的样式感觉会与整体风格有些不搭 所以需要自定义样式 很多项目中自定义控件都是必不可少的 这里参考网上的一些资料 实现了一个自定义Spinner  记录下 加深印象 效果图: 弹框是通过一个重写的Dialog和Listview实现 第一步   重写Dialog类SelectDialog.java [java] copy import import import public SelectDialog  AlertDialog { SelectDialo

Android中自定义Spinner和其下拉窗

如图所示,自定义的Spinner包括两部分,一部分是  这个其实就是一张图片而已,素材文件如下 至于下拉窗口其实就是自定义一个Adapter

Android UI自定义Spinner下拉框(用popuwindow实现)-转

定义出第一个图片的布局和弹出框(一个listView)的布局,,这里就不在多说了~ListView需要自己定义一个MyspinnerAdapter~做好这些准备之后,就是弹出框的实现了~  protected void onCreate(Bundle savedInstanceState) { 03         super.onCreate(savedInstanceState); 04         setContentView(R.layout.activity_main); 05  

Android 自定义Spinner字体、颜色、大小

昨天在公司项目中遇到Spinner颜色,字体,大小的困惑.所以今天也总结一下这方面知识.这个其实很简单,要改变字体,颜色以及大小,无非就是不要用系统自带的样式.自已例外写一个layout调用就行了.我就是这样做的.本文例子还有Spinner两种弹出方式,下拉框以及弹出框.加载数据源的两种方式.下面看代码介绍. 本文项目源码地址:http://download.csdn.net/detail/qq_16064871/8583085 转载请注明出处: http://blog.csdn.net/qq_

Android开发之自定义Spinner样式的效果实现(源代码实现)

android系统自带的Spinner样式是远远满足不了我们实际开发过程中对Spinner UI风格的要求,因此我们肯定需要为了切合整个应用的风格,修改我们的Spinner样式.系统给我们提供了两种常见的修改方式,一个是用XML方式静态,另一个就是Java代码动态来修改啦,我们这篇文章呢主要就是介绍如何动态修改Spinner的样式.我的实现方法呢,是自己构造一个SpinnerAdapter,继承来自ArrayAdapter,重写getDropDownView(),getView()这两个方法就好

Android 自定义spinner文字颜色 和 显示样式

项目中界面,有几个数值不允许用户输入,只能在下拉列表中选择项目,一开始想过自定义dialog或者popupwindow,但是会额外增加很多代码,考虑到现在的工程代码量已经很多了,所以想到了使用google已经开发好的组件spinner组件,这是一个非常好用的系统下拉选项组件,具体的用法我就不多说了,有很多已经总结过了,大概的流程就是先设置spinner控件,如下: Spinner< android:id="@+id/touchprice" android:layout_width

Android 自定义Spinner和其下拉窗口

http://www.cnblogs.com/coding-way/p/3549865.html 现效果: 自定义Spinner其实包括两个部分: 第一部分是用来打开下拉列表的按钮,如图,这个绿色背景直接设置Spinner的背景就行,素材文件如下: 里面的文字需要注意下,Spinner控件没有直接修改文字的接口,这个文字实际上是在Adapter中设置,例如: ArrayAdapter<String> adapter = new ArrayAdapter<String>(getCon

Android中自定义下拉样式Spinner

Android中自定义下拉样式Spinner 本文继续介绍android自定义控件系列,自定义Spinner控件的使用. 实现思路 1.定义下拉控件布局(ListView及子控件布局) 2.自定义SpinerPopWindow类 3.定义填充数据的Adapter 效果图 一.定义控件布局 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http:/

Android中自定义组件和它的属性

好长时间没有更新博客了,本来想积累点有深度的东西发,但一直没有找到很好的点.所以,写一些基础的东西,就当积累吧. Android开发中难免会用到自定义的组件,下面以ImageButton为例来介绍怎么自定义组件和它的属性: 第一步.在values/attrs.xml中为组件自定义属性: <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name=&