溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PullToRefreshScrollView+GridView,實(shí)現(xiàn)向下滑動(dòng)中隱藏自定義Action布局

發(fā)布時(shí)間:2020-06-02 12:27:18 來(lái)源:網(wǎng)絡(luò) 閱讀:2591 作者:失眠的考拉 欄目:移動(dòng)開(kāi)發(fā)

    最近電商類(lèi)項(xiàng)目有個(gè)需求挺頭疼,要求用GridView去顯示商品,滑動(dòng)到底部下拉能加載更多商品,向下滑動(dòng)過(guò)程中需要隱藏掉自定義的Action布局,向上滑動(dòng)能顯示出來(lái),整體效果類(lèi)似淘寶APP搜索結(jié)果頁(yè)那樣。

    起初覺(jué)得挺簡(jiǎn)單的,但是后來(lái)才發(fā)現(xiàn)還是得轉(zhuǎn)一點(diǎn)腦子。最開(kāi)始我想用PullToRefreshGridView,但是后來(lái)發(fā)現(xiàn)GridView沒(méi)有添加headview的方法,只能采用PullToRefreshScrollView內(nèi)嵌套GridView的方法,Scrollview里多放一個(gè)空白布局當(dāng)GridView的headview,高度和Action布局一樣就行。這時(shí)還有一個(gè)問(wèn)題,ScrollView和GridView會(huì)產(chǎn)生滑動(dòng)沖突,還好網(wǎng)上很容易找到解決辦法,我這里采用自定義GridView,最后就是監(jiān)聽(tīng)方法了,最為關(guān)鍵的點(diǎn),還是直接上代碼吧:


自定義GridView:

package com.example.ztestscrollview;


import android.content.Context;

import android.util.AttributeSet;

import android.view.View.MeasureSpec;

import android.widget.GridView;


public class MyGridView extends GridView{

public MyGridView(Context context, AttributeSet attrs) {

  super(context, attrs);

}

public MyGridView(Context context) {

  super(context);

}

public MyGridView(Context context, AttributeSet attrs, int defStyle) {

  super(context, attrs, defStyle);

}

@Override     

public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

   

   int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,

     MeasureSpec.AT_MOST);             

   super.onMeasure(widthMeasureSpec, expandSpec);

}




主界面:

package com.example.ztestscrollview;


import android.app.Activity;

import android.os.Bundle;

import android.util.Log;

import android.view.Menu;

import android.view.MotionEvent;

import android.view.View;

import android.view.View.OnTouchListener;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.ScrollView;


import com.handmark.pulltorefresh.library.PullToRefreshBase;

import com.handmark.pulltorefresh.library.PullToRefreshBase.Mode;

import com.handmark.pulltorefresh.library.PullToRefreshBase.OnRefreshListener;

import com.handmark.pulltorefresh.library.PullToRefreshScrollView;


public class MainActivity extends Activity

{


    int num = 10;

    private GridAdapter adapter;

    private ScrollView scrollView;

    private PullToRefreshScrollView ptr_scrollview;

    private View actionLayout;

    private MyGridView myGridview;


    @Override

    protected void onCreate(Bundle savedInstanceState)

    {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);


        actionLayout = findViewById(R.id.actionlayout);


        ptr_scrollview = (PullToRefreshScrollView) findViewById(R.id.ptr_scrollview);

        ptr_scrollview.setMode(Mode.PULL_UP_TO_REFRESH);

        ptr_scrollview.setOnRefreshListener(new OnRefreshListener<ScrollView>()

        {


            @Override

            public void onRefresh(PullToRefreshBase<ScrollView> refreshView)

            {

                num += 10;

                adapter.notifyDataSetChanged();

                ptr_scrollview.onRefreshComplete();

            }

        });


        myGridview = (MyGridView) findViewById(R.id.myGridView1);

        adapter = new GridAdapter();

        myGridview.setAdapter(adapter);


        scrollView = ptr_scrollview.getRefreshableView();

