android:dropDownWidth         下拉列表宽度
android:dropDownHorizontalOffset   下拉列表距离左边的距离
android:dropDownVerticalOffset       下拉菜单和文本之间的垂直偏移量
android:popupBackground         下拉列表中的背景色

android:prompt              下拉列表中的提示信息(基本没用了)

MainActivity.java

package com.kale.spinner;

import android.app.Activity;
import android.os.Bundle;
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 { Spinner spinner01,spinner02,spinner03;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
viewInit();
String []arr = {"JAVA","Android","xml","ios"}; //采用android提供的布局来创建
ArrayAdapter<String> adapter01 = new ArrayAdapter<>(this,
android.R.layout.simple_list_item_multiple_choice,arr);
spinner01.setAdapter(adapter01);
//监听器
spinner01.setOnItemSelectedListener(new OnItemSelectedListener() { @Override
public void onItemSelected(AdapterView<?> adapterView, View arg1,
int position, long id) {
// TODO 自动生成的方法存根
String selected = adapterView.getItemAtPosition(position).toString();
Toast.makeText(getApplicationContext(), selected, 0).show();
} @Override
public void onNothingSelected(AdapterView<?> arg0) {
}
}); //------------------------------------------------------------------------------ //默认的布局文件设置spinner的样式,用写死的数据来创建的。不是很推荐
ArrayAdapter<CharSequence> adapter02 = ArrayAdapter.createFromResource(this,
R.array.item, android.R.layout.simple_spinner_item);
//设置spinner点开后下拉菜单的样式
adapter02.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
spinner02.setAdapter(adapter02);
//spinner02.setPrompt("test");//设置提示文字,现在的界面中已经不显示了。所以可以说是没用了 //------------------------------------------------------------------------------
//采用动态的数据,布局文件是自己定义的item
ArrayAdapter<String> adapter03 = new ArrayAdapter<>(this, R.layout.item,
R.id.textView_id, arr);
spinner03.setAdapter(adapter03);
}
private void viewInit() {
spinner01 = (Spinner) findViewById(R.id.spinner01_id);
spinner02 = (Spinner) findViewById(R.id.spinner02_id);
spinner03 = (Spinner) findViewById(R.id.spinner03_id);
}
}

activity_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:orientation="vertical"
android:padding="16dp"> <!--
android:dropDownWidth 下拉列表宽度
android:dropDownHorizontalOffset 下拉列表距离左边的距离
android:dropDownVerticalOffset 下拉菜单和文本之间的垂直偏移量
android:popupBackground 下拉列表中的背景色
android:prompt 下拉列表中的提示信息 --> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="用代码填充数据的spinner(用android自带的布局)"
android:layout_marginTop="16dp"
android:textAppearance="?android:attr/textAppearanceMedium" /> <Spinner
android:id="@+id/spinner01_id"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:popupBackground="#ade9ee"
android:dropDownVerticalOffset="3dp"
android:prompt="@string/hello_world"/> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="数据写到array中的spinner(用android提供的布局)"
android:layout_marginTop="26dp"
android:textAppearance="?android:attr/textAppearanceMedium" /> <Spinner
android:id="@+id/spinner02_id"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:dropDownVerticalOffset="3dp"
android:prompt="@string/hello_world"/> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="使用自定义布局并动态填入数据的spinner"
android:layout_marginTop="26dp"
android:textAppearance="?android:attr/textAppearanceMedium" /> <Spinner
android:id="@+id/spinner03_id"
android:layout_width="match_parent"
android:layout_height="wrap_content"/> </LinearLayout>

item.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="vertical"
android:padding="8dp"> <TextView
android:id="@+id/textView_id"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Large Text"
android:textColor="#0000ff"
android:gravity="center_horizontal"
android:textAppearance="?android:attr/textAppearanceLarge" /> </LinearLayout>

