Android ListView與ScrollView沖突的解決方法總結(jié)
Android ListView與ScrollView沖突的解決方法總結(jié)
眾所周知ListView與ScrollView都具有滾動(dòng)能力,對(duì)于這樣的View控件,當(dāng)ScrollView與ListView相互嵌套會(huì)成為一種問(wèn)題:
問(wèn)題一:ScrollView與ListView嵌套導(dǎo)致ListView顯示不全面
問(wèn)題二:ScrollView不能正?;瑒?dòng)
解決方式一:
ScrollView+LinearLayout+ListView可以換成ScrollView+LinearLayout+LinearLayout,對(duì)于開發(fā)中,ScrollView所能滾動(dòng)的樣式形式各異,另外的話,ScrollView所顯示的內(nèi)容肯定不會(huì)太多,因此這種方案是合理而且可選的
解決方式二:
同樣是替換:ListView具有HeaderView與FooterView2部分,因此,在非下拉刷新,上拉加載的需求中,完全可以使用ListView來(lái)代替ScrollView,因此是合理可選的方案
解決方式三:
主動(dòng)計(jì)算和設(shè)置ListView的高度,這樣的結(jié)果最終得出類似解決方案一效果,具體來(lái)說(shuō)缺點(diǎn)是大材小用,但也是合理的解決辦法。
public class Utility {
public static void setListViewHeightBasedOnChildren(ListView listView) {
ListAdapter listAdapter = listView.getAdapter();
if (listAdapter == null) {
return;
}
int totalHeight = 0;
for (int i = 0; i < listAdapter.getCount(); i++) {
View listItem = listAdapter.getView(i, null, listView);
listItem.measure(0, 0);
totalHeight += listItem.getMeasuredHeight();
}
ViewGroup.LayoutParams params = listView.getLayoutParams();
params.height = totalHeight + (listView.getDividerHeight() * (listAdapter.getCount() - 1));
listView.setLayoutParams(params);
}
}
解決方式四:
復(fù)寫ScrollView,從事件方向進(jìn)行處理,缺點(diǎn)是靈活性不夠好、
public class ListScrollView extends ScrollView {
private List list = new ArrayList();
private int scrollPaddingTop; // scrollview的頂部?jī)?nèi)邊距
private int scrollPaddingLeft;// scrollview的左側(cè)內(nèi)邊距
private int[] scrollLoaction = new int[2]; // scrollview在窗口中的位置
private final static int UPGLIDE = 0;
private final static int DOWNGLIDE = 1;
private int glideState;
public ListScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
private int downY = 0;
private int moveY = 0;
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
downY = (int) ev.getY();
//System.out.println("actiondown" + ev.getY());
break;
case MotionEvent.ACTION_MOVE:
moveY= (int) ev.getY();
//System.out.println("move" + moveY + "down" + downY);
if((moveY - downY) >= 0) {
//System.out.println("'''''''''DOWNGLIDE'''''''''''");
glideState = DOWNGLIDE;
} else {
//System.out.println("'''''''''UPGLIDE'''''''''''");
glideState = UPGLIDE;
}
break;
case MotionEvent.ACTION_UP:
default:
break;
}
return super.dispatchTouchEvent(ev);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
// 該事件的xy是以scrollview的左上角為00點(diǎn)而不是以窗口為00點(diǎn)
int x = (int) ev.getX() + scrollLoaction[0];
int y = (int) ev.getY() + scrollLoaction[1];
for (int i = 0; i < list.size(); i++) {
ListView listView = list.get(i);
int[] location = new int[2];
listView.getLocationInWindow(location);
int width = listView.getWidth();
int height = listView.getHeight();
// 在listview的位置之內(nèi)則可以滑動(dòng)
if (x >= location[0] + scrollPaddingLeft
&& x <= location[0] + scrollPaddingLeft + width
&& y >= location[1] + scrollPaddingTop
&& y <= location[1] + scrollPaddingTop + height) {
//System.out.println(glideState);
if(( (listView.getLastVisiblePosition() == (listView.getCount()-1)) && (glideState == UPGLIDE) ) ) {
//System.out.println("up");
break;
}
if(( (listView.getFirstVisiblePosition() == 0) && (glideState == DOWNGLIDE))) {
//System.out.println("down");
break;
}
return false; //讓子控件直接處理
}
}
return super.onInterceptTouchEvent(ev);
}
@Override
public boolean onTouchEvent(MotionEvent ev) {
return super.onTouchEvent(ev);
}
private void findAllListView(View view) {
if (view instanceof ViewGroup) {
int count = ((ViewGroup) view).getChildCount();
for (int i = 0; i < count; i++) {
if (!(view instanceof ListView)) {
findAllListView(((ViewGroup) view).getChildAt(i));
}
}
if (view instanceof ListView) {
list.add((ListView) view);
}
}
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
scrollPaddingTop = getTop();
scrollPaddingLeft = getLeft();
getLocationInWindow(scrollLoaction);
}
@Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
super.onLayout(changed, l, t, r, b);
if (this.getChildCount() != 1) {
try {
throw new ScrollException();
} catch (ScrollException e) {
e.printStackTrace();
}
}
list.clear();
findAllListView(this.getChildAt(0));
}
}
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- Android之ScrollView嵌套ListView和GridView沖突的解決方法
- Android筆記之:在ScrollView中嵌套ListView的方法
- Android ListView的item中嵌套ScrollView的解決辦法
- Android編程之截屏實(shí)現(xiàn)方法(包括scrollview與listview)
- Android ScrollView嵌套ExpandableListView顯示不正常的問(wèn)題的解決辦法
- Android 中ScrollView嵌套GridView,ListView的實(shí)例
- Android ScrollView 下嵌套 ListView 或 GridView出現(xiàn)問(wèn)題解決辦法
- Android 中ScrollView與ListView沖突問(wèn)題的解決辦法
- Android開發(fā)實(shí)現(xiàn)ScrollView中嵌套兩個(gè)ListView的方法
相關(guān)文章
Android SharedPreferences四種操作模式使用詳解
這篇文章主要介紹了Android SharedPreferences四種操作模式使用詳解的相關(guān)資料,這里介紹了獲取Android SharedPreferences的兩種方法及比較,和操作模式的介紹,需要的朋友可以參考下2017-07-07
Android 類似UC瀏覽器的效果:向上滑動(dòng)地址欄隱藏功能
這篇文章主要介紹了Android 類似UC瀏覽器的效果:向上滑動(dòng)地址欄隱藏功能,需要的朋友可以參考下2017-12-12
Android編程實(shí)現(xiàn)自定義進(jìn)度條顏色的方法
這篇文章主要介紹了Android編程實(shí)現(xiàn)自定義進(jìn)度條顏色的方法,涉及Android進(jìn)度條的樣式布局及功能實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
Android中EditText光標(biāo)在4.0中的bug及解決方法
這篇文章主要介紹了Android中EditText光標(biāo)在4.0中的bug及解決方法,簡(jiǎn)單分析了Android4.0版本中EditText光標(biāo)消息的原因及相應(yīng)的解決方法,需要的朋友可以參考下2016-01-01
Android實(shí)現(xiàn)水波紋擴(kuò)散效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)水波紋擴(kuò)散效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
Android優(yōu)雅的方式解決軟鍵盤遮擋按鈕問(wèn)題
這篇文章主要介紹了Android優(yōu)雅的方式解決軟鍵盤遮擋按鈕問(wèn)題,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-01-01
Android 使用PopupWindow實(shí)現(xiàn)彈出更多的菜單實(shí)例詳解
最近想要做一個(gè)彈出更多的菜單,而原生的彈出菜單卻不是我們想要的效果,所以必然要自定義菜單。接下來(lái)通過(guò)本文給大家介紹android 使用popupwindow實(shí)現(xiàn)彈出更多的菜單實(shí)例詳解,需要的朋友可以參考下2017-04-04

