自定義控件的三種實現(xiàn)方法
- 對現(xiàn)有控件進行拓展
- 通過組合來實現(xiàn)新的控件:將系統(tǒng)原生控件組合起來帜消,加上動畫效果模蜡,形成一種特殊的UI效果
- 繼承View來實現(xiàn)全新的控件
通過組合來實現(xiàn)新的控件
優(yōu)酷菜單
對于消失動畫
- 角度:逆時針旋轉(zhuǎn)解孙,0 ~ -180
- 旋轉(zhuǎn)中心:底部中心點
輪播大圖
ViewPager是Android 3.0之后才出現(xiàn)的携茂,之前版本使用v4包里面的
ViewPager預加載機制:最多保存3個page澜搅,即當前顯示的page以及位于其左右的page敞掘,超過的page要被銷毀掉
下拉選擇
如果Listview的item中有Button越驻、ImageButton汁政、CheckBox等會強制獲取焦點的子控件道偷,整個item將無法獲取焦點,也就無法被點擊
解決方法:給item的根布局增加以下屬性
android:descendantFocusability="blocksDescendants"
重寫View來實現(xiàn)全新的控件
滑動開關(guān)
-
自定義控件步驟
- 測量:
onMeasure()
設置控件的原始測量寬高记劈,如果不需要支持wrap_content屬性勺鸦,則無需重寫該方法 - 布局:
onLayout()
設置控件顯示在屏幕上的位置(只有在自定義ViewGroup時才需要重寫,手動設置其子View的位置) - 繪制:
onDraw()
繪制View顯示在屏幕上的樣子(只有在自定義View時才用到)
- 測量:
-
View和ViewGroup的相同點和不同點
- 他們都需要進行測量操作
- ViewGroup主要是控制子View如何擺放目木,所以自定義ViewGroup必須實現(xiàn)
onLayout()
- 自定義View必須實現(xiàn)
onDraw()
下拉刷新
ListView的addHeaderView()必須在setAdapter()之前調(diào)用
將headerView的paddingTop設置為其高度的負值可以隱藏它
-
getHeight()和getMeasuredHeight()的區(qū)別
getMeasuredHeight():獲取原始測量高度换途,必須在onMeasure()之后執(zhí)行
getHeight():獲得最終顯示高度,必須在onLayout()之后執(zhí)行
-
獲取View寬高的兩種方式
先使用
view.measure(0,0)
主動通知系統(tǒng)去測量View刽射,然后再使用view.getMeasuredWidth()
和view.getMeasuredHeight()
就可以成功獲取原始測量寬高-
為View注冊一個監(jiān)聽器OnGlobalLayoutListener军拟,當View的onLayout()執(zhí)行完就會回調(diào)
onGlobalLayout()
,在回調(diào)方法中使用view.getWidth()
和view.getHeight()
就可以成功獲取寬高view.getViewTreeObserver().addOnGlobalLayoutListener(new OnGlobalLayoutListener() { @Override public void onGlobalLayout() { // onLayout()執(zhí)行完 view.getViewTreeObserver().removeOnGlobalLayoutListener(this); // 及時解除OnGlobalLayoutListener int viewHeight = view.getHeight(); // 直接可以獲取寬高 } });
setSelection(position)
將position位置的item放置到屏幕頂端
側(cè)滑菜單
- 在自定義ViewGroup中一般不需要我們?nèi)ブ貙憃nMeasure()誓禁,我們可以繼承系統(tǒng)已有的ViewGroup懈息,比如繼承FrameLayout,它在onMeasure()中已經(jīng)實現(xiàn)了對所有子View的測量摹恰,不需要我們再重寫onMeasure()就已支持wrap_content屬性
-
在ViewGroup中辫继,讓內(nèi)容移動有以下幾個方法:
view.layout(l,t,r,b)
offsetLeftAndRight(offsetX)
和offsetTopAndBottom(offsetY)
通過View的LayoutParams改變View的Margin
scrollTo(x, y)
和scrollBy(x, y)
,移動的是View的內(nèi)容俗慈,而不是View本身姑宽,所以不會影響View的背景
-
上面的方法都是瞬間移動,沒有過渡效果(彈性滑動)闺阱,下列方法可以讓View在一段時間內(nèi)移動到某個位置
使用Scroller低千,模擬一個執(zhí)行過程
使用自定義動畫,本質(zhì)是讓View在一段時間內(nèi)做某件事
-
Touch事件分發(fā)機制的三個相關(guān)方法
dispatchTouchEvent()
:用來分發(fā)觸摸事件馏颂,如果接下來被攔截則交給onTouchEvent()處理示血,否則傳遞給子ViewonInterceptTouchEvent()
:返回true表示攔截,false表示不攔截onTouchEvent()
:處理觸摸事件