在5.0以上系统,原生方式实现触模反馈

1.项目得用5.0或5.0以上的sdk 编译。

如:

android{
  compileSdkVersion 21
  buildToolsVersion '21.1.2'
}

2.添加 5.0样式(material design)

在value下,新建文件夹values-v21

添加styles.xml

<?xml version="1.0" encoding="uft-8">
<resources>
    <style name="AppBaseTheme" parent="android:Theme.Material.Light">
        <item name="android:windowTranslucentStatus">true</item>
    </style>
</resources>

3.添加一些5.0 对应的drawable 或者selector

首先新建一个drawable-v21的文件夹

  • a.有背景图片的按钮(Button)

正常情况下,我们会写一个selector

如:selector_login.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"
    >
  <!-- 这里只写了一种状态,也可以写多种-->
    <item android:drawable="@drawable/log_in"/>
</selector>

在drawable-21 里添加对应的文件( selector_login.xml )

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/post_item_list_s_ripple"><!-- 这里的这个color是必须不可少的参数-->

    <item android:drawable="@drawable/log_in"/>

</ripple>

android:color=”@color/post_item_list_s_ripple” 这个颜色值 ,就是对应的波纹颜色。

最后,在对应的按钮里设置背景就Ok

<Button
  android:id="@+id/btnExit"
  style="@style/layout_wrap"
  android:layout_gravity="center_horizontal"
  android:layout_marginTop="50dp"
  android:background="@drawable/selector_login"
  android:text="@string/setting_exit"
  android:textColor="@color/white_color" />
  • b.listview列表选项。

其本和上面按钮的是一样的。但是有几点注意。

1.发现用listSelector 比 用 itemView 的backgroud兼容性更好。

如果用listSelector的话:

item normal 时的颜色最好设置成ListView 的背景颜色。否则ListView 的item 都是没有默认色。

4.用代码创建 RippleDrawable

首先,创建一个selector (用代码的方式)

// 代码构建一个shape
GradientDrawable drawable = new GradientDrawable();
drawable.setColor(Color.parseColor("#ffffff"));
drawable.setStroke(1, getResources().getColor(R.color.all_bg));

GradientDrawable drawable_h = new GradientDrawable();
drawable_h.setColor(getResources().getColor(R.color.all_bg));

//构建一个根据 view 状态改变的Drawable
StateListDrawable stateListDrawable = new StateListDrawable();

//Non focused states
stateListDrawable.addState(new int[]{-android.R.attr.state_focused, 
    -android.R.attr.state_selected,
    -android.R.attr.state_pressed},
        drawable);
stateListDrawable.addState(new int[]{-android.R.attr.state_focused,
    android.R.attr.state_selected,
    -android.R.attr.state_pressed},
        drawable_h);
//Focused states
stateListDrawable.addState(new int[]{android.R.attr.state_focused, 
    -android.R.attr.state_selected, -android.R.attr.state_pressed},
        drawable_h);
stateListDrawable.addState(new int[]{android.R.attr.state_focused, 
    android.R.attr.state_selected, -android.R.attr.state_pressed},
        drawable_h);
//Pressed
stateListDrawable.addState(new int[]{android.R.attr.state_selected, 
    android.R.attr.state_pressed},
        drawable_h);
stateListDrawable.addState(new int[]{android.R.attr.state_pressed},
        drawable_h);

//上面是一个完整的,所以有点多。可以取部分自己需要。

创建RippleDrawable 就稍微简单得一点儿

// 还是上面的drawable 和 drawable_h
ColorStateList stateList = ColorStateList.valueOf(Color.parseColor("#cccccc"));
RippleDrawable rippleDrawable = new RippleDrawable(stateList,drawable,drawable_h);

    原文作者:满脸胡渣的年轻大叔
    原文地址: https://www.jianshu.com/p/3a45b3b7e346
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