Android實(shí)現(xiàn)快速滾動(dòng)FastScrollView效果
先看效果圖:
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); //擴(kuò)展拖動(dòng)區(qū)域?qū)挾龋勺孕行薷膍ScrollExHeight = dip2px(50); //擴(kuò)展拖動(dòng)區(qū)域高度,可自行修改 } @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,用于預(yù)留特殊空隙 * * @param mRightPadding */ public void setRightPadding(int mRightPadding) {this.mRightPadding = mRightPadding; }}
布局中設(shè)置了大滾動(dòng)條樣式,滾動(dòng)時(shí)更加明顯:
<com.zwxuf.apkparserdemo.FastScrollViewandroid: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'> <HorizontalScrollViewandroid:layout_width='match_parent'android:layout_height='match_parent' > <EditTextandroid: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>
同理,可以依此制作快速滾動(dòng)的 HorizontalScrollView。
到此這篇關(guān)于Android實(shí)現(xiàn)快速滾動(dòng)FastScrollView的文章就介紹到這了,更多相關(guān)android滾動(dòng)FastScrollView內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. php讀取xml中某個(gè)元素的內(nèi)容(PHP5以上才支持)2. Java基于redis和mysql實(shí)現(xiàn)簡(jiǎn)單的秒殺(附demo)3. SpringBoot+SpringCache實(shí)現(xiàn)兩級(jí)緩存(Redis+Caffeine)4. Kotlin + Flow 實(shí)現(xiàn)Android 應(yīng)用初始化任務(wù)啟動(dòng)庫(kù)5. IDEA SpringBoot 項(xiàng)目配置Swagger2的詳細(xì)教程6. 快速解決ajax返回值給外部函數(shù)的問題7. Java通俗易懂系列設(shè)計(jì)模式之模板模式8. jsp文件下載功能實(shí)現(xiàn)代碼9. AJAX實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)效果10. ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式詳解
