android 中 viewpager 滑动的指示器
先看下效果图:
这个需要用到1个开源的 库,这个后面也会说下的。
工程目录:
1. MainActivity.java
- public class MainActivity extends FragmentActivity {
- private ViewPagerFrameAdapter adapter; //适配器(标题和内容)
- private ViewPager mPager;
- private TabPageIndicator tabbPageIndicator; //
- private UnderlinePageIndicatorEx underlinePageIndicator;
- private int COUNT = 0;
- private List<String> titles = new ArrayList<String>(); //标题
- @Override
- protected void onCreate(Bundle bundle) {
- super.onCreate(bundle);
- requestWindowFeature(Window.FEATURE_NO_TITLE);
- setContentView(R.layout.activity_main);
- //标题,这里自己造的假数据
- for (int j = 0; j < 3 ; j++){
- titles.add( "第"+ j +"标签卡");
- }
- mPager = (ViewPager)findViewById(R.id.pager);
- adapter = new ViewPagerFrameAdapter(getSupportFragmentManager(),titles);
- mPager.setAdapter(adapter);
- //得到指示器
- tabbPageIndicator = (TabPageIndicator) findViewById(R.id.tab_indicator);
- tabbPageIndicator.setViewPager(mPager);
- //下标
- underlinePageIndicator = (UnderlinePageIndicatorEx)findViewById(R.id.underline_indicator);
- underlinePageIndicator.setViewPager(mPager);
- underlinePageIndicator.setFades(false);
- //设置指示器
- tabbPageIndicator.setOnPageChangeListener(underlinePageIndicator);
- }
- //adapter 没啥好说的 跟前面的一样
- private class ViewPagerFrameAdapter extends FragmentStatePagerAdapter{
- private List<String> title; //页面标题头部数据
- public ViewPagerFrameAdapter(FragmentManager fm, List<String> title) {
- super(fm);
- this.title = title;
- }
- //根据position 返回 fragment
- @Override
- public Fragment getItem(int position) {
- return ArrayFragment.newInstance(position);
- }
- //size
- @Override
- public int getCount() {
- return title.size();
- }
- //顶部的title
- @Override
- public CharSequence getPageTitle(int position) {
- if (titles != null){
- return titles.get(position).toString();
- }
- return super.getPageTitle(position);
- }
- }
- }
UnderlinePageIndicatorEx.java
- //继承这个然后重写
- public class UnderlinePageIndicatorEx extends UnderlinePageIndicator{
- public UnderlinePageIndicatorEx(Context context) {
- super(context, null);
- }
- public UnderlinePageIndicatorEx(Context context, AttributeSet attrs) {
- super(context, attrs, R.attr.vpiUnderlinePageIndicatorStyle);
- }
- public UnderlinePageIndicatorEx(Context context, AttributeSet attrs, int defStyle) {
- super(context, attrs, defStyle);
- }
- //自身的 ViewPage传递过去
- @Override
- public void setViewPager(ViewPager viewPager) {
- if (mViewPager == viewPager){
- return;
- }
- // if (mViewPager != null) {
- // mViewPager.setOnPageChangeListener(null);
- // }
- if (viewPager.getAdapter() == null) {
- throw new IllegalStateException(" pager 没有 加入 adapter");
- }
- mViewPager = viewPager;
- // mViewPager.setOnPageChangeListener(this);
- invalidate();
- post(new Runnable(){
- @Override public void run() {
- if (mFades) {
- post(mFadeRunnable);
- }
- }
- });
- }
- }
ArrayFragment.java
- public class ArrayFragment extends Fragment{
- private int position;
- public ArrayFragment(int position){
- this.position = position;
- }
- // 返回 viwePager 下面滑动的页面
- public static ArrayFragment newInstance(int position){
- return new ArrayFragment(position);
- }
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- }
- @Override
- public void onDestroy() {
- super.onDestroy();
- }
- // 根据position 返回不同的view
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- View view = inflater.inflate(R.layout.layoutaa, null);
- return view;
- }
- }
好了接下来是 布局xml了。
- <LinearLayout
- xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="vertical"
- >
- <!-- 标题 和 标题下面的 指示器 -->
- <LinearLayout
- android:layout_width="fill_parent"
- android:layout_height="35dp"
- android:orientation="vertical"
- android:background="@drawable/main_header_background">
- <com.viewpagerindicator.TabPageIndicator
- android:id="@+id/tab_indicator"
- android:layout_height="wrap_content"
- android:layout_width="fill_parent"/>
- <com.test.linepagerindictor.widget.UnderlinePageIndicatorEx
- android:id="@+id/underline_indicator"
- android:layout_height="3dip"
- android:layout_width="fill_parent"
- android:layout_alignParentBottom="true"/>
- </LinearLayout>
- <android.support.v4.view.ViewPager
- android:id="@+id/pager"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"/>
- </LinearLayout>
接下来设置 滑动指示器的style
- <!-- 总 style 直接引用 这个 由 tab style 和 Indicator style 组成 -->
- <style name="StyledAllIndicators" parent="@android:style/Theme.Light">
- <item name="vpiTabPageIndicatorStyle">@style/CustomTabPageIndicator</item>
- <item name="vpiUnderlinePageIndicatorStyle">@style/CustomUnderlinePageIndicator</item>
- </style>
- <!-- tab的 style -->
- <style name="CustomTabPageIndicator" parent="Widget.TabPageIndicator">
- <item name="android:background">#00000000</item>
- <item name="android:textAppearance">@style/CustomTabPageIndicator_text</item>
- <item name="android:textColor">@color/selector_tab</item>
- <item name="android:textSize">20sp</item>
- <!-- 分割线,可有可无的 -->
- <item name="android:divider">@drawable/custom_tab_indicator_divider</item>
- <item name="android:dividerPadding">10dip</item>
- <item name="android:showDividers">middle</item>
- <item name="android:paddingTop">4dp</item>
- <item name="android:paddingLeft">8dp</item>
- <item name="android:paddingBottom">4dp</item>
- <item name="android:paddingRight">8dp</item>
- <item name="android:fadingEdge">horizontal</item>
- <item name="android:fadingEdgeLength">8dp</item>
- </style>
- <style name="CustomTabPageIndicator_text" parent="android:TextAppearance.Medium">
- <item name="android:typeface">monospace</item>
- </style>
- <!-- 下标的指示器的颜色 -->
- <style name="CustomUnderlinePageIndicator">
- <item name="selectedColor">#EB5548</item>
- <item name="android:background">#00000000</item>
- <item name="fadeLength">1000</item>
- <item name="fadeDelay">1000</item>
- </style>
selector_tab.xml 这个是 选择器 在style中引用的,是用来切换 被选中的背景色的
- <?xml version="1.0" encoding="utf-8"?>
- <selector xmlns:android="http://schemas.android.com/apk/res/android">
- <item android:state_selected="true" android:color="#91D228" />
- <item android:state_focused="true" android:color="#91D228" />
- <item android:color="#dddddd" />
- </selector>
好了 ,基本就这些了 fragment的的那个xml 自己随意画吧, 那个开源库随后上传。
android 中 viewpager 滑动的指示器的更多相关文章
- Android中ViewPager实现滑动条及与Fragment结合的实例教程
ViewPager类主要被用来实现可滑动的视图功能,这里我们就来共同学习Android中ViewPager实现滑动条及与Fragment结合的实例教程,需要的朋友可以参考下 自主实现滑动指示条先上一个 ...
- Android中viewPager的一两点使用
Android中viewPager的一两点使用 viewPager是谷歌官方提供的一种方便实现页面滑动效果的控件,可以直接使用也可以和fragment联合使用.这里只简单说下直接使用. 使用viewP ...
- Android中ViewPager+Fragment取消(禁止)预加载延迟加载(懒加载)问题解决方案
转载请注明出处:http://blog.csdn.net/linglongxin24/article/details/53205878本文出自[DylanAndroid的博客] Android中Vie ...
- Android中实现滑动翻页—使用ViewFlipper(dp和px之间进行转换)
Android中实现滑动翻页—使用ViewFlipper(dp和px之间进行转换) Android中dp和px之间进行转换 在xml布局文件中,我们既可以设置px,也可以设置dp(或者dip).一般情 ...
- android 禁止ViewPager滑动
最近项目中,有个需求就是要禁止ViewPager滑动事件,我们看下360手机助手的界面,风格就类似这样的 大家如果使用过360手机助手就会发现中间内容是不可以滑动的,现在写一个demo,讲下怎么禁止V ...
- Android中ViewPager的使用
我们在一个apk中第一次開始的时候,会有一个guide界面.一般使用ViewPager来完毕. 布局文件例如以下: <? xml version="1.0" encoding ...
- Android中ViewPager如何设置不能通过屏幕左右滑动来切换页面
//很多时候,我想禁止用户通过屏幕的左右滑动来切换界面!如何实现! //创建一个类继承viewpager,实现 onTouchEvent 和 onInterceptTouchEvent方法,都 ...
- Android中分页滑动实现总结
手机的屏幕相对较小,因此会出现当有多项内容需要展示而不得不进行分页的情况.例如手机桌面的应用图标的展示.一般一屏可以显示4*4=16个小方块形的应用程序,可以通过左右滑动进行屏幕的选择.而Androi ...
- android 中 ViewPager 的平常用法 ViewPager+ Views
延续前面几个的经常用到的ViewPager, 直接加载各种不同的 View 工程目录: 代码: public class ViewActivity extends Activity { // 每个Vi ...
随机推荐
- LintCode: Maximum Subarray
1. 暴力枚举 2. “聪明”枚举 3. 分治法 分:两个基本等长的子数组,分别求解T(n/2) 合:跨中心点的最大子数组合(枚举)O(n) 时间复杂度:O(n*logn) class Solutio ...
- android camera preview常用格式
在Camera中推荐使用NV21和YV12,因为这两种格式支持所有的相机设备. 但是在Camera2中,推荐使用的格式则是YUV_420_888. 总的来说,在Android里面YUV用得比较多的应该 ...
- Oracle单引号双重角色——字符串引用与转义
单引号双重角色——字符串引用与转义 在ORACLE中,单引号有两个作用,一是字符串是由单引号引用,二是转义,开始学习时动态构成SQL时经常不解.单引号的使用是就近配对,即就近原则.而在单引号 ...
- spring & java 面试
https://blog.csdn.net/u014079773/article/details/52453002 1.Spring中AOP的应用场景.Aop原理.好处? 答:AOP--Aspect ...
- java byte数组与16进制间的相互转换
java byte数组与16进制间的相互转换 CreationTime--2018年6月11日15点34分 Author:Marydon 1.准备工作 import java.util.Array ...
- 浅谈Spring的PropertyPlaceholderConfigurer
大型项目中,我们往往会对我们的系统的配置信息进行统一管理,一般做法是将配置信息配置与一个cfg.properties的文件中,然后在我们系统初始化的时候,系统自动读取cfg.properties配置文 ...
- 基于源码编译安装openssh
最近的,openssl/openssh等相继漏洞的暴露,让暴露在公网的linux.沦陷为肉鸡的正营... 没办法,还是升级版本... 00.openssh简介 OpenSSH 是一组安全远程的连接工 ...
- 《数字图像处理原理与实践(MATLAB版)》一书之代码Part5
<数字图像处理原理与实践(MATLAB版)>一书之代码Part5 本文系<数字图像处理原理与实践(MATLAB版)>一书之代码系列的Part5.辑录该书第225至第280页之代 ...
- Oracle 中TNS的作用
什么是TNS? TNS是Oracle Net的一部分,专门用来管理和配置Oracle数据库和client连接的一个工具,在大多数情况下client和数据库要通讯,必须配置TNS,当然在少数情况下,不用 ...
- C++ 11保留小数点的四舍五入方案
当然,C++ 11提供各类型的std::round来四舍五入,但是没有一个能直接支持保留小数点位数的四舍五入方案. 所以需要通过setprecision来实现: #include <iomani ...