今天重新裝了編譯器,結果崩無極限,真是日了狗了了。剛剛才知道問題在哪邊。
好了,說正事,對于ios開發我沒接觸,不是很了解,百度了半天,差不多就是UIScrollView的把。如果不對,請指證。具體什么效果呢,我剛才拿朋友的iphone手機看了下,iphone的設置界面,第一個列表往下拉可以繼續滾,上拉同理。不過android好像沒有自帶的這種情況。
我把這種效果稱為滾無極限的scollview。
下面就來上源碼:
首先,最最最重要的就是判斷當前視圖是否為空,你空視圖滾不滾好像沒啥區別,除了android 5.0的scrollview自帶了那種弧度。好像沒什么軟用~~~
//視圖不為空即可滾動 protected void onFinishInflate() { if (getChildCount() > 0) { childview = getChildAt(0); } }這個屬性我也是剛知道沒多久,意思是當所有的布局呈現完成之后調用這個方法。
我這邊附上view常用的方法,你們可以自行研究,有好多方法我也不知道~~~.
自定義 View的常用方法:
onFinishInflate() 當View中所有的子控件 均被映射成xml后觸發
onMeasure(int, int) 確定所有子元素的大小
onLayout(boolean, int, int, int, int) 當View分配所有的子元素的大小和位置時觸發
onSizeChanged(int, int, int, int) 當view的大小發生變化時觸發
onDraw(Canvas) view渲染內容的細節
onKeyDown(int, KeyEvent) 有按鍵按下后觸發
onKeyUp(int, KeyEvent) 有按鍵按下后彈起時觸發
onTrackballEvent(MotionEvent) 軌跡球事件
onTouchEvent(MotionEvent)觸屏事件
onFocusChanged(boolean, int, Rect) 當View獲取 或失去焦點時觸發
onWindowFocusChanged(boolean) 當窗口包含的view獲取或失去焦點時觸發
onAttachedToWindow() 當view被附著到一個窗口時觸發
onDetachedFromWindow() 當view離開附著的窗口時觸發,提示該方法和 onAttachedToWindow() 是相反的。
onWindowVisibilityChanged(int) 當窗口中包含的可見的view發生變化時觸發
以上是View實現的一些基本接口的回調方法,一般我們需要處理畫布的顯示時,重寫onDraw(Canvas)用的的是最多的。
接下來就是ontouch事件來判斷位移和回彈的效果啦:
if (childview != null) { int action = event.getAction(); switch (action) { case MotionEvent.ACTION_DOWN: break; case MotionEvent.ACTION_UP: //判斷是否需要動畫 if (!normal.isEmpty()) { animation(); isCount = false; } break; case MotionEvent.ACTION_MOVE: final float DownY = startY; float moveY = event.getY(); int distance = (int) (DownY - moveY); if (!isCount) { distance = 0; // 在這里要歸0. } startY = moveY; if (isNeedMove()) { //頂部 if (normal.isEmpty()) { normal.set(childview.getLeft(), childview.getTop(), childview.getRight(), childview.getBottom()); } //底部 childview.layout(childview.getLeft(), childview.getTop() - distance / 2, childview.getRight(), childview.getBottom() - distance / 2); } isCount = true; break; }后面就是判斷是否需要滾動和回彈的動畫效果了。
public void animation() { // 開啟移動動畫 TranslateAnimation animation = new TranslateAnimation(0, 0, childview.getTop(), normal.top); animation.setDuration(200); childview.startAnimation(animation); // 設置回到正常的布局位置 childview.layout(normal.left, normal.top, normal.right, normal.bottom); normal.setEmpty(); } public boolean isNeedMove() { int offset = childview.getHeight() - getHeight(); int scrollY = getScrollY(); // 0是頂部,后面那個是底部 if (scrollY == 0 || scrollY == offset) { return true; } return false; }好了,一個滾,滾,滾,滾無極限的scrollview就誕生了。其實我感覺這個實用性不是很大,看個人需求了。其實也是蠻好玩的~
以上這篇android開發仿ios的UIScrollView實例代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答