在平常的开发中单选按键和下拉按键是非常常用的2个点击事件。首先介绍下单选按键

1:单选按键,单选的主键是radiogroup 这个主键也是很重要的

首先介绍下主键的布局

<?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="fill_parent"

android:orientation="vertical">

<TextView android:id="@+id/myRadioListenerTV"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:textSize="20px"

android:text="您选择的性别是:"/>

<RadioGroup android:id="@+id/myRadioListenerRG"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:checkedButton="@+id/myRadioListenerMale">

<RadioButton android:id="@+id/myRadioListenerMale"

android:text="男"/>

<RadioButton android:id="@+id/myRadioListenerFemale"

android:text="女"/>

</RadioGroup>

</LinearLayout>

在单选RadioGroup 中里面的选择项主要是由RadioButton 组成,这和一般的主键区别不大 radiogroup里面的属性就不一一介绍了。

private RadioGroup radioGroup;

private TextView textView;

private RadioButton btMale,btFemale;

protectedvoid onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

super.setContentView(R.layout.myradiolistener);

this.radioGroup=(RadioGroup)super.findViewById(R.id.myRadioListenerRG);

this.textView=(TextView)super.findViewById(R.id.myRadioListenerTV);

this.btMale=(RadioButton)super.findViewById(R.id.myRadioListenerMale);

this.btFemale=(RadioButton)super.findViewById(R.id.myRadioListenerFemale);

this.radioGroup.setOnCheckedChangeListener(new CheckedChanegdListener());

}

public RadioGroup getRadioGroup() {

returnradioGroup;

}

publicvoid setRadioGroup(RadioGroup radioGroup) {

this.radioGroup = radioGroup;

}

public TextView getTextView() {

returntextView;

}

publicvoid setTextView(TextView textView) {

this.textView = textView;

}

public RadioButton getBtMale() {

returnbtMale;

}

publicvoid setBtMale(RadioButton btMale) {

this.btMale = btMale;

}

public RadioButton getBtFemale() {

returnbtFemale;

}

publicvoid setBtFemale(RadioButton btFemale) {

this.btFemale = btFemale;

}

this.radioGroup.setOnCheckedChangeListener(new CheckedChanegdListener());

就是单选按键事件的重要点,我们不推荐在里面直接写内部类的方式

在单选RadioGroup 主要是实现CheckedChanegdListener方法

这个类是实现OnCheckedChangeListener这个接口的

publicvoid onCheckedChanged(RadioGroup group, int checkedId) {

if(group.getId()==R.id.myRadioListenerRG){

String temp="";

myRadioListener my1=(myRadioListener)group.getContext();

if(my1.getBtMale().getId()==checkedId){

temp="您选择的性别是:"+my1.getBtMale().getText();

}elseif(my1.getBtFemale().getId()==checkedId){

temp="您选择的性别是:"+my1.getBtFemale().getText();

}

my1.getTextView().setText(temp);

}

个参数第一个是当前的单选按键,第二个是被选中的radiobutton的id

group.getId()==R.id.myRadioListenerRG 判断当前是对那个单选按键操作

 

1:下拉列表(Spinner)

下拉列表的的主键是Spinner 这个主键和其他的主键有点区别,主要是数据源的来源,可以在代码中实现,也可以用配置的方式

下面的程序是用代码实现数据源的

<?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="fill_parent"

android:orientation="vertical">

<TextView android:id="@+id/mySpinnerClickTV"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="您选择的颜色是:"/>

<Spinner android:id="@+id/mySpinnerClickSpinner"

android:layout_width="fill_parent"

android:layout_height="wrap_content"/>

</LinearLayout>

package com.bruce;

import com.bruce.OnClickListener.ItemClickListenerImpl;

import com.bruce.OnClickListener.ItemSelectedListenerImpl;

import android.app.Activity;

import android.os.Bundle;

import android.widget.ArrayAdapter;

import android.widget.Spinner;

import android.widget.TextView;

publicclass mySpinnerClick extends Activity{

private TextView tv;

private Spinner spinner;

private ArrayAdapter<String> adapterColor=null;

private String [] colorArray={"红","黄","蓝"};

public TextView getTv() {

returntv;

}

publicvoid setTv(TextView tv) {

this.tv = tv;

}

public Spinner getSpinner() {

returnspinner;

}

publicvoid setSpinner(Spinner spinner) {

this.spinner = spinner;

}

protectedvoid onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

super.setContentView(R.layout.myspinnerclick);

this.tv=(TextView)super.findViewById(R.id.mySpinnerClickTV);

this.spinner=(Spinner)super.findViewById(R.id.mySpinnerClickSpinner);

this.adapterColor=new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item,colorArray);

this.adapterColor.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

this.spinner.setAdapter(adapterColor);

this.spinner.setPrompt("您选择的颜色是:");

this.spinner.setOnItemSelectedListener(new ItemSelectedListenerImpl());

}

}

在下拉列表中主要装载数据的是个

this.adapterColor=new ArrayAdapter<String>(this,android.R.layout.simple_spinner_item,colorArray);

创建一个ArrayAdapter 并把数据和其放在了一起android.R.layout.simple_spinner_item是怎么在主键中展现

 

his.adapterColor.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);打开下拉列表是用什么的方式

spinner其自身也有很多的方法比如设置下拉列表头this.spinner.setPrompt("您选择的颜色是:");

其选择事件是this.spinner.setOnItemSelectedListener(new ItemSelectedListenerImpl())

个方法

