自定義View

自定義控件的三種實現(xiàn)方法

  1. 對現(xiàn)有控件進行拓展
  2. 通過組合來實現(xiàn)新的控件:將系統(tǒng)原生控件組合起來帜消,加上動畫效果模蜡,形成一種特殊的UI效果
  3. 繼承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寬高的兩種方式

    1. 先使用view.measure(0,0)主動通知系統(tǒng)去測量View刽射,然后再使用view.getMeasuredWidth()view.getMeasuredHeight()就可以成功獲取原始測量寬高

    2. 為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)方法

    1. dispatchTouchEvent():用來分發(fā)觸摸事件馏颂,如果接下來被攔截則交給onTouchEvent()處理示血,否則傳遞給子View

    2. onInterceptTouchEvent():返回true表示攔截,false表示不攔截

    3. onTouchEvent():處理觸摸事件

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末救拉,一起剝皮案震驚了整個濱河市难审,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌亿絮,老刑警劉巖告喊,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異派昧,居然都是意外死亡黔姜,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門蒂萎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來秆吵,“玉大人,你說我怎么就攤上這事五慈∧杉牛” “怎么了主穗?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長毙芜。 經(jīng)常有香客問我忽媒,道長,這世上最難降的妖魔是什么腋粥? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任晦雨,我火速辦了婚禮,結(jié)果婚禮上隘冲,老公的妹妹穿的比我還像新娘闹瞧。我一直安慰自己,他們只是感情好对嚼,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著绳慎,像睡著了一般纵竖。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上杏愤,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天靡砌,我揣著相機與錄音,去河邊找鬼珊楼。 笑死通殃,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的厕宗。 我是一名探鬼主播画舌,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼已慢!你這毒婦竟也來了曲聂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤佑惠,失蹤者是張志新(化名)和其女友劉穎朋腋,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體膜楷,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡旭咽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了赌厅。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片穷绵。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖特愿,靈堂內(nèi)的尸體忽然破棺而出请垛,到底是詐尸還是另有隱情催训,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布宗收,位于F島的核電站漫拭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏混稽。R本人自食惡果不足惜采驻,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望匈勋。 院中可真熱鬧礼旅,春花似錦、人聲如沸洽洁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽饿自。三九已至汰翠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間昭雌,已是汗流浹背复唤。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留烛卧,地道東北人佛纫。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像总放,于是被迫代替她去往敵國和親呈宇。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容