iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android实现横向二级菜单
  • 186
分享到

Android实现横向二级菜单

菜单Android 2022-06-06 08:06:01 186人浏览 八月长安
摘要

本文实例为大家分享了Android二级横向菜单的实现过程.效果如上图:     这种横向的二级菜单在很多的app都有所应用.效果看起来还是非常的美观的.也算

本文实例为大家分享了Android二级横向菜单的实现过程.效果如上图:

 

  这种横向的二级菜单在很多的app都有所应用.效果看起来还是非常的美观的.也算是项目需要,自己也就学了一下这个效果,首先说一下逻辑.实现的方式其实并不是很难..只不过逻辑上可能有点复杂.原理其实就是一个按钮.当触发按钮的时候弹出PopWindow.PopWindow由两个ListView构成..对两个ListView适当的适配.就可以实现这个效果了..

  实现这种效果可以有两种不同的方式..一种是直接在布局文件layout.xml中写..最上方的可以是一个按钮.也可以是多个按钮..多个按钮就可以使用RadioGroup去实现..下方则采用ScrollView去实现也是可以的..

  不过我还是说一下第二种方式..直接用Java去写这个布局..通过使用自定义控件的方式实现这个效果..既然是自定义,那么首先我们需要继承一个布局.布局可以使用LinearLayout或者RelativeLayout.

  setValue()方法..

  setValue()方法是自定义的方法..主要是用于加载布局.以及在布局当中添加相关的View.没有加载任何的xml文件..


  
  @SuppressLint("ResourceAsColor") 
  public void setValue(ArrayList<String> textArray, ArrayList<View> viewArray) {
    if (mContext == null) {
      return;
    }
    LayoutInflater inflater = (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    mTextList = textArray;
    for (int i = 0; i < viewArray.size(); i++) {
      //这里就添加了一个View..
      final RelativeLayout r = new RelativeLayout(mContext);
      int maxHeight = (int) (displayHeight * 0.5);  //定义布局的高度..
      RelativeLayout.LayoutParams rl = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.MATCH_PARENT, maxHeight);
      r.addView(viewArray.get(i), rl); //在布局中添加View并指定参数
      mViewList.add(r);
      r.setTag(SMALL);
      //定义最上方的按钮,并在布局中添加这个按钮。并设置按钮的text
      ToggleButton tButton = (ToggleButton) inflater.inflate(R.layout.toggle_button, this, false);
      addView(tButton);
      mToggleList.add(tButton);
      tButton.setTag(i);
      tButton.setText(mTextList.get(i));
      //用于实现当PopWindow显示时.再次点击收回PopWindow
      r.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
          onPressBack();
        }
      });
      r.setBackgroundColor(mContext.getResources().getColor(R.color.popup_main_background));
      //当按钮被点击后需要触发的监听
      tButton.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View view) {
          ToggleButton tButton = (ToggleButton) view;
          
          if (selectedButton != null && selectedButton != tButton) {
            selectedButton.setChecked(false);
          }
          selectedButton = tButton;
          selectPosition = (Integer) selectedButton.getTag();
          
          startAnimation();
          if (mOnButtonClickListener != null && tButton.isChecked()) {
            mOnButtonClickListener.onClick(selectPosition);
          }
        }
      });
    }
  }

  那么设置完了布局的样式后..只有一个ToggleButton按钮.点击后没有任何的效果.我们需要去定义一个新的View视图.用于点击按钮后需要显示的弹出窗.那么这个弹出窗也需要自定义..

 弹出窗则采用两个ListView的形式进行显示.在布局中将两个ListView进行添加.对每一个ListView设置相应的适配器.然后将这个View添加到上面的主View当中.就可以实现当button被点击后,弹出窗在下方进行显示的效果..

 ChildView() 弹出窗View的布局实现方式..

 这里定义了这个View,并完成相应的初始化操作.设置对应的适配器也就完成了..


package com.example.view;
import java.util.ArrayList;
import java.util.LinkedList;
import android.content.Context;
import android.util.AttributeSet;
import android.util.SparseArray;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.ListView;
import com.example.adapter.TextAdapter;
import com.example.expandtabview.R;
public class ChildView extends LinearLayout {
  private ListView regionListView;  //主ListView
  private ListView plateListView;  //子ListView
  //主ListView每一个Item对应的text
  private String LeftFaString[] = new String[] { "美食", "快餐小吃", "火锅", "海鲜/烧烤",
      "特色菜", "香锅/烤鱼", "地方菜", "东南亚菜", "西餐", "日韩料理" };
  //子ListView每一个Item对应的text..采用了二维数组的实现方式..
  private String LeftCh1String[][] = new String[][] {
      { "全部" },
      { "全部", "中式简餐", "地方小吃", "盖浇饭", "米粉米线", "面馆", "麻辣烫", "黄焖鸡米饭",
          "鸭脖卤味", "饺子馄饨", "炸鸡炸串", "包子/粥", "零食", "生煎锅贴", "冒菜" },
      { "全部", "其他火锅" }, { "全部", "小龙虾" }, { "全部" }, { "全部", "香锅", "烤鱼" },
      { "全部", "鲁菜", "川菜", "其他" }, { "全部" },
      { "全部", "意面披萨", "西式快餐", "其他西餐" }, { "全部", "韩式简餐", "韩国料理" } };
  //添加主ListView中的数据信息
  private ArrayList<String> groups = new ArrayList<String>();
  //添加子ListView中的数据信息
  private LinkedList<String> childrenItem = new LinkedList<String>();
  //稀疏数组
  private SparseArray<LinkedList<String>> children = new SparseArray<LinkedList<String>>();
  //为ListView设置适配器
  private TextAdapter plateListViewAdapter;
  private TextAdapter earaListViewAdapter;
  //监听事件的设置
  private OnSelectListener mOnSelectListener;
  private int tEaraPosition = 0;   //用于保存当前主ListView被点击的Item对应的Position.
  private int tBlockPosition = 0;    //用于保存当前子ListView被点击的Item对应的Position.
  private String showString = "";
  public ChildView(Context context) {
    super(context);
    init(context);
  }
  public ChildView(Context context, AttributeSet attrs) {
    super(context, attrs);
    init(context);
  }
  private void init(Context context) {
    LayoutInflater inflater = (LayoutInflater) context
        .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    //加载布局,绑定ID.
    inflater.inflate(R.layout.view_region, this, true);
    regionListView = (ListView) findViewById(R.id.listView);
    plateListView = (ListView) findViewById(R.id.listView2);
    //初始化ListView中每一个item对应的text
    for(int i=0;i<10;i++){
      groups.add(LeftFaString[i]);
      LinkedList<String> tItem = new LinkedList<String>();
      for(int j=0;j<LeftCh1String[i].length;j++){
        tItem.add(LeftCh1String[i][j]);
      }
      children.put(i, tItem);
    }
    //主ListView列表项的适配器
    earaListViewAdapter = new TextAdapter(context, groups,
        R.drawable.choose,
        R.drawable.choose_eara_item_selector);
    earaListViewAdapter.setTextSize(12);
    earaListViewAdapter.setSelectedPositionNoNotify(tEaraPosition);
    regionListView.setAdapter(earaListViewAdapter);
    earaListViewAdapter
        .setOnItemClickListener(new TextAdapter.OnItemClickListener() {
          @Override
          public void onItemClick(View view, int position) {
            if (position < children.size()) {
              childrenItem.clear();
              //获取这一页的所有数据信息..然后唤醒适配器更新数据
              childrenItem.addAll(children.get(position));
              plateListViewAdapter.notifyDataSetChanged();
            }
          }
        });
    if (tEaraPosition < children.size())
      childrenItem.addAll(children.get(tEaraPosition));
    //子ListView的适配器
    plateListViewAdapter = new TextAdapter(context, childrenItem,
        R.drawable.choose_item_right,
        R.drawable.choose_plate_item_selector);
    plateListViewAdapter.setTextSize(12);
    plateListViewAdapter.setSelectedPositionNoNotify(tBlockPosition);
    plateListView.setAdapter(plateListViewAdapter);
    //设置当Item被点击后触发的监听.
    plateListViewAdapter
        .setOnItemClickListener(new TextAdapter.OnItemClickListener() {
          @Override
          public void onItemClick(View view, final int position) {
            //获取被点击的Item的文字数据
            showString = childrenItem.get(position);
            if (mOnSelectListener != null) {
              mOnSelectListener.getValue(showString);
            }
          }
        });
    if (tBlockPosition < childrenItem.size())
      showString = childrenItem.get(tBlockPosition);
    setDefaultSelect();
  }
  //设置当前Item的Position.
  public void setDefaultSelect() {
    //默认选择的Item项
    regionListView.setSelection(tEaraPosition);
    plateListView.setSelection(tBlockPosition);
  }
  public String getShowText() {
    return showString;
  }
  public void setOnSelectListener(OnSelectListener onSelectListener) {
    mOnSelectListener = onSelectListener;
  }
  public interface OnSelectListener {
    public void getValue(String showText);
  }
}

  那么最后就剩下适配器了..

  ArrayAdapter<String>

  这里使用了ArrayAdapter适配器.继承与BaseAdapter.可以用于显示文本数据..我们也都知道,适配器必须要实现的方法就是getView()方法了..那么我们就简单的看一下这个方法..


  @SuppressLint("ResourceAsColor") @SuppressWarnings("deprecation")
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    TextView view;
    if (convertView == null) {
      view = (TextView) LayoutInflater.from(mContext).inflate(R.layout.choose_item, parent, false);
    } else {
      view = (TextView) convertView;
    }
    view.setTag(position);
    String mString = "";
    if (mListData != null) {
      if (position < mListData.size()) {
        mString = mListData.get(position);
      }
    } else if (mArrayData != null) {
      if (position < mArrayData.length) {
        mString = mArrayData[position];
      }
    }
    if (mString.contains("不限"))
      view.setText("不限");
    else
      view.setText(mString);
    view.setTextSize(TypedValue.COMPLEX_UNIT_SP,textSize);
    if (selectedText != null && selectedText.equals(mString)) {
      view.setBackgroundDrawable(selectedDrawble);//设置选中的背景图片
    } else {
      view.setBackgroundDrawable(mContext.getResources().getDrawable(nORMalDrawbleId));//设置未选中状态背景图片
    }
    view.setPadding(20, 0, 0, 0);
    view.setOnClickListener(onClickListener);
    return view;
  }

  适配的工作还是非常的简单的.仅仅一个TextView就可以搞定了.当然我们也可以写一个比较复杂的样式.在一个Layout内部定义一些复杂的控件.就能够实现更好的效果.

  最后再MainActivity中的布局文件中加载这个控件,简单的做一些初始化操作就可以实现了..


package com.example.expandtabview;
import java.util.ArrayList;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;
import com.example.view.ExpandTabView;
import com.example.view.ChildView;
public class MainActivity extends Activity {
  private ExpandTabView expandTabView;
  private ArrayList<View> mViewArray = new ArrayList<View>();
  private ChildView viewLeft;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initView();
    initVaule();
    initListener();
  }
  private void initView() {
    //初始化控件
    expandTabView = (ExpandTabView) findViewById(R.id.expandtab_view);
    viewLeft = new ChildView(this);
  }
  private void initVaule() {
    mViewArray.add(viewLeft);
    //设置顶部数据信息
    ArrayList<String> mTextArray = new ArrayList<String>();
    mTextArray.add("全部");
    expandTabView.setValue(mTextArray, mViewArray);
    expandTabView.setTitle(viewLeft.getShowText(), 0);
  }
  private void initListener() {
    viewLeft.setOnSelectListener(new ChildView.OnSelectListener() {
      @Override
      public void getValue(String showText) {
        onRefresh(viewLeft,showText);
      }
    });
  }
  //视图被点击后刷新数据
  private void onRefresh(View view, String showText) {
    expandTabView.onPressBack();
    int position = getPositon(view);
    if (position >= 0 && !expandTabView.getTitle(position).equals(showText)) {
      expandTabView.setTitle(showText, position);
    }
    Toast.makeText(MainActivity.this, showText, Toast.LENGTH_SHORT).show();
  }
  //获取当前的view
  private int getPositon(View tView) {
    for (int i = 0; i < mViewArray.size(); i++) {
      if (mViewArray.get(i) == tView) {
        return i;
      }
    }
    return -1;
  }
}

 这里只是贴了一些核心代码.其他的涉及的一些不重要的代码就不在这里粘贴了..最后放一张图片流程.方便大家去理解.最后给出源代码.

 放一个源代码提供下载,方便去理解这个过程:Android实现横向二级菜单

您可能感兴趣的文章:Android编程实现二级下拉菜单及快速搜索的方法Android仿QQ分组实现二级菜单展示


--结束END--

本文标题: Android实现横向二级菜单

