Android L Ripple的使用


聲明:Demo並不是有本人所寫,本人只是總結在這里

 

工程源碼: RippleDemo.zip

----------------------------------------------------

總綱

1. 沒有邊界的Ripple(Ripple With No Mask)

2. 用顏色作為Mask的Ripple(Ripple With Color Mask),然而顏色並沒有什么卵用

3. 用圖片作為Mask的Ripple(Ripple With Picture Mask)

4. 用設定形狀作為Mask的Ripple(Ripple With Shape Mask)

5. 搭配selector作為Ripple(Ripple With Selector)

----------------------------------------------------

1. 沒有邊界的Ripple(Ripple With No Mask)

 

<ripple>標簽
Ripple標簽,即對應一個RippleDrawable,當它被設置為一個控件的background屬性時,控件在按下時,即會顯示水波效果

 

ripple_red.xml

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="#FF0000" >
    
</ripple>

使用 

<TextView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/ripple_red"
    android:clickable="true"
    android:gravity="center"
    android:text="Ripple With No Mask" />

效果:

 

 

2. 用顏色作為Mask的Ripple(Ripple With Color Mask),然而顏色並沒有什么卵用,對於限定邊界還是有用的

    如果在一個ripple標簽中,添加一個item,其id為@android:id/mask,drawable屬性為引用的顏色(color) ,則水波效果會限定在drawable對應的RippleDrawable本身矩形區域內部。

     ripple_red_with_white_mask.xml

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
        android:color="#FF0000" >

    <item android:id="@android:id/mask"
         android:drawable="@android:color/white" />
    
</ripple>

效果

    

 

3. 用圖片作為Mask的Ripple(Ripple With Picture Mask)

     如果在一個ripple標簽中,添加一個item,其id為@android:id/mask,drawable屬性為引用的圖片(png,jpg),則水波效果會限定在圖片drawable中非透明部分對應的區域內部。

     ripple_red_with_pic_mask

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
        android:color="#FF0000" >

    <item android:id="@android:id/mask"
         android:drawable="@drawable/icon_folder_r" />
    
</ripple>

    效果:

    

    

 

4. 用設定形狀作為Mask的Ripple(Ripple With Shape Mask)

    如果在一個ripple標簽中,添加一個item,其id為@android:id/mask,drawable屬性為引用的形狀(shape) ,則水波效果會限定在shape對應的區域內部。

     先定義shape:shape.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
    android:shape="rectangle">
    <solid android:color="#ff9d77"/>
    <corners 
        android:bottomRightRadius="100dp"/>
</shape>

 

     在定義ripple:ripple_red_with_shape_mask

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="#FF0000" >

    <item 
        android:id="@android:id/mask"
        android:drawable="@drawable/shape"/>

</ripple>

    效果:

    

 

 

5. 搭配selector作為Ripple(Ripple With Selector)

    如果在一個ripple標簽中,添加一個item,在item的內部寫上<selector>標簽,那么這個RippleDrawable在按下的時候,同時具有水波效果和selector指定的圖層。

    ripple_red_with_selector

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="#FF0000" >
    <item>
        <selector>
            <item
                android:drawable="@drawable/icon_folder_i"
                android:state_pressed="true">
            </item>
            <item
                android:drawable="@drawable/icon_folder_r"
                android:state_pressed="false">
            </item>
        </selector>
    </item>

</ripple>

    效果

    

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM