HorizontalScrollView横向滑动视图 & ViewFlipper翻转视图

HorizontalScrollView

是FrameLayout的子类,这意味着你只能在它下面放置一个子控件,这个子控件可以包含很多数据内容。有可能这个子控件本身就是一个布局控件,可以包含非常多的其他用来展示数据的控件。这个布局控件一般使用的是一个水平布局的LinearLayout 。
实际效果是一个可滑动的view 适用于频道切换下方选中标识(结合viewPager做频道切换效果)

ViewFlipper

ViewFlipper是Android自带的一个多页面管理控件且可以自动播放!它和ViewPager有所不同,ViewPager继承自ViewGroup,是一页一页的,可以带动画效果,可以兼容低版本;而ViewFlipper继承ViewAnimator,是一层一层的,切换View的时候可以设置动画效果

常用参数方法:
setInAnimation:View进入屏幕时使用动画;
setOutAnimation:View退出屏幕时使用动画;
showNext:显示ViewFlipper里的下一个View视图;
showPrevious:显示ViewFlipper里的上一个View视图;
setFlipInterval:View之间切换的时间间隔;
setAutoStart:是否可以自动播放,true为自动播放,false为不自动播放;
startFlipping:自动循环切换播放;
stopFlipping:停止自动切换播放;

动态添加视图轮播(文字):

 for (int i = 0; i < list.size(); i++) {
            String hotWord = list.get(i);
            int viewPosition = i + 1;
            View view = inflater.inflate(R.layout.********* null);
            TextView mTv = view.findViewById(R.id.#########);
            mTv.setText(hotWord);
            view.setTag(viewPosition);
            viewFlipper.addView(view);
}
         
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现安卓HorizontalScrollView每次滑动距离固定,可以通过监听HorizontalScrollView滑动事件,在滑动事件获取当前滑动的距离,如果当前滑动距离小于指定的距离,就让HorizontalScrollView继续滑动,否则就让HorizontalScrollView停止滑动。 具体实现代码可以参考以下示例: ``` private int mMaxScrollDistance = 100; // 指定每次滑动的最大距离 private HorizontalScrollView mHorizontalScrollView; private int mLastScrollX = 0; private boolean mIsScrolling = false; // 初始化HorizontalScrollView并设置滑动监听 private void initHorizontalScrollView() { mHorizontalScrollView = findViewById(R.id.horizontal_scroll_view); mHorizontalScrollView.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_MOVE: int scrollX = mHorizontalScrollView.getScrollX(); if (Math.abs(scrollX - mLastScrollX) > mMaxScrollDistance) { mIsScrolling = true; } mLastScrollX = scrollX; break; case MotionEvent.ACTION_UP: if (mIsScrolling) { int scrollX1 = mHorizontalScrollView.getScrollX(); int dx = scrollX1 % mMaxScrollDistance; if (dx > mMaxScrollDistance / 2) { mHorizontalScrollView.smoothScrollBy(mMaxScrollDistance - dx, 0); } else { mHorizontalScrollView.smoothScrollBy(-dx, 0); } mIsScrolling = false; } break; } return false; } }); } ``` 在上述示例,我们定义了一个mMaxScrollDistance变量,用于指定每次滑动的最大距离。在HorizontalScrollView滑动事件,我们通过获取当前滑动的距离和上一次滑动的距离,计算出当前滑动的距离是否大于指定的最大距离,如果是,则将mIsScrolling标记为true,表示当前正在进行滑动操作。在手指抬起的事件,如果当前正在进行滑动操作,则根据当前滑动的距离计算出需要滑动的距离,并通过HorizontalScrollView的smoothScrollBy方法来实现滑动效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值