实现ImageView按下变暗,抬起变亮。

直接上代码
package com.test.app;

import android.app.Activity;
import android.graphics.Color;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.widget.ImageView;


import com.readystatesoftware.viewbadger.BadgeView;

public class MainActivity extends Activity {
	ImageView ll_show;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.sss);

		ll_show = (ImageView) findViewById(R.id.ll_show);
		ImageViewListener imageViewListener = new ImageViewListener();
		ll_show.setOnClickListener(imageViewListener);
		ll_show.setOnTouchListener(imageViewListener);
	}

	class ImageViewListener implements OnClickListener, OnTouchListener {

		@Override
		public boolean onTouch(View v, MotionEvent event) {
			if (event.getAction() == MotionEvent.ACTION_UP) {
				((ImageView)v).clearColorFilter(); // 清除滤镜效果
			}
			if (event.getAction() == MotionEvent.ACTION_DOWN) {
				((ImageView)v).setColorFilter(Color.parseColor("#77000000")); // 设置滤镜效果
			}
			<span style="color:#ff6666;">return false;// 重点注意</span>
		}

		@Override
		public void onClick(View v) {
			ToastUtils.customShowShort(getApplication(), "click");
		}
	}
}



这里使用了ImageView的滤镜效果,在ImageViewListener里面的onTouch方法中return false。

如果return true的话,则onClick()事件不会被调用。详细请看Android的View的事件传递。

你可能感兴趣的:(实现ImageView按下变暗,抬起变亮。)