ViewPager+滑动条显示

这里写图片描述

ViewPager+标签页的显示效果做的很多,很常见。这里做的是,滑动ViewPager的时候,有一条滑动条显示,一定时间后,自动隐藏。

先在xml文件中,写一个textview,用于显示滑动条,背景就是滑动条显示的UI切图。

<android.support.v4.view.ViewPager
    android:id="@+id/viewpager"
    android:layout_width="match_parent"
    android:layout_height="150dp"
    >
</android.support.v4.view.ViewPager>
<TextView
    android:id="@+id/tvLine"
    android:layout_width="100dp"
    android:layout_height="10dp"
    android:layout_marginTop="40px"
    android:background="@drawable/e"
    />

代码中imageRIds.length是数据长度,根据实际获取的数据分配每一个textView实际应该显示多宽

这里转换成ViewGroup.MarginLayoutParams,是因为只有这个布局参数才能找到设置margin方法
int width = getWindowManager().getDefaultDisplay().getWidth();
int lineWidth = width / imageRIds.length;
layoutParams = (ViewGroup.MarginLayoutParams) tvline.getLayoutParams();
layoutParams.width = lineWidth;
tv_line.setLayoutParams(layoutParams);

此处有一个小细节,如果是在Activity之中,

int width = getWindowManager().getDefaultDisplay().getWidth();没有问题。

如果在Fragment中使用。换成

int width = activity.getWindowManager().getDefaultDisplay().getWidth();
这里用activity是因为getActivity()可能为空。
所以在fragment中onAttach方法中,把activity赋值给成员变量。
private Activity activity;
@Override
public void onAttach(Activity activity) {
    this.activity = activity;
    super.onAttach(activity);
}

在ViewPager滑动的时候,动态设置textView的margin实现跟随Viewpager滑动效果,设置滑动监听。

viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
    @Override
    public void onPageScrolled(int i, float v, int i1) {
        if (layoutParams != null && v != 0){
            tv_line.setVisibility(View.VISIBLE);
            layoutParams.setMarginStart((int) ((i + v) * layoutParams.width));
            tv_line.setLayoutParams(layoutParams);
        }

    }

    @Override
    public void onPageSelected(int i) {
        handler.postDelayed(new TVRun(),1000);
    }

    @Override
    public void onPageScrollStateChanged(int i) {

    }
});

此处发了一个延时handler,是ViewPager滑动结束以后,一秒钟之后隐藏滑动条。

class TVRun implements Runnable{
    @Override
    public void run() {
        tv_line.setVisibility(View.GONE);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值