android hover监控鼠标移动事件

在Android 4.0及以上版本,引入了hover事件来监测鼠标光标在View上的移动变化。本文将介绍如何利用hover组件实现鼠标监控功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     android之前对于鼠标光标事件的监控非常少,4.0之后多了一个hover的组件,此组件可以监控鼠标光标在view上的变化。

     代码如下:

public class HoverDemoActivity extends Activity {
	private Button btnBottom;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        btnBottom = (Button) findViewById(R.id.btn_bottom);
        
        btnBottom.setOnHoverListener(new OnHoverListener() {
			@Override
			public boolean onHover(View v, MotionEvent event) {
				int what = event.getAction();
				switch(what){
				 case MotionEvent.ACTION_HOVER_ENTER:  //鼠标进入view
					 System.out.println("bottom ACTION_HOVER_ENTER");
                     break;
                 case MotionEvent.ACTION_HOVER_MOVE:  //鼠标在view上
                	 System.out.println("bottom ACTION_HOVER_MOVE");
                     break;
                 case MotionEvent.ACTION_HOVER_EXIT:  //鼠标离开view
                	 System.out.println("bottom ACTION_HOVER_EXIT");
                     break;
				}
				return false;
			}
		});
    }
}
    当view隐藏时,无法监控点击,触摸和hover事件。

  

dependencies { compile "com.android.support:support-v4:20.+" compile 'com.nineoldandroids:library:2.4.0' compile 'com.daimajia.easing:library:1.0.0@aar' compile 'com.daimajia.androidanimations:library:1.1.2@aar' compile 'com.daimajia.androidviewhover:library:1.0.4@aar' } Create an original view, and make sure it was wrapped by BlurLayout for example: <com.daimajia.androidviewhover.BlurLayout android:id="@+id/sample" android:layout_width="wrap_content" android:layout_height="wrap_content"> <ImageView android:layout_centerInParent="true" android:scaleType="fitXY" android:src="@drawable/kid" android:layout_width="match_parent"/> </com.daimajia.androidviewhover.BlurLayout> Note: BlurLayout is entended from RelativeLayout. You can use the RelativeLayout rules to layout your view. Create a hover view, there is no rules to obey. Just please remember that this view will be stretched as large as the original view you have created. Bind a hover view to BlurLayout BlurLayout sampleLayout = (BlurLayout)findViewById(R.id.sample); View hover = LayoutInflater.from(mContext).inflate(R.layout.hover, null); sampleLayout.setHoverView(hover); and don't forget that you can add various animations just in one line code. For example: //View (R.id.heart) appear animation. sampleLayout.addChildAppearAnimator(hover, R.id.heart, Techniques.FlipInX); //View (R.id.heart) disappear animation. sampleLayout.addChildDisappearAnimator(hover, R.id.heart, Techniques.FlipOutX); You can view the samples in my preset examples.
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值