原文作者是大牛:http://blog.csdn.net/yihongyuelan/article/details/14000363
對於手機OEM/ODM廠商來講,客製化是必不可少的,國際廠商比如三喪,LG等等,都會對原生Android進行定製。我們買到的手機,系統都是經過定製的,這跟Google Android AOSP有很大的區別,這些區別就是廠商們想搞的差異化。以下內容爲GlowPadView客製化的一些筆記,怕以後忘了再去查。
轉載請務必註明出處:http://blog.csdn.net/yihongyuelan
GlowPadView就是用來實現滑動接聽的控件,該控件隸屬InCallScreen界面,也就是我們撥打或接聽電話的那個界面,在之前的文章裏面也有提到關於InCallScreen界面UI的詳細分析,有興趣的童鞋可以自取搜來看一下。
最近需要做關於滑動接聽的一些定製,我們知道,Android原生就支持來電滑動接聽/拒接/短信回覆三種方式,實現該效果的控件在Android 4.2中叫GlowPadView.java,之前的版本叫做MultiWaveView.java。在Android 4.2上,Google對這一塊又做了一些改動,比如移除了在4.0上的水波紋動畫,滑動時不再顯示圓圈,取而代之的是小白點,帶面裏面叫PointCloud。之前在github上有看到一個開源項目,就是講4.2上的這種動畫效果提取出來,這對於像將該效果移植到4.2以前的設備上還是很有幫助的。
代碼位置:SourceCode/packages/app/Phone
滑動接聽控件佈局如下所示:
- <com.android.internal.widget.multiwaveview.GlowPadView
- android:id="@+id/incomingCallWidget"
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:layout_gravity="center|bottom"
- android:layout_marginTop="20dip"
- android:layout_marginBottom="-110dip"
- android:background="@android:color/black"
- android:visibility="gone"
- android:gravity="top"
- prvandroid:targetDrawables="@array/incoming_call_widget_3way_targets"
- prvandroid:targetDescriptions="@array/incoming_call_widget_3way_target_descriptions"
- prvandroid:directionDescriptions="@array/incoming_call_widget_3way_direction_descriptions"
- prvandroid:handleDrawable="@drawable/ic_in_call_touch_handle"
- prvandroid:innerRadius="@*android:dimen/glowpadview_inner_radius"
- prvandroid:outerRadius="@*android:dimen/glowpadview_target_placement_radius"
- prvandroid:outerRingDrawable="@*android:drawable/ic_lockscreen_outerring"
- prvandroid:snapMargin="@*android:dimen/glowpadview_snap_margin"
- prvandroid:vibrationDuration="20"
- prvandroid:feedbackCount="1"
- prvandroid:glowRadius="@*android:dimen/glowpadview_glow_radius"
- prvandroid:pointDrawable="@*android:drawable/ic_lockscreen_glowdot"
- />
名詞解釋:
1. targetDrawables
來電接聽控件默認有三個處理事件:接聽、拒接、短信回覆。這裏的@arrary/incoming_call_widget_3way_targets實際內容如下:
- <array name="incoming_call_widget_3way_targets">
- <item>@drawable/ic_lockscreen_answer</item>
- <item>@drawable/ic_lockscreen_text</item>
- <item>@drawable/ic_lockscreen_decline</item>
- <item>@null</item>"
- </array>
針對接聽控件對應的描述文字。內容如下:
- <array name="incoming_call_widget_3way_target_descriptions">
- <item>@string/description_target_answer</item>
- <item>@string/description_target_send_sms</item>
- <item>@string/description_target_decline</item>
- <item>@null</item>"
- </array>
對滑動接聽控件方向的描述,內容如下:
- <array name="incoming_call_widget_3way_direction_descriptions">
- <item>@*android:string/description_direction_right</item>
- <item>@*android:string/description_direction_up</item>
- <item>@*android:string/description_direction_left</item>
- <item>@null</item>
- </array>
這個就是中間按個小圓圈的圖片資源
5. innerRadius
內圓的半徑大小。這裏說的內圓使我們看不到的,與後面提到的外圓對應起來。當來電時會有一個小白點從中心向外擴散的動畫,這裏的起點就是從innerRadius開始的。
6. outerRadius
外圓的半徑大小。與前面的內圓對應起來,都是用於輔助顯示小白點動畫的,外圓就是動畫的截止點,內圓爲起始點。
7. outerRingDrawable
外圓的邊界線。這是通過shape配置畫出來的。代碼如下:
- <shape xmlns:android="http://schemas.android.com/apk/res/android"
- android:shape="oval"
- >
- <size android:height="@dimen/keyguard_lockscreen_outerring_diameter"
- android:width="@dimen/keyguard_lockscreen_outerring_diameter" />
- <solid android:color="#00000000" />
- <stroke android:color="#1affffff" android:width="2dp" />
- </shape>
8. snapMargin
距離target多遠會達到觸發條件。也就是在來電時,如果我們點擊中間的按鈕並逐漸向接聽側滑動,當滑動到一定的位置時,會自動將將接聽按鈕的狀態改變,隨之圖片也會改變。這裏的snapMargin就是用來判斷我們手指與target距離的。
9. vibrationDuration
震動持續時長。
10. feedbackCount
動畫出現的次數。也就是來電時,小白點從內向外擴散,這種效果只有一次。這裏爲什麼會有這個參數呢?因爲在Android 4.0時,那個時候還沒有小白點,只有水波紋,而且這個值也默認是3,我們可以看到來電時,會閃動3個水波紋,Android 4.2在其基礎上進行了修改,但爲了保留原來的結構,因此並沒有大刀闊斧的刪掉這些代碼。
11. glowRadius
這個是光暈半徑。也就是當我們按下並移動時,跟隨我們手指移動的那一小團小白點。在4.0中是handleDrawable會跟着移動,4.2中但出發了onTouchEvent後,handleDrawable就會消失,取而代之的是出現一小圈小白點,也就是這裏的光暈半徑。
12. pointDrawable
這就是那個小白點的資源。
說明圖如下: