zoukankan      html  css  js  c++  java
  • listview实现点击条目上的箭头展开隐藏菜单。

    效果如下图,当点击listview中的小三角时,显示出下面布局,再点隐藏, 点击其他条目的三角时,上一个展开的条目隐藏的同时展开当前条目。

    思路是在item布局中放入展开菜单的布局,并设置状态为隐藏,然后再适配器的getview方法中控制其显示和隐藏,具体请查看代码。

    主布局:

    <?xml version="1.0" encoding="utf-8"?>
    <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.create.qdocumentimtest.Main2Activity">
    
    
        <ListView
            android:id="@+id/listview"
            android:layout_width="match_parent"
            android:layout_height="match_parent"/>
    </RelativeLayout>

    item布局

    <?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="wrap_content"
        android:orientation="vertical"
    
        >
    
        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="70dp">
    
            <ImageView
                android:id="@+id/imageview"
                android:layout_width="50dp"
                android:layout_height="50dp"
                android:layout_centerVertical="true"
                android:layout_marginLeft="10dp"
                android:src="@drawable/logo" />
    
            <TextView
                android:id="@+id/tv_test"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerVertical="true"
                android:layout_marginLeft="10dp"
                android:layout_toRightOf="@id/imageview"
                android:text="这个是测试用条目" />
    
            <ImageView
                android:id="@+id/checkbox"
                android:layout_width="18dp"
                android:layout_height="18dp"
                android:layout_alignParentRight="true"
                android:layout_centerVertical="true"
                android:background="@drawable/right_icon_selector"
                android:layout_marginRight="10dp"
                android:clickable="true"
                />
    
        </RelativeLayout>
    
        <include layout="@layout/item_hide_layout"
            />
    
    
    </LinearLayout>

    include中就是隐藏的布局,如下:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:background="#bcb9b9"
    android:id="@+id/ll_hide"
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:orientation="horizontal"
    android:visibility="gone"//设置初始时隐藏状态。
        >
    
    <TextView
        android:id="@+id/hide_1"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:gravity="center"
        android:text="加密" />
    
    <TextView
        android:id="@+id/hide_2"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:gravity="center"
        android:text="解密" />
    
    <TextView
        android:id="@+id/hide_3"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:gravity="center"
        android:text="分享" />
    
    <TextView
        android:id="@+id/hide_4"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:gravity="center"
        android:text="删除" />
    
    <TextView
        android:id="@+id/hide_5"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:gravity="center"
        android:text="属性" />
    
    
    </LinearLayout>

    activity代码:

    package com.create.qdocumentimtest;
    
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.BaseAdapter;
    import android.widget.ImageView;
    import android.widget.LinearLayout;
    import android.widget.ListView;
    import android.widget.TextView;
    import android.widget.Toast;
    
    import java.util.ArrayList;
    
    public class Main2Activity extends AppCompatActivity {
        private ListView listview;
        private ArrayList<String> list;
        public int clickPosition = -1;
        public Boolean flag = false;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main2);
            listview = (ListView) findViewById(R.id.listview);
            list = new ArrayList<>();
            for (int i = 0; i < 200; i++) {
                list.add("我是第" + i + "个条目");
            }
            adapter = new MyAdapter();
            listview.setAdapter(adapter);
        }
    
        private MyAdapter adapter;
    
        class MyAdapter extends BaseAdapter implements View.OnClickListener {
    
    
            @Override
            public int getCount() {
                return list.size();
            }
    
            @Override
            public Object getItem(int position) {
                return null;
            }
    
            @Override
            public long getItemId(int position) {
                return 0;
            }
    
            @Override
            public View getView(final int position, View convertView, ViewGroup parent) {
                final MyViewHolder vh;
                if (convertView == null) {
                    convertView = View.inflate(Main2Activity.this, R.layout.item_layout, null);
                    vh = new MyViewHolder(convertView);
                    convertView.setTag(vh);
                } else {
                    vh = (MyViewHolder) convertView.getTag();
                }
                vh.tv_test.setText(list.get(position));
                //刷新adapter的时候,getview重新执行,此时对在点击中标记的position做处理
                if (clickPosition == position) {//当条目为刚才点击的条目时
                    if (vh.selectorImg.isSelected()) {//当条目状态图标为选中时,说明该条目处于展开状态,此时让它隐藏,并切换状态图标的状态。
                        vh.selectorImg.setSelected(false);
                        vh.ll_hide.setVisibility(View.GONE);
                        Log.e("listview","if执行");
                       clickPosition=-1;//隐藏布局后需要把标记的position去除掉,否则,滑动listview让该条目划出屏幕范围,
                        // 当该条目重新进入屏幕后,会重新恢复原来的显示状态。经过打log可知每次else都执行一次 (条目第二次进入屏幕时会在getview中寻找他自己的状态,相当于重新执行一次getview) 
                        //因为每次滑动的时候没标记得position填充会执行click
                    } else {//当状态条目处于未选中时,说明条目处于未展开状态,此时让他展开。同时切换状态图标的状态。
                        vh.selectorImg.setSelected(true);
                        vh.ll_hide.setVisibility(View.VISIBLE);
    
                        Log.e("listview","else执行");
                    }
    //                ObjectAnimator//
    //                        .ofInt(vh.ll_hide, "rotationX", 0.0F, 360.0F)//
    //                        .setDuration(500)//
    //                        .start();
                    // vh.selectorImg.setSelected(true);
                } else {//当填充的条目position不是刚才点击所标记的position时,让其隐藏,状态图标为false。
    
                    //每次滑动的时候没标记得position填充会执行此处,把状态改变。所以如果在以上的if (vh.selectorImg.isSelected()) {}中不设置clickPosition=-1;则条目再次进入屏幕后,还是会进入clickposition==position的逻辑中
                    //而之前的滑动(未标记条目的填充)时,执行此处逻辑,已经把状态图片的selected置为false。所以上面的else中的逻辑会在标记过的条目第二次进入屏幕时执行,如果之前的状态是显示,是没什么影响的,再显示一次而已,用户看不出来,但是如果是隐藏状态,就会被重新显示出来
                    vh.ll_hide.setVisibility(View.GONE);
                    vh.selectorImg.setSelected(false);
    
                    Log.e("listview","状态改变");
                }
                vh.hide_1.setOnClickListener(this);
                vh.hide_2.setOnClickListener(this);
                vh.hide_3.setOnClickListener(this);
                vh.hide_4.setOnClickListener(this);
                vh.hide_5.setOnClickListener(this);
                vh.selectorImg.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View v) {
                        Toast.makeText(Main2Activity.this, "被点了", Toast.LENGTH_SHORT).show();
                        clickPosition = position;//记录点击的position
                        notifyDataSetChanged();//刷新adapter重新填充条目。在重新填充的过程中,被记录的position会做展开或隐藏的动作,具体的判断看上面代码
                   //在此处需要明确的一点是,当adapter执行刷新操作时,整个getview方法会重新执行,也就是条目重新做一次初始化被填充数据。
                        //所以标记position,不会对条目产生影响,执行刷新后 ,条目重新填充当,填充至所标记的position时,我们对他处理,达到展开和隐藏的目的。
                     //明确这一点后,每次点击代码执行逻辑就是 onclick()---》getview()
                    }
                });
                return convertView;
            }
    
            @Override
            public void onClick(View v) {
                switch (v.getId()) {
                    case R.id.hide_1:
                        Toast.makeText(Main2Activity.this, "加密", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.hide_2:
                        Toast.makeText(Main2Activity.this, "解密", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.hide_3:
                        Toast.makeText(Main2Activity.this, "分享", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.hide_4:
                        Toast.makeText(Main2Activity.this, "删除", Toast.LENGTH_SHORT).show();
                        break;
                    case R.id.hide_5:
                        Toast.makeText(Main2Activity.this, "属性", Toast.LENGTH_SHORT).show();
                        break;
                }
            }
    
    
            class MyViewHolder {
                View itemView;
                TextView tv_test;
                TextView hide_1, hide_2, hide_3, hide_4, hide_5;
                ImageView selectorImg;
                LinearLayout ll_hide;
    
                public MyViewHolder(View itemView) {
                    this.itemView = itemView;
                    tv_test = (TextView) itemView.findViewById(R.id.tv_test);
                    selectorImg = (ImageView) itemView.findViewById(R.id.checkbox);
                    hide_1 = (TextView) itemView.findViewById(R.id.hide_1);
                    hide_2 = (TextView) itemView.findViewById(R.id.hide_2);
                    hide_3 = (TextView) itemView.findViewById(R.id.hide_3);
                    hide_4 = (TextView) itemView.findViewById(R.id.hide_4);
                    hide_5 = (TextView) itemView.findViewById(R.id.hide_5);
                    ll_hide = (LinearLayout) itemView.findViewById(R.id.ll_hide);
                }
            }
        }
    
    
    }

    目前没有加入动画效果,所以点击显示的状态有点生硬,后续处理会加入展开和隐藏的上下平移动画。

  • 相关阅读:
    php中运算符的分类及注意事项
    ecshopv3.6安装
    phpstudy多站点配置教程
    织梦dedecms出现DedeCMS Error: (PHP 5.3 and above) Please set 'request_order' ini value to i解决办法
    thinkphp3.2批量删除功能
    怎么使用阿里图标库
    人人网,微博,QQ空间,朋友圈,常用API调用实现方法
    ueditor注意事项
    大图在小于自身的div中,水平居中
    thinkphp3.2 实现分页功能
  • 原文地址:https://www.cnblogs.com/epmouse/p/5555264.html
Copyright © 2011-2022 走看看