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ū)挾?,可自行修改mScrollExHeight = 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. HTML DOM setInterval和clearInterval方法案例詳解2. css代碼優(yōu)化的12個(gè)技巧3. 使用css實(shí)現(xiàn)全兼容tooltip提示框4. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera5. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案6. 詳解瀏覽器的緩存機(jī)制7. HTML <!DOCTYPE> 標(biāo)簽8. css進(jìn)階學(xué)習(xí) 選擇符9. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)10. 告別AJAX實(shí)現(xiàn)無(wú)刷新提交表單
