用ArrayAdapter来创建Spinner(自定义布局、默认布局、动态内容、静态内容)


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(自定义布局、默认布局、动态内容、静态内容)的更多相关文章
- 自定义 Collection View 布局
自定义 Collection View 布局 answer-huang 29 Mar 2014 分享文章 UICollectionView 在 iOS6 中第一次被引入,也是 UIKit 视图类中的一 ...
- iOS系列译文:自定义Collection View布局
原文出处: Ole Begemann 译文出处: 黄爱武(@answer-huang).欢迎加入技术翻译小组. UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一 ...
- Customize the View Items Layout 自定义视图项目布局
In this lesson, you will learn how to customize the default editor layout in a Detail View. For this ...
- 自定义Collection View布局
转自answer-huang的博客 原文出自:Custom Collection View Layouts UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一颗 ...
- Android动画效果之自定义ViewGroup添加布局动画
前言: 前面几篇文章介绍了补间动画.逐帧动画.属性动画,大部分都是针对View来实现的动画,那么该如何为了一个ViewGroup添加动画呢?今天结合自定义ViewGroup来学习一下布局动画.本文将通 ...
- 整理 PHPstorm实用个人配置,修改调整个性化快捷键,修改使用phpstorm创建的模板的默认注释:
对你有助请点赞,请顶------送人玫瑰,手留余香! 1:58 2016/3/12 整理PHPstorm实用个人配置,修改调整个性化快捷键,修改使用phpstorm创建的模板的默认注释: PHPsto ...
- Android自定义Dialog及其布局
实际项目开发中默认的Dialog样式无法满足需求,需要自定义Dialog及其布局,并响应布局中控件的事件. 上效果图: 自定义Dialog,LogoutDialog: 要将自定义布局传入构造函数中, ...
- PS网页设计教程XXVI——如何在PS中创建一个专业的网页布局
作为编码者,美工基础是偏弱的.我们可以参考一些成熟的网页PS教程,提高自身的设计能力.套用一句话,“熟读唐诗三百首,不会作诗也会吟”. 本系列的教程来源于网上的PS教程,都是国外的,全英文的.本人尝试 ...
- 如何创建一个自定义jQuery插件
简介 jQuery 库是专为加快 JavaScript 开发速度而设计的.通过简化编写 JavaScript 的方式,减少代码量.使用 jQuery 库时,您可能会发现您经常为一些常用函数重写相同的代 ...
随机推荐
- Nginx配置支持https协议-应用实践
Nginx配置支持https协议-应用实践 https简介 HTTPS 是运行在 TLS/SSL 之上的 HTTP,与普通的 HTTP 相比,在数据传输的安全性上有很大的提升. TLS是传输层安全协议 ...
- 神仙数据结构——FHQ_Treap
$FHQ\_Treap$是平衡树的一种,它不仅支持几乎所有的平衡树的操作,而且实现特别简单,总共只有两个操作.这里来简单介绍一下. 基本操作 $FHQ\_Treap$和$Treap$一样是需要用随机值 ...
- 循序渐进学.Net Core Web Api开发系列【16】:应用安全续-加密与解密
系列目录 循序渐进学.Net Core Web Api开发系列目录 本系列涉及到的源码下载地址:https://github.com/seabluescn/Blog_WebApi 一.概述 应用安全除 ...
- iOS 11开发教程(十五)iOS11应用视图的位置和大小
iOS 11开发教程(十五)iOS11应用视图的位置和大小 当一个视图使用拖动的方式添加到主视图后,它的位置和大小可以使用拖动的方式进行设置,也可以使用尺寸检查器面板中的内容进行设置,如图1.52所示 ...
- react比较入门的小demo
什么是jsx? JSX是JavaScript XML 这两个单词的缩写,xml和html非常类似,简单来说可以把它理解成使用各种各样的标签,大家可以自行 百度.所以jsx就是在javascri ...
- 【BZOJ 4059】 (分治暴力|扫描线+线段树)
4059: [Cerc2012]Non-boring sequences Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 632 Solved: 22 ...
- BZOJ3712[PA2014]Fiolki 建图+倍增lca
居然是一道图论题 毫无思路 我们对于每一次的融合操作 $(a,b)$ 建一个新点$c$ 并向$a,b$连边 再将$b$瓶当前的位置赋成$c$ 这样子我们就可以建成一个森林 现在枚举每一种反应$M_i$ ...
- 使用MFC做一个简单的‘能自动生成小学生四则运算的软件’
这是软件工程的第一次作业!但由于我们python还没入门,所以这次的要求是‘语言不限’. 小学期做过一个关于MFC的‘资金管理系统’,也正好可以有界面,所以就选择了自己很熟悉的MFC来做这个作业! 1 ...
- MHDD硬盘坏道检测修复教程(转)
MHDD算是在DOS下比较专业的检测工具,比一些GUI的好用很多,并且现在有人专门做成硬件机器卖到了电脑城,电脑城一般倒卖硬盘的都使用这种机器. 进入MHDD 上面图片中就可以看到硬盘是ST34081 ...
- 收集的一些MikroTik RouterOS 5.x破解版
链接:https://pan.baidu.com/s/1RyREMfrpLkpQ-AIcDQES_Q 密码:byhd