From 1c757c667d4d827cc0bcf692dae663f7ca49b01c Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Sun, 01 May 2022 08:51:00 +0000
Subject: [PATCH] 悬浮窗  位置移动

---
 app/src/main/java/com/auto/lyric/MainActivity.java |   77 +++++++++++++++++++++++++++-----------
 1 files changed, 55 insertions(+), 22 deletions(-)

diff --git a/app/src/main/java/com/auto/lyric/MainActivity.java b/app/src/main/java/com/auto/lyric/MainActivity.java
index 0340eef..462bbc8 100644
--- a/app/src/main/java/com/auto/lyric/MainActivity.java
+++ b/app/src/main/java/com/auto/lyric/MainActivity.java
@@ -1,47 +1,58 @@
 package com.auto.lyric;
 
 import android.content.Intent;
+import android.graphics.PixelFormat;
 import android.net.Uri;
 import android.os.Build;
+import android.os.Handler;
+import android.os.Message;
 import android.provider.Settings;
 import android.text.TextUtils;
 import android.util.Log;
+import android.view.Gravity;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.WindowManager;
+
+import androidx.annotation.NonNull;
 
 import com.auto.lyric.base.activities.BaseActivity;
 import com.auto.lyric.databinding.ActivityMainBinding;
+import com.auto.lyric.databinding.FloatViewBinding;
 import com.auto.lyric.service.AutoInputService;
+import com.auto.lyric.service.FloatingWindowService;
 import com.auto.lyric.vm.MainViewModel;
 
 public class MainActivity extends BaseActivity<ActivityMainBinding, MainViewModel> {
 
-    Intent service  = new Intent(getApplicationContext(), AutoInputService.class);
-
     @Override
     public void initViews() {
 
-    }
+        Intent inputService  = new Intent(getApplicationContext(), AutoInputService.class);
 
-    @Override
-    protected void onResume() {
-        super.onResume();
+        Intent floatService  = new Intent(getApplicationContext(), FloatingWindowService.class);
+        binding.button.setOnClickListener(v -> {
 
-        //申请权限
-        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
-            //开启悬浮窗
-            if(!Settings.canDrawOverlays(getApplicationContext())) {
-                //启动Activity让用户授权
-                Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION);
-                intent.setData(Uri.parse("package:" + getPackageName()));
-                intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK );
-                startActivity(intent);
-            }else if(!isAccessibilitySettingsOn()){//辅助权限
-                Intent intent = new Intent(Settings.ACTION_ACCESSIBILITY_SETTINGS);
-                intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK );
-                startActivity(intent);
-            }else{//开启监听服务
-                startService(service);
+            //申请权限
+            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
+                //开启悬浮窗
+               /* if(!Settings.canDrawOverlays(getApplicationContext())) {
+                    //启动Activity让用户授权
+                    Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION);
+                    intent.setData(Uri.parse("package:" + getPackageName()));
+                    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK );
+                    startActivity(intent);
+                }else if(!isAccessibilitySettingsOn()){//辅助权限
+                    Intent intent = new Intent(Settings.ACTION_ACCESSIBILITY_SETTINGS);
+                    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK );
+                    startActivity(intent);
+                }else{//开启监听服务
+                    //startService(floatService);
+                }*/
+                startService(floatService);
+                //showFloatView();
             }
-        }
+        });
     }
 
     public boolean isAccessibilitySettingsOn() {
@@ -82,5 +93,27 @@
         return false;
     }
 
+    private void showFloatView(){
+
+
+        //View view = LayoutInflater.from(this).inflate(R.layout.float_view,null);
+        FloatViewBinding binding = FloatViewBinding.inflate(getLayoutInflater());
+        WindowManager manager = (WindowManager) getApplicationContext().getSystemService(WINDOW_SERVICE);
+        WindowManager.LayoutParams params = new WindowManager.LayoutParams();
+        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
+            params.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;
+        }else {
+            params.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;
+        }
+        params.format = PixelFormat.RGBA_8888;
+        params.gravity = Gravity.CENTER;
+        params.flags = WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL | WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;
+        params.width = WindowManager.LayoutParams.MATCH_PARENT;
+        params.height = WindowManager.LayoutParams.WRAP_CONTENT;
+        binding.btnBack.setOnClickListener(v ->{
+            stopService(new Intent(this,this.getClass()));
+        });
+        manager.addView(binding.getRoot(),params);
+    }
 
 }
\ No newline at end of file

--
Gitblit v1.9.1