当前位置: 首页 > 编程笔记 >

android实现下拉菜单三级联动

师承弼
2023-03-14
本文向大家介绍android实现下拉菜单三级联动,包括了android实现下拉菜单三级联动的使用技巧和注意事项,需要的朋友参考一下

android中的下拉菜单联动应用非常普遍,android中的下拉菜单用Spinner就能实现,以下列子通过简单的代码实现三级菜单联动。

一 样式文件

<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="com.example.spinner.MainActivity" >
 
  <Spinner android:layout_width="match_parent"
    android:layout_height="wrap_content"
    
    android:id="@+id/spn"
    android:dropDownWidth="200dp"/>
  
  <Spinner android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@id/spn"
    android:id="@+id/city"
    android:dropDownWidth="200dp"/>
  <Spinner android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_below="@id/city"
    android:id="@+id/counstryside"
    android:dropDownWidth="200dp"/>
 
</RelativeLayout>

二 联动逻辑代码

package com.example.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;
 
/**
 * @author ZMC
 * 三级联动主要是灵活的应用三维数组
 */
public class MainActivity extends Activity {
 private String province[] = new String[]{"江西","湖南"};
 private Spinner spinner1,spinner2,spinner3;
 private int provinceindex;
 private String city [][] = {{"南昌","赣州"},{"长沙","湘潭"}};
 private String counstryside [][][] = {{{"青山湖区","南昌县"},{"章贡区","赣县"}},{{"长沙县","沙县"},{"湘潭县","象限"}}};
 ArrayAdapter<String> adapter1,adapter2,adapter3;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 spinner1 = (Spinner) findViewById(R.id.spn);
 adapter1 = new ArrayAdapter<>(this, android.R.layout.simple_dropdown_item_1line,province);
 spinner1.setAdapter(adapter1);
 
 spinner2 = (Spinner)findViewById(R.id.city);
 adapter2 = new ArrayAdapter<>(this, android.R.layout.simple_dropdown_item_1line,city[0]);
 spinner2.setAdapter(adapter2);
 
 spinner3 = (Spinner)findViewById(R.id.counstryside);
 adapter3 = new ArrayAdapter<>(this, android.R.layout.simple_dropdown_item_1line,counstryside[0][0]);
 spinner3.setAdapter(adapter3);
 spinner1.setOnItemSelectedListener(new OnItemSelectedListener() {
 
  @Override
  public void onItemSelected(AdapterView<?> parent, View view,
   int position, long id) {
  // TODO Auto-generated method stub
  provinceindex = position;
  adapter2 = new ArrayAdapter<>(MainActivity.this, android.R.layout.simple_dropdown_item_1line,city[position]);
  spinner2.setAdapter(adapter2);
  }
 
  @Override
  public void onNothingSelected(AdapterView<?> parent) {
  // TODO Auto-generated method stub
  
  }
 });
 
 spinner2.setOnItemSelectedListener(new OnItemSelectedListener() {
 
  @Override
  public void onItemSelected(AdapterView<?> parent, View view,
   int position, long id) {
  // TODO Auto-generated method stub
  
  adapter3 = new ArrayAdapter<>(MainActivity.this, android.R.layout.simple_dropdown_item_1line,counstryside[provinceindex][position]);
  //adapter3.notifyDataSetChanged();
  spinner3.setAdapter(adapter3);
  }
 
  @Override
  public void onNothingSelected(AdapterView<?> parent) {
  // TODO Auto-generated method stub
  //当时据为空的时候触发的
  }
 });
 
 
 }
 
 
}

三 结果

四 总结

三级联动主要是灵活的应用三维数组,这样能很方便的通过数组索引将三个菜单关联,同时通过设置Spinner的setOnItemSelectedListener来监听选择的动作,动态设置下拉菜单的内容。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍javascript实现省市区三级联动下拉框菜单,包括了javascript实现省市区三级联动下拉框菜单的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript实现省市区三级联动下拉框菜单代码。分享给大家供大家参考,具体如下 运行效果截图如下: 首先写一个静态的页面: 调用的geo.js源码:

  • 本文向大家介绍iOS 三级下拉菜单功能实现,包括了iOS 三级下拉菜单功能实现的使用技巧和注意事项,需要的朋友参考一下 前言 App 常用控件 -- 多级下拉菜单, 如团购类, 房屋类, 对数据进行筛选. 有一级, 二级, 三级, 再多就不会以这种样式,呈现给用户了. 作者就简单聊一下 多级下拉菜单 一 目标 默认显示一个 TableView, 点击数据后, 添加第二个TableView, 并实现

  • 本文向大家介绍基于jquery实现三级下拉菜单,包括了基于jquery实现三级下拉菜单的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了jquery三级下拉菜单的具体实现代码,供大家参考,具体内容如下 在写这个的时候,首先要捋顺思路。点一个菜单的时候,其他的要闭合,点一级菜单的时候,二三级菜单要闭合,等等。 大致代码如下: 如果要添加样式的话,一定要注意,否则菜单可能会出现错误。 完整

  • 本文向大家介绍ajax三级联动下拉菜单效果,包括了ajax三级联动下拉菜单效果的使用技巧和注意事项,需要的朋友参考一下 ajax写三级联动,先写一个文件类吧,以后用的时候直接调用即可; 来找一张表: 实现: 中国地域的三级联动:省、市、区; 图: 说一下思路: (1)当用户选择省份的时候触发事件,把当前的省份的id通过ajax发出请求传递到服务端的程序中 (2)比如取中国地域,中国是0001,那么

  • 问题内容: 我试图使用AngularJS创建一个链接/级联的下拉列表(选择元素),但是我很难用我的对象属性过滤和更新“ selected”属性。 首次加载页面时,所选项目将被过滤并正确显示在下拉菜单中。更改父级下拉菜单后,子级选择项不会抓住已过滤列表中的第一个项,导致子级下拉项不会更新。 任何见解将不胜感激,请注意,我将父/子/孙子数组分开(而不是在子数组中),因为最终我将从SQL中的单独spoc

  • 本文向大家介绍JS实现的Select三级下拉菜单代码,包括了JS实现的Select三级下拉菜单代码的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JS实现的Select三级下拉菜单。分享给大家供大家参考。具体如下: 这里使用js实现Select三级下拉菜单,比如全国省市城市选择、数码类产品分类、人才类别选择等,都比较具有代表性,在表单中容易使用Select下拉列表菜单供用户选择,当然,自己