簡(jiǎn)評(píng):使用 StateListAnimator 輕松實(shí)現(xiàn) Material Design 效果。
專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)靖安免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了千余家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
Material Design 中最基礎(chǔ)的一條原則就是 'motion provides meaning',也就是當(dāng)用戶和你的 app 交互時(shí)應(yīng)當(dāng)提供合理的視覺(jué)反饋。標(biāo)準(zhǔn)做法是使用官方提供的 StateListDrawable 來(lái)為控件實(shí)現(xiàn)交互效果。
StateListAnimator 是和 Material Design 一同在 API 21 引入的,可以用來(lái)方便的實(shí)現(xiàn)交互反饋的視覺(jué)效果,今天這篇文章就講解了 StateListAnimator 的用法。
在以前,我們處理 Button,TextView 等控件的點(diǎn)擊效果時(shí),通常是定義一個(gè) selector,為按下和普通情況分別設(shè)置顏色。但這樣的效果一方面不夠動(dòng)人,另一方面也不符合 Material Design 的規(guī)范。
Material Design 規(guī)范推薦 Button 等控件應(yīng)當(dāng)以材質(zhì)的方式表現(xiàn),當(dāng)接觸到手指時(shí)上升。因此 Material Design 對(duì)組件有了 z 軸這個(gè)概念,也就是高度。z 值越大,組件離界面底層(水平面)越遠(yuǎn),投影越重。
那我們?cè)趺磥?lái)實(shí)現(xiàn)組件在 z 軸(高度)上的變化效果呢?這就需要用到今天講到的 StateListAnimator 了。
首先,讓我們創(chuàng)建一個(gè) animator 資源文件夾,在其中創(chuàng)建一個(gè) selector_animator.xml:
<?xml version="1.0" encoding="utf-8"?>
代碼很簡(jiǎn)單,當(dāng)處于按下情況時(shí),組件沿 x, y 軸擴(kuò)大 1.025 倍并升高 4dp(會(huì)在組件四周產(chǎn)生投影效果)。
需要注意其中的 propertyName 屬性目前支持:
然后在 layout 文件中設(shè)置組件的 stateListAnimator 值就可以啦:
因?yàn)橹醪恢С?gif,感興趣的同學(xué)可以點(diǎn)擊原文鏈接查看實(shí)現(xiàn)效果。
原文:StateListAnimator
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。