@conjugatedirection と @Tomasz からの以前の回答でのカラー フィルターの提案が気に入っています。しかし、これまでに提供されたコードは、思ったほど簡単に適用できないことがわかりました。
まず、カラー フィルターをどこに適用してクリアするかについては言及されていませんでした。これを行うのに適した場所が他にもある可能性がありますが、私が思いついたのはOnTouchListener でした。
元の質問を読んだところ、理想的な解決策は画像を含まないものです。@emmby の custom_button.xml を使用して受け入れられた回答は、それが目標である場合、おそらくカラー フィルターよりも適切です。私の場合、ボタンがどのように見えるべきかの UI デザイナーからの png 画像から始めています。ボタンの背景をこの画像に設定すると、デフォルトのハイライト フィードバックが完全に失われます。このコードは、その動作をプログラムによる暗くする効果に置き換えます。
button.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
// 0x6D6D6D sets how much to darken - tweak as desired
setColorFilter(v, 0x6D6D6D);
break;
// remove the filter when moving off the button
// the same way a selector implementation would
case MotionEvent.ACTION_MOVE:
Rect r = new Rect();
v.getLocalVisibleRect(r);
if (!r.contains((int) event.getX(), (int) event.getY())) {
setColorFilter(v, null);
}
break;
case MotionEvent.ACTION_OUTSIDE:
case MotionEvent.ACTION_CANCEL:
case MotionEvent.ACTION_UP:
setColorFilter(v, null);
break;
}
return false;
}
private void setColorFilter(View v, Integer filter) {
if (filter == null) v.getBackground().clearColorFilter();
else {
// To lighten instead of darken, try this:
// LightingColorFilter lighten = new LightingColorFilter(0xFFFFFF, filter);
LightingColorFilter darken = new LightingColorFilter(filter, 0x000000);
v.getBackground().setColorFilter(darken);
}
// required on Android 2.3.7 for filter change to take effect (but not on 4.0.4)
v.getBackground().invalidateSelf();
}
});
これを複数のボタンに適用するための別のクラスとして抽出しました - アイデアを得るために匿名の内部クラスとして表示されます。