Android 自定義布局豎向的ViewPager的實(shí)現(xiàn)
效果圖:
這個(gè)自定義控件涉及到的知識(shí)點(diǎn):
自定義ViewGroup中onMeasure和onLayout的寫(xiě)法
彈性滾動(dòng)Scroller的用法
速度軌跡追蹤器VelocityTracker的用法
如何處理滑動(dòng)事件沖突
dispatchTouchEvent:(外部攔截)告訴此ScrollLayout的父布局,什么時(shí)候該攔截觸摸事件,什么時(shí)候不該攔截觸摸事件
onInterceptTouchEvent:(內(nèi)部攔截)ScrollLayout告訴自己什么時(shí)候要攔截內(nèi)部子View的觸摸事件,什么時(shí)候不要攔截內(nèi)部子View的觸摸事件
處理觸摸滑動(dòng)的思路:
//即確定當(dāng)前顯示的子控件的位置, //確定彈性滑動(dòng)滑向那個(gè)位置 if (Math.abs(velocityY) > criticalVelocityY) {//當(dāng)手指滑動(dòng)速度快時(shí),按照速度方向直接翻頁(yè) // 重點(diǎn)二、快速滑動(dòng)時(shí),如何判斷當(dāng)前顯示的是第幾個(gè)控件,并且再次包含邊界判斷(必須包含邊界判斷,因?yàn)榍懊娴倪吔缗袛?,只適用于低速滑動(dòng)時(shí)) if (shouZhiXiangXiaHuaDong) { if (currentPage > 1) {//★★★★★★★★邊界限制,防止滑倒第一個(gè),還繼續(xù)滑動(dòng),注意★(currentPage-2) mScroller.startScroll(0, getScrollY(), 0, childHeight * (currentPage - 2) - getScrollY()); currentPage--; } } else { if (currentPage < childCount) {//★★★★★★★邊界限制,防止滑倒最后一個(gè),還繼續(xù)滑動(dòng),注意★currentPage mScroller.startScroll(0, getScrollY(), 0, childHeight * currentPage - getScrollY()); currentPage++; } } Log.e("eee", currentPage + "");