@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();
}
});
私はこれを複数のボタンに適用するための個別のクラスとして抽出しました-アイデアを得るために匿名の内部クラスとして示されています。