        scrollView.setOnTouchListener(new OnTouchListener()

        {

            // 判斷是否第一個(gè)滑動(dòng)值

            boolean isFirst = true;

            // Scrollview滑動(dòng)的ScrollY值

            private int ScrollY_Move;

            // 第一個(gè)滑動(dòng)的ScrollY值

            private int First_ScrollY_Move;

            // 手指抬起時(shí)ScrollY值

            private int ScrollY_Up;

            // ScrollY_Move和First_ScrollY_Move的差值

            private int Cha;


            @Override

            public boolean onTouch(View v, MotionEvent event)

            {

                switch (event.getAction())

                {

                //ACTIN_DOWN沒(méi)用,不用監(jiān)聽(tīng)

                case MotionEvent.ACTION_MOVE:

                    if (isFirst)

                    {

                        // 記錄下第一個(gè)滑動(dòng)的ScrollY值

                        First_ScrollY_Move = v.getScrollY();

                        isFirst = false;

                    }

                    // 記錄下Scrollview滑動(dòng)的ScrollY值

                    ScrollY_Move = v.getScrollY();


                    // 計(jì)算出ScrollY_Move和First_ScrollY_Move的差值

                    Cha = ScrollY_Move - First_ScrollY_Move;


                    // 當(dāng)ScrollY_Move>First_ScrollY_Move時(shí)證明滑動(dòng)方向是向下;

                    // 加上判斷差值的目的:當(dāng)Actionbar顯示的時(shí)候,手指按住往下滑過(guò)一段距離還未抬起時(shí),Actionbar也能隱藏

                    if (First_ScrollY_Move < ScrollY_Move || Cha > 200)

                    {

                        // 隱藏Actionbar

                        actionLayout.setVisibility(View.GONE);

                    }


                    // 當(dāng)ScrollY_Move<First_ScrollY_Move時(shí)證明滑動(dòng)方向是向上;

                    // 加上判斷差值的目的:當(dāng)Actionbar顯示的時(shí)候,手指按住往上滑過(guò)一段距離還未抬起時(shí),Actionbar也能顯示

                    // 判斷ScrollY_Move < 150目的:當(dāng)Scrollview滑動(dòng)接近頂端時(shí)必須顯示Actionbar

                    else if (First_ScrollY_Move > ScrollY_Move || Cha < -200

                            || ScrollY_Move < 150)

                    {

                        actionLayout.setVisibility(View.VISIBLE);

                    }

                    break;

                case MotionEvent.ACTION_UP:

                    ScrollY_Up = v.getScrollY();// 記錄下手指抬起時(shí)ScrollY值

                    isFirst = true;// 將isFirst還原為初始化

                    if (ScrollY_Up == 0)

                    {

                        actionLayout.setVisibility(View.VISIBLE);

                    }

                    // Log.e("ACTION_UP--->", "scrollY_up:" + scrollY_up + "   "

                    // + "eventY_up:" + eventY_up);


                    break;


                default:

                    break;

                }

                return false;

            }


        });


    }


    class GridAdapter extends BaseAdapter

    {

        @Override

        public View getView(int position, View convertView, ViewGroup parent)

        {

            View inflate = getLayoutInflater().inflate(R.layout.griditem, null);

            return inflate;

        }


        @Override

        public int getCount()

        {

            // TODO Auto-generated method stub

            return num;

        }


        @Override

        public Object getItem(int position)

        {

            // TODO Auto-generated method stub

            return null;

        }


        @Override

        public long getItemId(int position)

        {

            // TODO Auto-generated method stub

            return 0;

        }


    }


    @Override

    public boolean onCreateOptionsMenu(Menu menu)

    {

        // Inflate the menu; this adds items to the action bar if it is present.

        getMenuInflater().inflate(R.menu.main, menu);

        return true;

    }


}



布局:

<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"

    tools:context=".MainActivity" >


    <com.handmark.pulltorefresh.library.PullToRefreshScrollView

        android:id="@+id/ptr_scrollview"

        android:layout_width="match_parent"

        android:layout_height="match_parent"

        android:layout_alignParentLeft="true"

        android:layout_alignParentTop="true" >


        <RelativeLayout

            android:layout_width="match_parent"

            android:layout_height="match_parent"

            android:descendantFocusability="blocksDescendants" >


            <RelativeLayout

                android:id="@+id/headview"

                android:layout_width="match_parent"

                android:layout_height="120dp"

                android:layout_alignParentLeft="true"

                android:layout_alignParentTop="true" >

            </RelativeLayout>


            <com.example.ztestscrollview.MyGridView

                android:id="@+id/myGridView1"

                android:layout_width="match_parent"

                android:layout_height="match_parent"

                android:layout_below="@+id/headview"

                android:numColumns="2" >

            </com.example.ztestscrollview.MyGridView>

        </RelativeLayout>

    </com.handmark.pulltorefresh.library.PullToRefreshScrollView>


    <RelativeLayout

        android:id="@+id/actionlayout"

        android:layout_width="match_parent"

        android:layout_height="120dp"

        android:layout_alignParentLeft="true"

        android:layout_alignParentTop="true"

        android:background="#cdcdcd" >


        <TextView

            android:layout_width="wrap_content"

            android:layout_height="wrap_content"

            android:layout_centerHorizontal="true"

            android:layout_centerVertical="true"

            android:text="ActionLayout" />

    </RelativeLayout>


</RelativeLayout>


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI