Android自訂控制項:Android L控制項點擊水波紋的實現(源碼 + Demo)

來源:互聯網
上載者:User

標籤:控制項   android   android開發   源碼   ui   

實現思路來自singwhatiwanna

http://blog.csdn.net/singwhatiwanna/article/details/42614953


Demo:



一、控制項的流程:

大致上如下,實際是有些偏差的大家可以自己畫畫

RevealLayout()--->init()--->onMeasure()--->onLayout()--->onDraw()--->dispatchTouchEvent()--->getTargetView()--->isTouchPointInView()--->-initParametersForChild()-->dispatchDraw()


二、設計思路:

1、為什麼選擇使用LinearLayout

從Layout去實現這個效果很大一個原因是減少代碼複用,我們知道,如果只對Button,TextView等控制項進行重寫,很多代碼其實都是相似的(幾乎一樣)這樣我們等於不斷地寫一樣的東西,浪費了時間,所以為了可複用的原則,我們重寫一個Layout。


從dispatchDraw()裡的設計我們可以知道,我們在這實現水波紋的效果,是不斷的重新整理控制項,增大canvas繪製的圓的半徑,實現視覺上圓增大的效果。


如果我們選用其他的layout,一方面可能會是繪製的內容更複雜(RelativeLayout),另一方面可能是適用性低(AbsoluteLayout)。而LinearLayout其實可以和Relative等布局結合使用,實現複雜布局,所以綜合來考慮我們選用LinearLayout來實現。


2、為什麼是dispatchTouchEvent()

在Android中,當TouchEvent發生時,首先Activity將TouchEvent傳遞給最頂層的View, TouchEvent最先到達最頂層 view 的dispatchTouchEvent ,然後由  dispatchTouchEvent 方法進行分發,如果dispatchTouchEvent返回true ,則交給這個view的onTouchEvent處理,如果dispatchTouchEvent返回 false ,則交給這個 view 的 interceptTouchEvent 方法來決定是否要攔截這個事件,如果 interceptTouchEvent 返回 true ,也就是攔截掉了,則交給它的 onTouchEvent 來處理,如果 interceptTouchEvent 返回 false ,那麼就傳遞給子 view ,由子 view 的 dispatchTouchEvent 再來開始這個事件的分發。如果事件傳遞到某一層的子 view 的 onTouchEvent 上了,這個方法返回了 false ,那麼這個事件會從這個 view 往上傳遞,都是 onTouchEvent 來接收。而如果傳遞到最上面的 onTouchEvent 也返回 false 的話,這個事件就會“消失”,而且接收不到下一次事件。


3、為什麼在dispatchTouchEvent()中使用getRawX與getRawY獲得座標

getX和getY獲得的是相對於被點擊的View的座標,而getRawX獲得的是相對於螢幕的座標。而我們想要看到的水波紋效果,應該是從相對於螢幕中被點擊的點向外散開水波。


4、initParametersForChild()中的mMaxRadius是什麼,mTransformedCenterX又是什麼

這個我覺得用一張圖來解釋會非常好懂


5、dispatchDraw()是怎麼繪製出水波紋的

基於前面的基礎,我們在dispatchDraw()裡是不斷的重新整理頁面,在mRadius達到mMaxRadius之前,都重新整理並且在canvas中繪製新的圓。延時操作是防止棧溢出和UI線程阻塞。


三、源碼下載

Click Here!

Android自訂控制項:Android L控制項點擊水波紋的實現(源碼 + Demo)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.