publicvoid onItemSelected(AdapterView<?> parent, View view, int position,

long id) {

System.out.println(parent.getId());

System.out.println(view.getId());

System.out.println(R.id.mySpinnerClickSpinner);

System.out.println(view.getId() == R.id.mySpinnerClickSpinner);

if(parent.getId()==R.id.mySpinnerClickSpinner){

String value = parent.getItemAtPosition(position).toString();

mySpinnerClick my1 = (mySpinnerClick) view.getContext();

my1.getTv().setText("您选择的颜色是:" + value);

}

publicvoid onNothingSelected(AdapterView<?> arg0) {

// TODO Auto-generated method stub

}

个参数,parent当前下拉列表,view当前视图,position下拉列表id,id选择的下拉列表值

onItemSelected是对下拉列表操作的时候做的事

onNothingSelected 不做任何操作的时候做的事

[置顶] Android事件—单选按键和下拉按键的更多相关文章

  1. Android之RecyclerView轻松实现下拉刷新和加载更多

    今天研究了下RecyclerView的滑动事件,特别是下拉刷新和加载更多事件,在现在几乎所有的APP显示数据列表时都用到了.自定义RecyclerView下拉刷新和加载更多听上去很复杂,实际上并不难, ...

  2. Android UI--自定义ListView(实现下拉刷新+加载更多)

    Android UI--自定义ListView(实现下拉刷新+加载更多) 关于实现ListView下拉刷新和加载更多的实现,我想网上一搜就一堆.不过我就没发现比较实用的,要不就是实现起来太复杂,要不就 ...

  3. [置顶] Android源码分析-点击事件派发机制

    转载请注明出处:http://blog.csdn.net/singwhatiwanna/article/details/17339857 概述 一直想写篇关于Android事件派发机制的文章,却一直没 ...

  4. [置顶] Android开发笔记(成长轨迹)

    分类: 开发学习笔记2013-06-21 09:44 26043人阅读 评论(5) 收藏 Android开发笔记 1.控制台输出:called unimplemented OpenGL ES API ...

  5. [置顶] Android图片异步加载之Android-Universal-Image-Loader

    将近一个月没有更新博客了,由于这段时间以来准备毕业论文等各种事务缠身,一直没有时间和精力沉下来继续学习和整理一些东西.最近刚刚恢复到正轨,正好这两天看了下Android上关于图片异步加载的开源项目,就 ...

  6. Android事件分发机制(下)

    这篇文章继续讨论Android事件分发机制,首先我们来探讨一下,什么是ViewGroup?它和普通的View有什么区别? 顾名思义,ViewGroup就是一组View的集合,它包含很多的子View和子 ...

  7. 【转】 [置顶] Android 通知栏Notification的整合 全面学习 (一个DEMO让你完全了解它)

    在Android的应用层中,涉及到很多应用框架,例如:Service框架,Activity管理机制,Broadcast机制,对话框框架,标题栏框架,状态栏框架,通知机制,ActionBar框架等等. ...

  8. 【朝花夕拾】Android自定义View篇之(七)Android事件分发机制(下)滑动冲突解决方案总结

    前言 转载请声明,转自[https://www.cnblogs.com/andy-songwei/p/11072989.html],谢谢! 前面两篇文章,花了很大篇幅讲解了Android的事件分发机制 ...

  9. [置顶] Android系统五大布局详解Layout

    我们知道Android系统应用程序一般是由多个Activity组成,而这些Activity以视图的形式展现在我们面前,视图都是由一个一个的组件构成的.组件就是我们常见的Button.TextEdit等 ...

随机推荐

  1. 如何使用Ubuntu打电话

    在这个视频,我们学习如何使用Ubuntu打电话.Ubuntu手机的很多用户谁是不是很熟悉. 特别是,他什么都无所谓的物理按键(菜单键.home纽带.回车键).然后用户如何控制手机它?Ubuntu手机凭 ...

  2. View Component

    View Component 在之前的MVC中,我们经常需要类似一种小部件的功能,通常我们都是使用Partial View来实现,因为MVC中没有类似Web Forms中的WebControl的功能. ...

  3. 绑定枚举到dropdownlist

    pageTools.BindEnumToDropdownList(typeof(enumDealerArea), ddlBmwArea, new ListItem("--请选择--" ...

  4. mysql_【MySQL】常见的mysql 进程state

    Analyzing 线程是对MyISAM 表的统计信息做分析(例如, ANALYZE TABLE ). checking permissions 线程是检查服务器是否具有所需的权限来执行该语句. Ch ...

  5. 华为-on练习--身高找到最好的二人

    称号: 离5个人选择2个人作为礼工具.中的每个个体的身高的范围160-190,要求2个人高差值至少(假设差异值一样,他们中最高的选择).输出的两个人的身高升序. Smple input:161 189 ...

  6. dedeCMS中单独调用子栏目模板和子栏目的文章时修改源代码给channel和chanenartllist加上limit

    在网站文件中找到include-taglib-chanel.lib.php,和chaneartllist.lib.php 下载用php的IDE打开, chanel.php加入limit属性修改如下 & ...

  7. crm创建和编辑全局选项集

    一个选项集就是可包含在一个实体中的某种类型的字段.它定义一组选项.当一个选项集显示在窗口中时,将使用下拉列表控件.当在 Advanced Find 中显示时,则使用选择列表控件.有时,开发者将选项集称 ...

  8. 表单元素的外观改变(webkit and IE10)

    1.禁止表单默认外观: input,select{ -webkit-appearance:none; appearance:none; }2.伪元素改变ie10表单元素默认外观 select::-ms ...

  9. javascript6

    eval("3+2")//5 eval():全局eval():严格eval() 函数和可执行的对象(callable object) delete一元操作符,善处对象属性或者数组元 ...

  10. ASP.NET中 RegularExpressValidator(正则验证)的使用

    原文:ASP.NET中 RegularExpressValidator(正则验证)的使用 ylbtech-ASP.NET-Control-Validator: RegularExpressValida ...