先看效果图:
public class FastScrollView extends ScrollView { private Rect mBarRect = new Rect(); private int mScrollExWidth; private int mScrollExHeight; private boolean mScrollStart; private int dx, dy; private int mRightPadding; public FastScrollView(Context context) { super(context); init(); } public FastScrollView(Context context, AttributeSet attrs) { super(context, attrs); init(); } public FastScrollView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(); } private void init() { mScrollExWidth = dip2px(16); //扩展拖动区域宽度,可自行修改 mScrollExHeight = dip2px(50); //扩展拖动区域高度,可自行修改 } @Override public boolean dispatchTouchEvent(MotionEvent ev) { switch (ev.getAction() & ev.getActionMasked()) { case MotionEvent.ACTION_DOWN: //Log.e("fly", "down"); mScrollStart = false; if (canScroll()) { dx = (int) ev.getX(); dy = (int) ev.getY(); float scrollPos = (float) getHeight() / getChildView().getHeight(); int barHeight = (int) (scrollPos * getHeight()); //Log.e("fly", scrollPos+", "+ barHeight); mBarRect.left = getWidth() - mRightPadding - getVerticalScrollbarWidth(); mBarRect.right = getWidth() - mRightPadding; mBarRect.top = (int) (getScrollY() * scrollPos); mBarRect.bottom = mBarRect.top + barHeight; //Dbg.print(mBarRect.left, mBarRect.right, mBarRect.top, mBarRect.bottom, dx, dy); if (dx >= mBarRect.left - mScrollExWidth && dx < mBarRect.right && dy >= mBarRect.top - mScrollExHeight && dy < mBarRect.bottom + mScrollExHeight) { //Log.e("fly", "mScrollStart"); mScrollStart = true; } } break; case MotionEvent.ACTION_MOVE: if (mScrollStart) { int offsetY = (int) ev.getY() - dy; //Log.e("fly", "move: " + ev.getY()); int top = mBarRect.top + offsetY; float scrollPos = (float) top / getHeight(); int scrollY = (int) (scrollPos * getChildView().getHeight()); if (scrollY < 0) { scrollY = 0; } if (scrollY > getChildView().getHeight() - getHeight()) { scrollY = getChildView().getHeight() - getHeight(); } setScrollY(scrollY); return true; } break; } return super.dispatchTouchEvent(ev); } private boolean canScroll() { View child = getChildView(); if (child != null && child.getHeight() > getHeight()) { return true; } else { return false; } } private View getChildView() { if (getChildCount() > 0) { return getChildAt(0); } else { return null; } } private int dip2px(float dpValue) { final float scale = getContext().getResources().getDisplayMetrics().density; return (int) (dpValue * scale + 0.5f); } /** * 这里不用view的paddding,用于预留特殊空隙 * * @param mRightPadding */ public void setRightPadding(int mRightPadding) { this.mRightPadding = mRightPadding; } }
布局中设置了大滚动条样式,滚动时更加明显:
<com.zwxuf.apkparserdemo.FastScrollView android:id="@+id/mScrollView" android:layout_width="0dp" android:layout_weight="1" android:scrollbarSize="10dp" android:paddingRight="10dp" android:scrollbarThumbVertical="@drawable/fast_scroll_thumb_drawable" android:layout_height="match_parent"> <HorizontalScrollView android:layout_width="match_parent" android:layout_height="match_parent" > <EditText android:id="@+id/et_xml" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@null" android:editable="false" android:textColor="#000000" android:textSize="10sp" android:typeface="monospace"/> </HorizontalScrollView> </com.zwxuf.apkparserdemo.FastScrollView>
同理,可以依此制作快速滚动的 HorizontalScrollView。
到此这篇关于Android实现快速滚动FastScrollView的文章就介绍到这了,更多相关android滚动FastScrollView内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!
- 本文固定链接: https://zxbcw.cn/post/219854/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)