クリックアニメーションを追加しようとしています ここに示すように をリサイクラービューに追加しましたが、失敗しました。これが私のコードの一部です。
私の活動の中
@Override
protected void onCreate(Bundle savedInstanceState) {
...
mRecyclerView = (RecyclerView) findViewById(R.id.recycler_view);
ItemOffsetDecoration itemDecoration = new ItemOffsetDecoration(this, R.dimen.card_item_offset);
mRecyclerView.addItemDecoration(itemDecoration);
mLayoutManager = new LinearLayoutManager(this);
mRecyclerView.setLayoutManager(mLayoutManager);
mAdapter = new CustomAdapter(this);
mRecyclerView.setAdapter(mAdapter);
}
ビューホルダー内
public CustomViewHolder(View itemView) {
super(itemView);
this.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
/* on click stuff here */
}
});
}
CardView.xml内
<?xml version="1.0" encoding="utf-8"?>
<Android.support.v7.widget.CardView
xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:card_view="http://schemas.Android.com/apk/res-auto"
Android:id="@+id/card_loading"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
card_view:cardCornerRadius="4dp"
Android:clickable="true"
Android:background="?android:attr/selectableItemBackground">
<TextView
Android:id="@+id/card_message"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content" />
</Android.support.v7.widget.CardView>
問題がどこにあるかわからないが、助けてくれてありがとう=)
これは、前景ではなく背景で試行しているリップル効果と呼ばれます
Android:focusable="true"
Android:clickable="true"
Android:foreground="?android:attr/selectableItemBackground"
カスタムにすることもできます
<ripple xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:color="@color/colorcode">
<item
Android:id="@Android:id/mask"
Android:drawable="@color/colorcode" />
</ripple>
古いバージョンでサポートするには、そのようにすることができます
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:Android="http://schemas.Android.com/apk/res/Android">
<item Android:state_pressed="true">
<shape Android:shape="rectangle">
<solid Android:color="@color/colorcode" />
</shape>
</item>
<item>
<shape Android:shape="rectangle">
<solid Android:color="@Android:color/colorcode" />
</shape>
</item>
</selector>