关于ontouchlistener的监听问题

写了一个类似鼠标的东西 在屏幕上有个view 然后加一个ontouchlistener(不是加给view的) 以下是部分代码 一个浮动框的代码 和 ontouch事件的代码
mWM = (WindowManager) getBaseContext().getSystemService(Context.WINDOW_SERVICE);
ivCursor = new ImageView(getBaseContext());
ivCursor.setImageResource(R.drawable.ic_launcher);
mParams = new WindowManager.LayoutParams();// 对ivCursor对象的参数描述对象
mParams.height = WindowManager.LayoutParams.WRAP_CONTENT;// 宽度自适应
mParams.width = WindowManager.LayoutParams.WRAP_CONTENT;// 高度自适应
mParams.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;// 设置成不能获取焦点
mParams.type = LayoutParams.TYPE_PHONE;
// 设置图片格式,效果为背景透明
mParams.format = PixelFormat.RGBA_8888;
//mParams.gravity = Gravity.TOP | Gravity.LEFT;
mParams.x = 0;// 相对于屏幕原点的x轴距离
mParams.y = 0;// 相对于屏幕原点的y轴距离
mWM.addView(ivCursor, mParams);

    relativeLayout.setOnTouchListener(new OnTouchListener() {

        @Override
        public boolean onTouch(View v, MotionEvent event) {
            // TODO Auto-generated method stub
            int action = event.getAction();
            switch (action) {
            case MotionEvent.ACTION_DOWN:
                x=event.getRawX();
                y=event.getRawY();          
                break;
            case MotionEvent.ACTION_MOVE:
                mx=event.getRawX();
                my=event.getRawY();
                rx=mx-x;
                ry=my-y;
                mParams.x =(int) rx;
                mParams.y =(int)ry;
                mWM.updateViewLayout(ivCursor, mParams);
                break;
            case MotionEvent.ACTION_UP:
                break;
            }
            return true;
        }
    });

    然后问题就出现了 第一次去 down --move -- up 很正常 那个浮动框也跟着动 up之后也就停在了移动过后的位置 但是第二次 再去 down -- move 的时候 当出现move事件的时候那个浮动框就回到了刚开始的初始位置 然后再去跟着移动再停止  这是怎么回事啊 为什么会出现这样的情况啊 有没有大神帮忙解决下啊 很急!!

这个是因为你在回调MotionEvent.ACTION_MOVE的方法里,mParams.x和mParams.y每次都是以原点为基准进行移动的,请用以下代码试试:

 private int mParamsX, mParamsY;
            relativeLayout.setOnTouchListener(new OnTouchListener() {
        @Override
        public boolean onTouch(View v, MotionEvent event) {
            // TODO Auto-generated method stub
            int action = event.getAction();
            switch (action) {
            case MotionEvent.ACTION_DOWN:
                x=event.getRawX();
                y=event.getRawY();  

                                // 先记录一下在手指按下时view所在位置
                                mParamsX = mParams.x;
                                mParamsX = mParams.x;
                break;
            case MotionEvent.ACTION_MOVE:
                mx=event.getRawX();
                my=event.getRawY();
                rx=mx-x;
                ry=my-y;
                mParams.x = mParamsX + (int) rx;
                mParams.y = mParamsY + (int) ry;
                mWM.updateViewLayout(ivCursor, mParams);
                break;
            case MotionEvent.ACTION_UP:
                break;
            }
            return true;
        }
    });

你看看有没有其他的滑动监听,是不是焦点被抢夺了

http://blog.csdn.net/lxk_1993/article/details/50725489