您好,登錄后才能下訂單哦!
最近電商類(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>
免責(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)容。