仿微信地图的可变化高度的列表页

栏目: Android · 发布时间: 5年前

内容简介:通过拖拽事件,改变列表的高度

点击实现列表的伸缩,拖拽实现列表的伸缩

仿微信地图的可变化高度的列表页

一句话原理

通过拖拽事件,改变列表的高度

代码

activity_map.xml

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <include layout="@layout/common_title_lib" />

    <com.amap.api.maps.MapView
        android:id="@+id/map"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_marginTop="60dp"
        android:layout_weight="1"></com.amap.api.maps.MapView>

    <LinearLayout
        android:id="@+id/ll_line"
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:background="@android:color/white"
        android:orientation="vertical"

        app:layout_constraintBottom_toBottomOf="parent">

        <android.support.constraint.ConstraintLayout
            android:layout_width="match_parent"
            android:layout_height="56dp"
            android:id="@+id/cl_top"
            android:paddingLeft="16dp"
            android:paddingTop="8dp"
            android:paddingRight="16dp">

            <ImageView

                android:layout_width="56dp"
                android:layout_height="8dp"
                android:src="@drawable/gray_tag"
                app:layout_constraintLeft_toLeftOf="parent"
                app:layout_constraintRight_toRightOf="parent" />

            <ImageView
                android:id="@+id/imgVew_1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginTop="8dp"
                android:src="@drawable/red_point"
                app:layout_constraintBottom_toTopOf="@id/imgVew_2"
                app:layout_constraintTop_toTopOf="parent" />


            <TextView
                android:id="@+id/tv_start_address"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="16dp"
                android:textColor="@android:color/black"
                app:layout_constraintBottom_toBottomOf="@id/imgVew_1"

                app:layout_constraintLeft_toRightOf="@id/imgVew_1"
                app:layout_constraintTop_toTopOf="@id/imgVew_1"
                tools:text="山西鼎盛钢铁" />

            <ImageView
                android:id="@+id/imgVew_2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginTop="8dp"
                android:paddingBottom="8dp"
                android:src="@drawable/blue_point"
                app:layout_constraintBottom_toBottomOf="parent"
                app:layout_constraintTop_toBottomOf="@id/imgVew_1" />

            <TextView
                android:id="@+id/tv_end_address"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="16dp"

                android:paddingBottom="8dp"
                android:textColor="@android:color/black"
                app:layout_constraintBottom_toBottomOf="@id/imgVew_2"
                app:layout_constraintLeft_toRightOf="@id/imgVew_2"
                app:layout_constraintTop_toTopOf="@id/imgVew_2"
                tools:text="山西鼎盛钢铁" />
        </android.support.constraint.ConstraintLayout>

        <View
            android:layout_width="match_parent"
            android:layout_height="1dp"
            android:background="@color/edit_hint" />

        <android.support.v7.widget.RecyclerView
            android:id="@+id/lstVew_line"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:layout_constraintBottom_toBottomOf="parent" />
    </LinearLayout>
</android.support.constraint.ConstraintLayout>

关键逻辑代码

llLine = findViewById(R.id.ll_line);
        clTop = findViewById(R.id.cl_top);
 llLineMinHight = (int) (ScreenUtil.getScreenHeight(GpsActivity.this) * 0.3 + 0.5);
        llLineMaxHight = (int) (ScreenUtil.getScreenHeight(GpsActivity.this) * 0.8 + 0.5);
        llLineCurrentHight = llLineMinHight;
        ConstraintLayout.LayoutParams lp = (ConstraintLayout.LayoutParams) llLine.getLayoutParams();
        lp.height = llLineMinHight;
        llLine.setLayoutParams(lp);


        clTop.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                switch (event.getAction()) {
                    case MotionEvent.ACTION_DOWN:
                        // 获取当前列表的高度
                        currentHight = llLine.getLayoutParams().height;
                        lastY = (int) event.getRawY();
                        break;
                        case MotionEvent.ACTION_MOVE:
                        // 滑动的距离
                        int dy = (int) event.getRawY() - lastY;
                        //判断是点击事件还是拖拽事件
                        if(dy==0){
                            isClick=true;
                        }else{
                            isClick=false;
                        }
                        int newHight = currentHight - dy;
                        //判断拖拽的高度在最大值和最小值之间
                        if (newHight >= llLineMaxHight) {
                            llLineCurrentHight = llLineMaxHight;
                            newHight = llLineMaxHight;

                        } else if (newHight <= llLineMinHight) {
                            llLineCurrentHight = llLineMinHight;
                            newHight = llLineMinHight;
                        }
            
                        llLine.getLayoutParams().height = newHight;
                        //刷新UI
                        llLine.requestLayout();
                        break;

                    case MotionEvent.ACTION_UP:
                        // 手指抬起时,获取当前列表的高度
                        currentHight = llLine.getLayoutParams().height;
                        // 点击事件的 展开
                        if (currentHight == llLineMinHight && isClick) {
                            startPropertyAnimation(llLine, llLineMinHight, llLineMaxHight);
                            llLineCurrentHight = llLineMaxHight;
                        } 
                        //如果拖拽的高度接近最大,则缓缓展开
                        else if (currentHight > llLineMinHight && currentHight <= llLineMaxHight/1.5) {
                            startPropertyAnimation(llLine, currentHight, llLineMinHight);
                            llLineCurrentHight = llLineMinHight;
                        } 
                        //如果拖拽的高度接近最小,则缓缓收缩
                        else if (currentHight > llLineMaxHight / 1.5 && currentHight < llLineMaxHight) {
                            startPropertyAnimation(llLine, currentHight, llLineMaxHight);
                            llLineCurrentHight = llLineMaxHight;
                        } 
                        //收缩点击事件
                        else if (currentHight == llLineMaxHight && isClick) {
                            startPropertyAnimation(llLine, llLineMaxHight, llLineMinHight);
                            llLineCurrentHight = llLineMinHight;
                        }
                        clTop.performClick();
                        break;
                                        default:
                        break;
                }
                return true;
            }
        });

以上所述就是小编给大家介绍的《仿微信地图的可变化高度的列表页》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Linux命令行与shell脚本编程大全 第3版

Linux命令行与shell脚本编程大全 第3版

[美]布鲁姆,布雷斯纳汉 / 门佳、武海峰 / 人民邮电出版社 / 2016-8-1 / CNY 109.00

这是一本关于Linux命令行与shell脚本编程的全方位教程,主要包括四大部分:Linux命令行,shell脚本编程基础,高级shell脚本编程,如何创建实用的shell脚本。本书针对Linux系统的最新特性进行了全面更新,不仅涵盖了详尽的动手教程和现实世界中的实用信息,还提供了与所学内容相关的参考信息和背景资料。通过本书的学习,你将轻松写出自己的shell脚本。一起来看看 《Linux命令行与shell脚本编程大全 第3版》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码