本文链接: https://www.lsjlt.com/news/25381.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 利用CSS实现多级下拉横向导航菜单
    本篇内容主要讲解“利用CSS实现多级下拉横向导航菜单”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“利用CSS实现多级下拉横向导航菜单”吧!本文实例为大家分享了纯...
    99+
    2024-04-02
  • JavaScript实现伸缩二级菜单
    JavaScript实现伸缩二级菜单的具体代码,供大家参考,具体内容如下 伸缩二级菜单: 案例说明:效果图如下,一次只能打开一个,打开后,+ 号变 - 。 HTML 代码 &l...
    99+
    2024-04-02
  • java二级菜单怎么实现
    实现Java二级菜单可以通过使用多层嵌套的菜单结构来实现。以下是一个简单的示例代码: import java.util.Scanne...
    99+
    2024-03-13
    java
  • 纯css如何实现二级菜单
    这篇“纯css如何实现二级菜单”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“纯css如何实现二级菜单”文章吧。HTML结构设...
    99+
    2023-07-05
  • AJAX 中怎么实现二级联级菜单
    AJAX 中怎么实现二级联级菜单,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 客户端代码: <!DOCT...
    99+
    2024-04-02
  • JavaScript实现二级菜单的制作
    本文实例为大家分享了JavaScript实现二级菜单效果的具体代码,供大家参考,具体内容如下 这次实现的效果图如下: 这个二级菜单实现的效果是: 当点击某一个框时,会将已经打开的框...
    99+
    2024-04-02
  • css如何实现动态二级菜单
    这篇文章将为大家详细讲解有关css如何实现动态二级菜单,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。动态实现简单的二级菜单当鼠标放到一级标签上时,鼠标会变成小手的形状 展示二级菜单,源码如下,复制即可直接...
    99+
    2023-06-08
  • 用纯JS实现二级菜单效果
    本文实例为大家分享了JS实现二级菜单效果的具体代码,供大家参考,具体内容如下 js点击出现二级菜单,点击二级菜单主菜单换成二级菜单 点击出现二级菜单 <style> ...
    99+
    2024-04-02
  • php实现二级联动菜单的方法
    小编给大家分享一下php实现二级联动菜单的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php实现二级联动菜单的方法:首先创建好HTML文件和PHP文件;然后...
    99+
    2023-06-14
  • jQuery插件实现手风琴二级菜单
    本文实例制作了一个用jQuery插件形式实现的手风琴二级菜单,供大家参考,具体内容如下 HTML5结构要求: <div id="accordion"> <...
    99+
    2024-04-02
  • bootstrap如何实现二级下拉菜单效果
    这篇文章将为大家详细讲解有关bootstrap如何实现二级下拉菜单效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下<!DOCTYPE htm...
    99+
    2024-04-02
  • 怎么用CSS+XHTML实现二级导航菜单
    这篇文章主要讲解了“怎么用CSS+XHTML实现二级导航菜单”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用CSS+XHTML实现二级导航菜单”吧!这是...
    99+
    2024-04-02
  • 怎么用CSS实现二级下拉导航菜单
    这篇文章主要讲解了“怎么用CSS实现二级下拉导航菜单”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用CSS实现二级下拉导航菜单”吧!这是一款纯CSS菜单...
    99+
    2024-04-02
  • CSS中怎么实现二级弹出菜单效果
    这篇文章将为大家详细讲解有关CSS中怎么实现二级弹出菜单效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。具体代码如下:<!DOCTYPE ...
    99+
    2024-04-02
  • CSS怎么实现有立体感的横向按钮式菜单效果
    这篇文章主要讲解了“CSS怎么实现有立体感的横向按钮式菜单效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS怎么实现有立体感的横向按钮式菜单效果”吧!...
    99+
    2024-04-02
  • 使用Ajax怎么实现一个二级联动菜单
    本篇文章为大家展示了使用Ajax怎么实现一个二级联动菜单,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。index.jsp<%@ page language="ja...
    99+
    2023-06-08
  • Python下三级菜单实现
    今天学了一个三级菜单,甚是开心!!! 1.流程图 2.代码如下: #!/usr/bin/env python #name bearcatfly university_list = { # 大学列表 "安...
    99+
    2023-01-31
    菜单 Python
  • React四级菜单的实现
    效果图 JS import { Fragment, useState } from 'react'; import styles from './style.less'; cons...
    99+
    2024-04-02
  • Vue3.0实现无限级菜单
    业务需求 菜单项是业务系统的重要组成部分,一般业务系统都要支持显示多级业务菜单,但是根据每个业务人员的权责不同,看到的的菜单项也是不同的。 这就要求页面可以支持无限极菜单显示,根据每...
    99+
    2024-04-02
  • Android studio实现菜单效果
    本文实例为大家分享了Android studio实现菜单效果的具体代码,供大家参考,具体内容如下 一、onCreateOptionsMenu() 首先在res目录下新建一个menu文...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作