概述
先看效果图:
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内容请搜索靠谱客以前的文章或继续浏览下面的相关文章希望大家以后多多支持靠谱客!
最后
以上就是炙热萝莉为你收集整理的Android实现快速滚动FastScrollView效果的全部内容,希望文章能够帮你解决Android实现快速滚动FastScrollView效果所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复