這篇文章主要為大家展示了“android如何實現(xiàn)ios的UIScrollView”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“android如何實現(xiàn)ios的UIScrollView”這篇文章吧。
公司主營業(yè)務:做網站、網站建設、移動網站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出烏魯木齊免費做網站回饋大家。
首先,最最最重要的就是判斷當前視圖是否為空,你空視圖滾不滾好像沒啥區(qū)別,除了android 5.0的scrollview自帶了那種弧度。好像沒什么軟用~~~
//視圖不為空即可滾動 protected void onFinishInflate() { if (getChildCount() > 0) { childview = getChildAt(0); } }
這個屬性我也是剛知道沒多久,意思是當所有的布局呈現(xiàn)完成之后調用這個方法。
我這邊附上view常用的方法,你們可以自行研究,有好多方法我也不知道~~~.
自定義 View的常用方法:
onFinishInflate() 當View中所有的子控件 均被映射成xml后觸發(fā)
onMeasure(int, int) 確定所有子元素的大小
onLayout(boolean, int, int, int, int) 當View分配所有的子元素的大小和位置時觸發(fā)
onSizeChanged(int, int, int, int) 當view的大小發(fā)生變化時觸發(fā)
onDraw(Canvas) view渲染內容的細節(jié)
onKeyDown(int, KeyEvent) 有按鍵按下后觸發(fā)
onKeyUp(int, KeyEvent) 有按鍵按下后彈起時觸發(fā)
onTrackballEvent(MotionEvent) 軌跡球事件
onTouchEvent(MotionEvent)觸屏事件
onFocusChanged(boolean, int, Rect) 當View獲取 或失去焦點時觸發(fā)
onWindowFocusChanged(boolean) 當窗口包含的view獲取或失去焦點時觸發(fā)
onAttachedToWindow() 當view被附著到一個窗口時觸發(fā)
onDetachedFromWindow() 當view離開附著的窗口時觸發(fā),提示該方法和 onAttachedToWindow() 是相反的。
onWindowVisibilityChanged(int) 當窗口中包含的可見的view發(fā)生變化時觸發(fā)
以上是View實現(xiàn)的一些基本接口的回調方法,一般我們需要處理畫布的顯示時,重寫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; }
以上是“android如何實現(xiàn)ios的UIScrollView”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!