用ArrayAdapter来创建Spinner(自定义布局、默认布局、动态内容、静态内容)的更多相关文章

  1. 自定义 Collection View 布局

    自定义 Collection View 布局 answer-huang 29 Mar 2014 分享文章 UICollectionView 在 iOS6 中第一次被引入,也是 UIKit 视图类中的一 ...

  2. iOS系列译文:自定义Collection View布局

    原文出处: Ole Begemann   译文出处: 黄爱武(@answer-huang).欢迎加入技术翻译小组. UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一 ...

  3. Customize the View Items Layout 自定义视图项目布局

    In this lesson, you will learn how to customize the default editor layout in a Detail View. For this ...

  4. 自定义Collection View布局

    转自answer-huang的博客 原文出自:Custom Collection View Layouts    UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一颗 ...

  5. Android动画效果之自定义ViewGroup添加布局动画

    前言: 前面几篇文章介绍了补间动画.逐帧动画.属性动画,大部分都是针对View来实现的动画,那么该如何为了一个ViewGroup添加动画呢?今天结合自定义ViewGroup来学习一下布局动画.本文将通 ...

  6. 整理 PHPstorm实用个人配置,修改调整个性化快捷键,修改使用phpstorm创建的模板的默认注释:

    对你有助请点赞,请顶------送人玫瑰,手留余香! 1:58 2016/3/12 整理PHPstorm实用个人配置,修改调整个性化快捷键,修改使用phpstorm创建的模板的默认注释: PHPsto ...

  7. Android自定义Dialog及其布局

     实际项目开发中默认的Dialog样式无法满足需求,需要自定义Dialog及其布局,并响应布局中控件的事件. 上效果图: 自定义Dialog,LogoutDialog: 要将自定义布局传入构造函数中, ...

  8. PS网页设计教程XXVI——如何在PS中创建一个专业的网页布局

    作为编码者,美工基础是偏弱的.我们可以参考一些成熟的网页PS教程,提高自身的设计能力.套用一句话,“熟读唐诗三百首,不会作诗也会吟”. 本系列的教程来源于网上的PS教程,都是国外的,全英文的.本人尝试 ...

  9. 如何创建一个自定义jQuery插件

    简介 jQuery 库是专为加快 JavaScript 开发速度而设计的.通过简化编写 JavaScript 的方式,减少代码量.使用 jQuery 库时,您可能会发现您经常为一些常用函数重写相同的代 ...

随机推荐

  1. 解决Eclipse启动报错【Failed to create the Java Virtual Machine】

    电脑:2G内存,WIN7 32位. 启动adt-bundle-windows-x86-20140702\eclipse\eclipse.exe时,报错[Failed to create the Jav ...

  2. 001.etcd简介及单节点使用

    一 etcd简介 1.1 概述 etcd 是 CoreOS 团队发起的开源项目,是一个管理配置信息和服务发现(service discovery)的项目,它的目标是构建一个高可用的分布式键值(key- ...

  3. 001.DNS原理及配置格式

    一 dns简介 DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串. ...

  4. AngularJS初始化静态模板

    AngularJS可以通过ng-app来自动初始化模块,也可以通过angular.bootstrap(document, [module])手动启动应用,不管用哪种方法,应用启动后,动态往dom树里面 ...

  5. Java 内部类.md

    Java 内部类 学习自 <Java编程思想> Overview 什么是内部类? Thinking In Java 中如此定义: 将一个类的定义放在里另一个类的定义的内部,这就是内部类. ...

  6. Ⅳ.Catalan数

    Catalan数首先是由Euler在精确计算对凸n边形的不同的对角三角形剖分的个数问题时得到的,它经常出现在组合计数问题中.     问题的提出:在一个凸n边形中,通过不相交于n边形内部的对角线,把n ...

  7. windows环境配置:同时安装Python2.7和Python3.6开发环境

    一.下载安装Python2.7和Python3.6 安装包下载地址:https://www.python.org/downloads/ 二.配置系统环境变量 在环境变量中添加 1.安装目录\Pytho ...

  8. MySQL_事务没有提交导致 锁等待 Lock wait timeout exceeded

    java.lang.Exception:### Error updating database.  Cause: java.sql.SQLException: Lock wait timeout ex ...

  9. 区别ES3ES5和ES6this的指向问题。区分普通函数和箭头函数中this的指向问题

    ES3 ES5this的指向问题 this指的是该函数被调用的对象 var foo = function () { this.a = 'a', this.b = 'b', this.c = { a: ...

  10. Dapper Miser implementation of CMSIS-DAP, MC HCK as SWD Adapter

    Dapper Miser In late 2013, I created a functional implementation of CMSIS-DAP that runs in a low cos ...