Android-悬浮窗效果FloatingView

作者: Kotyo | 来源:发表于2018-03-05 23:34 被阅读209次

前言

之前有写录制视频的小demo,有同学反映要添加浮窗View,这样录制的时候就不需要来回切换当前的页面。所以,这里我晚上花了点时间写了一个FloatingView

老规矩,先看图


这里我们需要用的就是WindowManger来add布局

public class FloatingViewService extends Service {

    private WindowManager mWindowManager;
    private View mFloatingView;

    public FloatingViewService() {
    }

    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    @Override
    public void onCreate() {
        super.onCreate();
        mFloatingView = LayoutInflater.from(this).inflate(R.layout.layout_floating_view, null);
        //设置WindowManger布局参数以及相关属性
        final WindowManager.LayoutParams params = new WindowManager.LayoutParams(
                WindowManager.LayoutParams.WRAP_CONTENT,
                WindowManager.LayoutParams.WRAP_CONTENT,
                WindowManager.LayoutParams.TYPE_PHONE,
                WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE,
                PixelFormat.TRANSLUCENT);
        //初始化位置
        params.gravity = Gravity.TOP | Gravity.LEFT;       
        params.x = 10;
        params.y = 100;
        //获取WindowManager对象
        mWindowManager = (WindowManager) getSystemService(WINDOW_SERVICE);
        mWindowManager.addView(mFloatingView, params);
        //关闭FloatingView
        ImageView closeBtn = (ImageView) mFloatingView.findViewById(R.id.close_btn);
        closeBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                stopSelf();
            }
        });
        //录制按钮
        ImageView screenBtn = (ImageView) mFloatingView.findViewById(R.id.screen_btn);
        screenBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(FloatingViewService.this, "点击录制", Toast.LENGTH_LONG).show();
            }
        });
        
       //FloatingView的拖动事件    
       mFloatingView.findViewById(R.id.floating_container).setOnTouchListener(new View.OnTouchListener() {
            //获取X坐标
            private int startX;
            //获取Y坐标
            private int startY;
            //初始化X的touch坐标
            private float startTouchX;
            //初始化Y的touch坐标
            private float startTouchY;

            @Override
            public boolean onTouch(View v, MotionEvent event) {
                switch (event.getAction()) {
                    case MotionEvent.ACTION_DOWN:
                        startX = params.x;
                        startY = params.y;
                        startTouchX = event.getRawX();
                        startTouchY = event.getRawY();
                        return true;
                    case MotionEvent.ACTION_MOVE:
                        params.x = startX + (int) (event.getRawX() - startTouchX);
                        params.y = startY + (int) (event.getRawY() - startTouchY);
                        //更新View的位置
                        mWindowManager.updateViewLayout(mFloatingView, params);
                        return true;
                }
                return false;
            }
        });
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        //移除FloatingView
        if (mFloatingView != null) mWindowManager.removeView(mFloatingView);
    }
}

Mainfest.xml需要添加相关权限以及注册Service

<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>

<service android:name="cn.android.example.knowledge.service.FloatingViewService"
            android:enabled="true"/>

这样,就可以把之前的录制视频的代码,与FloatingView相结合,这样录制起来就方便一点了。

好了,睡觉了。。。

相关文章

网友评论

    本文标题:Android-悬浮窗效果FloatingView

    本文链接:https://www.haomeiwen.com/subject/uonhfftx.html