问题:如何让HorizontalScrollView中的item能滚动的时候点击居中

解决时间:9:00 — 13:50
解决路程:
1、 首先,想到的就是通过计算item和边框之间的距离来使其滚动到指定的位置,所以上网上找了一些方法,都是有关于计算的,具体代码就不说啦,反正都是不好使,具体思路就是,计算选中的item到第一个item的距离,判断是否大于屏幕的一半,大于就滚动,滚动的距离就是二者之差,
2、 可是坏就坏在判断上,这一上午的时间就一直在调试这个判断,各种判断条件都试一遍,但是,不是在开头的时候滚动不对,就是在末尾的时候滚动不对,或者向右滚动好使,但是向左不好使。也是没谁啦。
3、 最后还找了一个自定义的HorizontalScrollView,说是可以自动让item居中,但是用不明白,放弃啦,
4、 最后,自己冷静一下,然后不在按照网上代码的思路去想,自己写了一个方法,解决啦,很简单就一句话。
解决方案:
scrollViewWidth = mHorizontalScrollView.getWidth();
int rb_px = (int)rb.getX() + rb.getWidth() / 2;
mHorizontalScrollView.scrollTo( rb_px - scrollViewWidth / 2 , 0);

不在获取item之间的距离,而是获取点击的item与屏幕之间的距离getX(),不在进行判断,而是直接滚动,滚动的距离就是item与屏幕距离-屏幕的一半。这样只要可以滚动就可以滚动到中间。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在Android开发,我们可以使用HorizontalScrollView来实现图片左右滚动的功能。HorizontalScrollView是一个可以水平滚动的视图容器,可以包含任意数量的子视图,在用户滑动时自动滚动。 首先,在布局文件使用HorizontalScrollView作为容器,设置其宽度和高度适配图片的尺寸,例如: ``` <HorizontalScrollView android:layout_width="match_parent" android:layout_height="200dp"> <LinearLayout android:layout_width="wrap_content" android:layout_height="match_parent"> <!--在这里添加需要滚动的图片--> </LinearLayout> </HorizontalScrollView> ``` 然后,在代码动态地添加图片到LinearLayout: ```java LinearLayout linearLayout = findViewById(R.id.linear_layout); for (int i = 0; i < imageNameList.size(); i++) { ImageView imageView = new ImageView(this); imageView.setImageResource(imageNameList.get(i)); linearLayout.addView(imageView); } ``` 其,`imageNameList`是一个包含图片资源ID的列表,可以根据自己的需求进行设置。 滚动效果的实现是通过监听用户的手势来实现的,可以使用`OnTouchListener`接口来监听HorizontalScrollView的滑动事件: ```java horizontalScrollView.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { int action = event.getAction(); switch (action) { case MotionEvent.ACTION_DOWN: // 手指按下时的操作 break; case MotionEvent.ACTION_MOVE: // 手指滑动时的操作 break; case MotionEvent.ACTION_UP: // 手指抬起时的操作 break; } return false; } }); ``` 在滑动事件,可以通过调用HorizontalScrollView的`scrollTo()`方法来实现滚动的效果: ```java int scrollX = horizontalScrollView.getScrollX(); // 获取滚动的距离 int scrollTo = scrollX + distance; // 根据手指滑动的距离计算要滚动到的位置 horizontalScrollView.scrollTo(scrollTo, 0); // 进行滚动 ``` 其,`distance`是根据手指滑动的速度和方向计算出来的滑动距离。 这样,就可以通过使用HorizontalScrollView来实现图片的左右滚动了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值