android ViewPager嵌套WebView滑动冲突问题解决

android ViewPager嵌套WebView滑动冲突问题解决,第1张

在ViewPager, ScrollView, ListView等容器控件中内嵌了webview,特别是webview的大小固定的情况下,会出现滑动的冲突,可以采用如下自定义的webview来完美解决。

这个方法是通过验证了的,真是可行。而且webview中js控制的轮播效果也出来了。

微信小程序中scroll-into-view跳转到指定位置是这样使用的:

1、首先第一步,打开微信开发者工具。

2、其次第二步,打开wxml文件,然后在文件里先新建一个scroll-view的标签即可。

3、再次第三步,设置这个scroll-into-view滚动的方向设置为x轴,与此同时设置scroll-into-view的值,这个值就是子元素中的id,表示滚动到哪一个元素,如下图所示。

4、接下来就是设置子元素,先新建一个view的子元素,然后设置class和id,并且多设置几个view标签,以便观察效果。

5、最后一步,点击打开模拟器,在下面我们就可以看到滚动的元素,接着就按照我们之前设置的显示就行了。

前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个ListItem中放入另外一个ListView。但刚开始的时候,会发现放入的小ListView会显示不完全,它的高度始终有问题。上网查了下,发现别人也有遇到这样的问题,而大多数人都不推荐这样的设计,因为默认情况下Android是禁止在ScrollView中放入另外的ScrollView的,它的高度是无法计算的。

又搜索了一下,发现有StackOverflow上的牛人已经解决了这个问题,经过试验发现是可以解决问题的,它的思路就是在设置完ListView的Adapter后,根据ListView的子项目重新计算ListView的高度,然后把高度再作为LayoutParams设置给ListView,这样它的高度就正确了,以下是源码:

public class Utility {  

    public static void setListViewHeightBasedOnChildren(ListView listView) {  

        ListAdapter listAdapter = listViewgetAdapter();   

        if (listAdapter == null) {  

            // pre-condition  

            return;  

        }  

  

        int totalHeight = 0;  

        for (int i = 0; i < listAdaptergetCount(); i++) {  

            View listItem = listAdaptergetView(i, null, listView);  

            listItemmeasure(0, 0);  

            totalHeight += listItemgetMeasuredHeight();  

        }  

  

        ViewGroupLayoutParams params = listViewgetLayoutParams();  

        paramsheight = totalHeight + (listViewgetDividerHeight()  (listAdaptergetCount() - 1));  

        listViewsetLayoutParams(params);  

    }  

}

只要在设置ListView的Adapter后调用此静态方法即可让ListView正确的显示在其父ListView的ListItem中。但是要注意的是,子ListView的每个Item必须是LinearLayout,不能是其他的,因为其他的Layout(如RelativeLayout)没有重写onMeasure(),所以会在onMeasure()时抛出异常。

在ScrollView中嵌套ListView(或者ScrollView)的另外一个问题就是,子ScrollView中无法滑动的(如果它没有显示完全的话),因为滑动事件会被父ScrollView吃掉,如果想要让子ScrollView也可以滑动,只能强行截取滑动事件,有牛人在论坛中发过代码说可以。虽然我没有亲自试过,但估计是可行的。

虽然在ScrollView中显示ScrollView在技术上的难题可以攻破,但是这样的设计却是非常差的用户体验因为用户会不容易看到和 *** 作子ScrollView中的内容。比如好的设计是,父ListView的每个Item只显示概括性的描述,然后点击其Item会进入另外一个页面来详细描述和展示以及对这个Item的 *** 作。

ScrollView中嵌套ListView或ExpandableListView会产生什么问题就不说了,懒- -

直接说解决办法吧:

其实还是需要计算出adapter的所有item的高度,再设置给listiew。

上代码,是一个封装好的方法,在listviewsetAdapter()之后调用此方法就行了

public static class Utility {

public static void setListViewHeightBasedOnChildren(ExpandableListView listView) {

//获取ListView对应的Adapter

ListAdapter listAdapter = listViewgetAdapter();

if (listAdapter == null) {

// pre-condition

return;

}

int totalHeight = 0;

for (int i = 0, len = listAdaptergetCount(); i < len; i++) { //listAdaptergetCount()返回数据项的数目

View listItem = listAdaptergetView(i, null, listView);

listItemmeasure(0, 0); //计算子项View 的宽高

totalHeight += listItemgetMeasuredHeight(); //统计所有子项的总高度

}

ViewGroupLayoutParams params = listViewgetLayoutParams();

paramsheight = totalHeight + (listViewgetDividerHeight() (listAdaptergetCount() - 1));

//listViewgetDividerHeight()获取子项间分隔符占用的高度

//paramsheight最后得到整个ListView完整显示需要的高度

listViewsetLayoutParams(params);

}

}

测试完全可行。

ScrollView中嵌套ListView或ExpandableListView会产生什么问题就不说了,懒- -

直接说解决办法吧:

其实还是需要计算出adapter的所有item的高度,再设置给listiew。

上代码,是一个封装好的方法,在listviewsetAdapter()之后调用此方法就行了

public static class Utility {

public static void setListViewHeightBasedOnChildren(ExpandableListView listView) {

//获取ListView对应的Adapter

ListAdapter listAdapter = listViewgetAdapter();

if (listAdapter == null) {

// pre-condition

return;

}

int totalHeight = 0;

for (int i = 0, len = listAdaptergetCount(); i < len; i++) { //listAdaptergetCount()返回数据项的数目

View listItem = listAdaptergetView(i, null, listView);

listItemmeasure(0, 0); //计算子项View 的宽高

totalHeight += listItemgetMeasuredHeight(); //统计所有子项的总高度

}

ViewGroupLayoutParams params = listViewgetLayoutParams();

paramsheight = totalHeight + (listViewgetDividerHeight() (listAdaptergetCount() - 1));

//listViewgetDividerHeight()获取子项间分隔符占用的高度

//paramsheight最后得到整个ListView完整显示需要的高度

listViewsetLayoutParams(params);

}

}

测试完全可行。

你获得是计算的实际高度还是有问题的高度,我们知道,scrollview嵌套listview、gridview之类的有问题,所以如果你需要计算recycleview的高度,就需要知道 item的个数与item的高度,然后计算得出

以上就是关于android ViewPager嵌套WebView滑动冲突问题解决全部的内容,包括:android ViewPager嵌套WebView滑动冲突问题解决、微信小程序如何使用scroll-into-view中跳转到指定位置、如何在ListView中嵌套ListView等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10131975.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存