Android scrollView和viewpager嵌套 指示器吸顶 根据viewpager每个页面的内容适配高度

本文主要是介绍Android scrollView和viewpager嵌套 指示器吸顶 根据viewpager每个页面的内容适配高度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这几天 朋友问我了个问题  有个特别的需求  页面如下

就是当viewpager里面的当前页面内容足够多的时候  要去能滑上去 并且指示器吸顶  但是当内容不多的时候  能滑到哪就停在哪  当时第一反应是用coordinatelayout  结果不行 内容少的时候  也直接滑到顶部了 

activity的xml文件

 

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/main_content"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><com.example.wenlaisu.myapplication.MyScrollviewandroid:id="@+id/scroll"android:layout_width="match_parent"android:layout_height="match_parent"android:fillViewport="true"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><ImageViewandroid:layout_width="match_parent"android:layout_height="200dp"android:background="?attr/colorPrimary"android:scaleType="fitXY"android:id="@+id/iv"android:src="@drawable/tangyan" /><LinearLayoutandroid:id="@+id/layout"android:layout_width="match_parent"android:layout_height="wrap_content"><android.support.design.widget.TabLayoutandroid:id="@+id/tabs"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="?attr/colorPrimary" /></LinearLayout><com.example.wenlaisu.myapplication.CustomViewPagerandroid:id="@+id/viewpager"android:layout_width="match_parent"android:layout_height="wrap_content" /></LinearLayout></com.example.wenlaisu.myapplication.MyScrollview><RelativeLayoutandroid:id="@+id/rl_layout"android:layout_width="match_parent"android:layout_height="wrap_content" ></RelativeLayout>
</RelativeLayout>

 

后来就直接用scrollView包裹来实现了 自定义scrollView实现滚动监听 用来实现指示器吸顶效果  

 

 

public class MyScrollview extends ScrollView {private ScrollViewListener scrollViewListener = null;public MyScrollview(Context context) {super(context);}public MyScrollview(Context context, AttributeSet attrs) {super(context, attrs);}public MyScrollview(Context context, AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);}public void setScrollViewListener(ScrollViewListener scrollViewListener) {this.scrollViewListener = scrollViewListener;}@Overrideprotected void onScrollChanged(int l, int t, int oldl, int oldt) {super.onScrollChanged(l, t, oldl, oldt);if (scrollViewListener != null) {scrollViewListener.onScrollChanged(this, l, t, oldl, oldt);}}public interface ScrollViewListener {void onScrollChanged(MyScrollview scrollView, int l, int t, int oldl, int oldt);}
}

在activity里面设置监听

 

scroll.setScrollViewListener(new MyScrollview.ScrollViewListener() {@Overridepublic void onScrollChanged(MyScrollview scrollView, int l, int t, int oldl, int oldt) {if (t >iv.getHeight() && mTabLayout.getParent() == layout) {layout.removeView(mTabLayout);rl_layout.addView(mTabLayout);} else if (t < iv.getHeight() && mTabLayout.getParent() == rl_layout) {rl_layout.removeView(mTabLayout);layout.addView(mTabLayout);}}
});

然后就是实现viewpager的每个页面的内容高度适配了  从写viewpager

 

public class CustomViewPager extends ViewPager {private int current;  private int height = 0;  /**  * 保存position与对于的View  */  private HashMap<Integer, View> mChildrenViews = new LinkedHashMap<Integer, View>();private boolean scrollble = true;  public CustomViewPager(Context context) {super(context);  }  public CustomViewPager(Context context, AttributeSet attrs) {super(context, attrs);  }  @Override  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {  if (mChildrenViews.size() > current) {  View child = mChildrenViews.get(current);  if (child != null) {  child.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));  height = child.getMeasuredHeight();  }  }  heightMeasureSpec = MeasureSpec.makeMeasureSpec(height, MeasureSpec.EXACTLY);  super.onMeasure(widthMeasureSpec, heightMeasureSpec);  }  public void resetHeight(int current) {  this.current = current;  if (mChildrenViews.size() > current) {  LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams) getLayoutParams();if (layoutParams == null) {  layoutParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, height);} else {  layoutParams.height = height;  }  setLayoutParams(layoutParams);  }  }  /**  * 保存position与对于的View  */  public void setObjectForPosition(View view, int position) {  mChildrenViews.put(position, view);  }  @Override  public boolean onTouchEvent(MotionEvent ev) {if (!scrollble) {  return true;  }  return super.onTouchEvent(ev);  }  public boolean isScrollble() {  return scrollble;  }  public void setScrollble(boolean scrollble) {  this.scrollble = scrollble;  }  }  

