在 API < & > 21 的 ListView 项上创建涟漪效应
Create Ripple Effect on ListView Item for API < & > 21
我有下面的 XML 并且正在尝试创建 onClick 的连锁反应。 ListView 中每个项目的背景都是黑色的,所以理想情况下,波纹效果会产生某种灰色:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/selectableItemBackground"
android:orientation="vertical">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="80dp"
android:background="@color/black"
android:orientation="horizontal">
<ImageView
android:id="@+id/imageView1"
android:layout_width="80dp"
android:layout_height="80dp"
android:src="@drawable/placeholder" />
<TextView
android:id="@+id/latest_item_question"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/white"
android:textSize="12sp" />
</LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
代码创建以下内容。请注意,我想涵盖 pre 和 post Lollipop:
尝试为 api pre Lollipop 创建两个背景,一个有波纹,另一个没有波纹
在 drawable
中创建
ripple_gray.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- Non focused states -->
<item android:state_pressed="true">
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<corners android:radius="3dp"/>
<solid android:color="@android:color/white"/>
</shape>
</item>
<item>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<corners android:radius="3dp"/>
<solid android:color="@android:color/black"/>
</shape>
</item>
</selector>
在 drawable-v21 中创建
ripple_gray.xml
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@android:color/white">
<item android:drawable="@android:color/black"/>
</ripple>
使用 ripple_gray 创建并添加 id
更改 XML 布局背景
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/selectableItemBackground"
android:orientation="vertical">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
<LinearLayout
android:id="@+id/viewId"
android:layout_width="match_parent"
android:layout_height="80dp"
android:background="@drawable/ripple_gray"
android:orientation="horizontal">
<ImageView
android:id="@+id/imageView1"
android:layout_width="80dp"
android:layout_height="80dp"
android:src="@drawable/placeholder" />
<TextView
android:id="@+id/latest_item_question"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/white"
android:textSize="12sp" />
</LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
</LinearLayout>
在你的 ACtivity onCreate() 或你需要的地方
findViewById(R.id.viewId).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
我有下面的 XML 并且正在尝试创建 onClick 的连锁反应。 ListView 中每个项目的背景都是黑色的,所以理想情况下,波纹效果会产生某种灰色:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/selectableItemBackground"
android:orientation="vertical">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="80dp"
android:background="@color/black"
android:orientation="horizontal">
<ImageView
android:id="@+id/imageView1"
android:layout_width="80dp"
android:layout_height="80dp"
android:src="@drawable/placeholder" />
<TextView
android:id="@+id/latest_item_question"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/white"
android:textSize="12sp" />
</LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
代码创建以下内容。请注意,我想涵盖 pre 和 post Lollipop:
尝试为 api pre Lollipop 创建两个背景,一个有波纹,另一个没有波纹 在 drawable
中创建ripple_gray.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- Non focused states -->
<item android:state_pressed="true">
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<corners android:radius="3dp"/>
<solid android:color="@android:color/white"/>
</shape>
</item>
<item>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<corners android:radius="3dp"/>
<solid android:color="@android:color/black"/>
</shape>
</item>
</selector>
在 drawable-v21 中创建 ripple_gray.xml
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@android:color/white">
<item android:drawable="@android:color/black"/>
</ripple>
使用 ripple_gray 创建并添加 id
更改 XML 布局背景<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/selectableItemBackground"
android:orientation="vertical">
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
<LinearLayout
android:id="@+id/viewId"
android:layout_width="match_parent"
android:layout_height="80dp"
android:background="@drawable/ripple_gray"
android:orientation="horizontal">
<ImageView
android:id="@+id/imageView1"
android:layout_width="80dp"
android:layout_height="80dp"
android:src="@drawable/placeholder" />
<TextView
android:id="@+id/latest_item_question"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/white"
android:textSize="12sp" />
</LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/white" />
</LinearLayout>
在你的 ACtivity onCreate() 或你需要的地方
findViewById(R.id.viewId).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});