這篇文章主要為大家展示了“android如何實現(xiàn)ios的UIScrollView”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“android如何實現(xiàn)ios的UIScrollView”這篇文章吧。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的博州網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!首先,最最最重要的就是判斷當前視圖是否為空,你空視圖滾不滾好像沒啥區(qū)別,除了android 5.0的scrollview自帶了那種弧度。好像沒什么軟用~~~
//視圖不為空即可滾動 protected void onFinishInflate() { if (getChildCount() > 0) { childview = getChildAt(0); } }
這個屬性我也是剛知道沒多久,意思是當所有的布局呈現(xiàn)完成之后調(diào)用這個方法。
我這邊附上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渲染內(nèi)容的細節(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)的一些基本接口的回調(diào)方法,一般我們需要處理畫布的顯示時,重寫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); // 設(shè)置回到正常的布局位置 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”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!