用法是在每个fragment 的onCreatView里面添加一行代码就行 

然后在viewpager所在的activity里面设置监听  就可以了

 

mViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {mViewPager.resetHeight(position);}@Overridepublic void onPageScrollStateChanged(int state) {}
});

下面是整个activity的代码

 

package com.example.wenlaisu.myapplication;import android.os.Bundle;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import java.util.ArrayList;
import java.util.List;
/*** Created by wenlaisu on 2018/4/12.*/
public class ViewPagerSample extends AppCompatActivity {CustomViewPager mViewPager;List<Fragment> mFragments;String[] mTitles = new String[]{"主页", "微博", "相册"};private TabLayout mTabLayout;private MyScrollview scroll;private LinearLayout layout;private RelativeLayout rl_layout;private ImageView iv;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_third);// 第一步,初始化ViewPager和TabLayoutmViewPager = (CustomViewPager) findViewById(R.id.viewpager);mTabLayout = (TabLayout) findViewById(R.id.tabs);layout = (LinearLayout) findViewById(R.id.layout);rl_layout = (RelativeLayout) findViewById(R.id.rl_layout);scroll = (MyScrollview) findViewById(R.id.scroll);iv = (ImageView) findViewById(R.id.iv);setupViewPager();}private void setupViewPager() {mFragments = new ArrayList<>();ListFragment listFragment = new ListFragment(mViewPager, 0);ListFragment2 listFragment2 = new ListFragment2(mViewPager, 1);ListFragment3 listFragment3 = new ListFragment3(mViewPager, 2);mFragments.add(listFragment);mFragments.add(listFragment2);mFragments.add(listFragment3);// 第二步:为ViewPager设置适配器BaseFragmentAdapter adapter =new BaseFragmentAdapter(getSupportFragmentManager(), mFragments, mTitles);mViewPager.setAdapter(adapter);//  第三步:将ViewPager与TableLayout 绑定在一起mTabLayout.setupWithViewPager(mViewPager);mViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {mViewPager.resetHeight(position);}@Overridepublic void onPageScrollStateChanged(int state) {}});scroll.setScrollViewListener(new MyScrollview.ScrollViewListener() {@Overridepublic void onScrollChanged(MyScrollview scrollView, int l, int t, int oldl, int oldt) {if (t >iv.getHeight() && mTabLayout.getParent() == layout) {layout.removeView(mTabLayout);rl_layout.addView(mTabLayout);} else if (t < iv.getHeight() && mTabLayout.getParent() == rl_layout) {rl_layout.removeView(mTabLayout);layout.addView(mTabLayout);}}});}
}

就可以了

demo的github地址

 

这篇关于Android scrollView和viewpager嵌套 指示器吸顶 根据viewpager每个页面的内容适配高度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/753521

相关文章

Java如何将文件内容转换为MD5哈希值

《Java如何将文件内容转换为MD5哈希值》:本文主要介绍Java如何将文件内容转换为MD5哈希值的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java文件内容转换为MD5哈希值一个完整的Java示例代码代码解释注意事项总结Java文件内容转换为MD5

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

全解析CSS Grid 的 auto-fill 和 auto-fit 内容自适应

《全解析CSSGrid的auto-fill和auto-fit内容自适应》:本文主要介绍了全解析CSSGrid的auto-fill和auto-fit内容自适应的相关资料,详细内容请阅读本文,希望能对你有所帮助... css  Grid 的 auto-fill 和 auto-fit/* 父元素 */.gri

Android 实现一个隐私弹窗功能

《Android实现一个隐私弹窗功能》:本文主要介绍Android实现一个隐私弹窗功能,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 效果图如下:1. 设置同意、退出、点击用户协议、点击隐私协议的函数参数2. 《用户协议》、《隐私政策》设置成可点击的,且颜色要区分出来res/l

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整

Android 12解决push framework.jar无法开机的方法小结

《Android12解决pushframework.jar无法开机的方法小结》:本文主要介绍在Android12中解决pushframework.jar无法开机的方法,包括编译指令、框架层和s... 目录1. android 编译指令1.1 framework层的编译指令1.2 替换framework.ja