導航:首頁 > 操作系統 > android系統懸浮窗

android系統懸浮窗

發布時間:2023-02-06 20:42:53

android8.0之懸浮窗和通知欄

懸浮窗:

        使用場景:例如微信在視頻的時候,點擊Home鍵,視頻小窗口仍然會在屏幕上顯示;

        注意事項:

                1、一般需要在後台進行操作的時候才需要懸浮窗,這樣懸浮窗才有意義;

                2、API Level >= 23的時候,需要在AndroidManefest.xml文件中聲明許可權SYSTEM_ALERT_WINDOW才能在其他應用上繪制控制項。

<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />;除了這個許可權外,我們還需要在系統設置裡面對本應用進行設置懸浮窗許可權。該許可權在應用中需要啟動Settings.ACTION_MANAGE_OVERLAY_PERMISSION來讓用戶手動設置許可權:startActivityForResult(new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName())), REQUEST_CODE);

                3、LayoutParam設置:LayoutParam里的type變數。這個變數是用來指定窗口類型的。在設置這個變數時,需要注意一個坑,那就是需要對不同版本的Android系統進行適配。

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {

    layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;

} else {

    layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;

};在Android 8.0之前,懸浮窗口設置可以為TYPE_PHONE,這種類型是用於提供用戶交互操作的非應用窗口。

而Android 8.0對系統和API行為做了修改,包括使用SYSTEM_ALERT_WINDOW許可權的應用無法再使用一下窗口類型來在其他應用和窗口上方顯示提醒窗口:

- TYPE_PHONE

- TYPE_PRIORITY_PHONE

- TYPE_SYSTEM_ALERT

- TYPE_SYSTEM_OVERLAY

- TYPE_SYSTEM_ERROR

如果需要實現在其他應用和窗口上方顯示提醒窗口,那麼必須該為TYPE_APPLICATION_OVERLAY的新類型;

如果在Android 8.0以上版本仍然使用TYPE_PHONE類型的懸浮窗口,則會出現如下異常信息:

android.view.WindowManager$BadTokenException: Unable to add window android.view.ViewRootImpl$W@f8ec928 -- permission denied for window type 2002;

        具體實現:

        1、Activity:
        public void startFloatingService(View view) {        

    ...

    if (!Settings.canDrawOverlays(this)) {

        Toast.makeText(this, "當前無許可權,請授權", Toast.LENGTH_SHORT);

        startActivityForResult(new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName())), 0);

    } else {

        startService(new Intent(MainActivity.this, FloatingService.class));

    }

}

@Override

protected void onActivityResult(int requestCode, int resultCode, Intent data) {

    if (requestCode == 0) {

        if (!Settings.canDrawOverlays(this)) {

            Toast.makeText(this, "授權失敗", Toast.LENGTH_SHORT).show();

        } else {

            Toast.makeText(this, "授權成功", Toast.LENGTH_SHORT).show();

            startService(new Intent(MainActivity.this, FloatingService.class));

        }

    }

}

2、service:

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

    showFloatingWindow();

    return super.onStartCommand(intent, flags, startId);

}

private void showFloatingWindow() {

    if (Settings.canDrawOverlays(this)) {

        // 獲取WindowManager服務

        WindowManager windowManager = (WindowManager) getSystemService(WINDOW_SERVICE);

        // 新建懸浮窗控制項

        Button button = new Button(getApplicationContext());

        button.setText("Floating Window");

        button.setBackgroundColor(Color.BLUE);

        // 設置LayoutParam

        WindowManager.LayoutParams layoutParams = new WindowManager.LayoutParams();

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {

            layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;

        } else {

            layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;

        }

        layoutParams.format = PixelFormat.RGBA_8888;

        layoutParams.width = 500;

        layoutParams.height = 100;

        layoutParams.x = 300;

        layoutParams.y = 300;

        // 將懸浮窗控制項添加到WindowManager

        windowManager.addView(button, layoutParams);

    }

}

        效果展示:

                

安卓系統懸浮球關閉

如果您想關閉懸浮導航,進入設置 > 系統和更新 > 系統導航方式 > 更多 或設置 > 系統和更新 > 系統導航方式 > 懸浮導航 (取決於您的機型),關閉懸浮導航開關。

Ⅲ 安卓手機開啟無障礙功能與懸浮窗的方法

怎麼開啟輔助服務?

使用優Q的功能必須開服輔助服務,輔助服務是安卓官方提供的功能。

打開優Q點擊【我的】點擊許可權設置,開啟即可。如果無法快速開啟,請參考如下的方法。

部分手機輔助可通過快捷鍵開啟,優Q仍提示未開啟,將輔助服務關閉一下再打開就可以了。

如果仍然無效,請先關閉優Q然後重啟手機。

VIVO設置-更多設置-輔助功能-開啟-優Q

OPPO設置-其他設置-輔助功能-開啟-優Q

小米設置-更多設置-無障礙-開啟-優Q

魅族設置-輔助功能-無障礙-開啟-優Q

華為設置-高級設置-輔助功能-開啟-優Q

聯想設置-高級設置-輔助功能-開啟-優Q

三星設置-輔助功能-開啟-優Q

樂視設置-輔助功能-開啟-優Q

360設置-輔助功能-開啟優Q

錘子設置-全局高級設置-輔助功能-開啟-優Q

一加設置-其他高級設置-無障礙-開啟-優Q

怎麼開啟懸浮窗?

部分高版本手機打開優Q會自動跳轉到懸浮窗開關。

打開優Q點擊【我的】點擊許可權設置,開啟懸浮窗即可。如果無法快速開啟,請參考如下的方法。

不同的手機打開懸浮窗許可權的方法不一樣,常見的方法是在應用許可權管理或手機管家進行設置。

VIVO

系統6.0:設置-更多設置-許可權管理-優Q-開啟懸浮窗系統

5.0:i管家-軟體管理-懸浮窗管理-開啟-"優Q

OPPO手機管家-隱私許可權-懸浮窗許可權管理-開啟

優Q

小米安全中心-應用許可權管理-優Q-允許顯示懸浮窗

魅族手機管家-應用許可權管理-優Q-開啟桌面懸浮窗

華為設置許可權管理-懸浮窗開啟優Q

聯想安全中心-許可權管理-顯示懸浮窗-

允許"優Q顯示懸浮窗

三星設置-應用程序-應用程序管理器-右上角更多-

可出現在頂部的應用程序-開啟優Q

樂視設置-隱私許可權-應用許可權管理器-應用列表

優Q-允許顯示懸浮窗

360安全衛士-軟體管理-許可權管理-優Q-

允許顯示懸浮窗

錘子設置-安全中心-應用程序許可權管理-懸浮窗-

開啟優Q

一加設置-應用程序-特殊訪問許可權-出現在其他應用上--找到優Q打開即可

三條魚軟體官網

Ⅳ 安卓的懸浮球怎麼設置的

若使用的是vivo手機,進入設置--快捷與輔助/更多設置--懸浮球中,將懸浮球開啟即可。
關閉的方法:進入設置--快捷與輔助/更多設置--懸浮球中,將懸浮球關閉即可。
註:目前支持懸浮球功能的機型有:X60t、iQOO Z3、iQOO Neo5、S9/S9e、Y31s標准版、S7t、iQOO 7、Y31s、X60/X60 Pro/X60 Pro+、iQOO U3、Y30標准版、Y52s、iQOO U1x、S7e、Y3s、Y30、Y73s、iQOO 5系列、S7、iQOO U1、iQOO Z1x、X50系列、Y70s、iQOO Z1、iQOO Neo3、Y50、S6、NEX 3S、Z6、iQOO 3、X30 Pro/X30、iQOO Neo 855競速版、U3、Y9s、Z5i、S5、Y5s、iQOO Neo 855版、U3x、NEX 3、Z5/Z5x、Y7s、X27/X27Pro、S1/S1Pro、Z3x、iQOO Pro/iQOO/iQOO Neo、NEX雙屏版、Y81s、Y70、X23、Y97、Y91、NEX/NEX旗艦版、Z1、Z3i、U1、X21/X21i、Y71、Y85、X20、Y79、Y75s、Y83、Y3、X20Plus(需升級至最新版本)。
可進入手機設置--快捷與輔助/更多設置--查看是否有「懸浮球」功能。

Ⅳ 安卓12打開浮懸窗,屏幕不觸控咋搞

可能是您手機系統限制了懸浮窗的顯示。
若您使用的手機為小米手機,建議您進入小米手機設置--安全中心--授權管理--應用許可權管理--應用管理--手機管家--顯示懸浮窗
將該許可權授予管家後即可正常顯示。
若您使用的手機為華為手機,建議您進入華為自帶手機管家--通知管理--懸浮窗口管理 將騰訊手機管家的開關打開即可正常顯示。
若您使用的手機系統為android5.0及其以上,則需要在手機管家的小火箭與桌面懸浮窗設置內開啟全部頁面顯示才能夠正常顯示。
其他機型,可以在系統設置中找類似的懸浮窗或者彈框許可權設置。

Ⅵ android 系統級的懸浮窗實現

當我們在使用的app的時候,如果需要實時觀測到某個功能的實時進度並且不影響其他的操作的時候或者不影響使用其他應用的時候,系統級的懸浮球是個非常不錯的選擇。

public class QueueUpFloatService extends Service {

/**

* 啟動服務並傳值

*

* @param activity 啟動服務的activity

* @param modeBean 數據對象

*/

public static void launchService(Activity activity, ModeBean modeBean) {

try {

        Intent intent =new Intent(activity, QueueUpFloatService.class);

        Bundle bundle =new Bundle();

        bundle.putSerializable(KEY_MODEL, modeBean);

        intent.putExtras(bundle);

        activity.startService(intent);

    }catch (Exception e) {

        e.printStackTrace();

    }

}

    @Override

    public void onCreate() {

            super.onCreate();

    }

    @Override

    public IBinder onBind(Intent intent) {

            return null;

    }

    @Override

    public int onStartCommand(Intent intent, int flags, int startId) {

            return super.onStartCommand(intent, flags, startId);

    }

    @Override

    public void onDestroy() {

            super.onDestroy();

    }

}

@Override

public void onCreate() {

    super.onCreate();

    //加一點簡單的動畫 

    buttonScale = (ScaleAnimation) AnimationUtils.loadAnimation(this, R.anim.anim_float);

    windowManager = (WindowManager) getSystemService(WINDOW_SERVICE);

    layoutParams =new WindowManager.LayoutParams();

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {

            layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;

    }else {

            layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;

    }

    layoutParams.format = PixelFormat.RGBA_8888;

    layoutParams.gravity = Gravity.LEFT | Gravity.TOP;

    layoutParams.flags = WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL |             WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;

    layoutParams.width = ScreenUtils.dp2px(66);

    layoutParams.height = ScreenUtils.dp2px(66);

    layoutParams.x = ScreenUtils.getRealWidth() - ScreenUtils.dp2px(60);

    layoutParams.y = ScreenUtils.deviceHeight() *2 /3;

}

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

    ModeBean modeBean = (ModeBean) intent.getExtras().getSerializable(KEY_MODEL);

    LayoutInflater layoutInflater = LayoutInflater.from(this);

    floatView = layoutInflater.inflate(R.layout.view_float, null);

    RelativeLayout rlFloatParent =floatView.findViewById(R.id.rl_float_parent);

    rlFloatParent.startAnimation(buttonScale);

    TextView tvIndex =floatView.findViewById(R.id.tv_queue_index);

    tvIndex.setText(modeBean.title);

    floatView.findViewById(R.id.iv_close_float).setOnClickListener(v -> stopSelf());

    //修改懸浮球的滑動實現

    floatView.setOnTouchListener(new FloatingOnTouchListener());

    windowManager.addView(floatView, layoutParams);

    return super.onStartCommand(intent, flags, startId);

}

private class View.OnTouchListener {

    private int x;

    private int y;

    private long downTime;

    @SuppressLint("ClickableViewAccessibility")

    @Override

    public boolean onTouch(View view, MotionEvent event) {

            switch (event.getAction()) {

                case MotionEvent.ACTION_DOWN:

                        downTime = System.currentTimeMillis();

                        x = (int) event.getRawX();

                        y = (int) event.getRawY();

                        break;

                case MotionEvent.ACTION_MOVE:

                        int nowX = (int) event.getRawX();

                        int nowY = (int) event.getRawY();

                        int movedX = nowX -x;

                        int movedY = nowY -y;

                        x = nowX;

                        y = nowY;

                        layoutParams.x =layoutParams.x + movedX;

                        layoutParams.y =layoutParams.y + movedY;

                        windowManager.updateViewLayout(view, layoutParams);

                        break;

                case MotionEvent.ACTION_UP:

                        /* *

                        * 這里根據手指按下和抬起的時間差來判斷點擊事件還是滑動事件

                        * */

                        if ((System.currentTimeMillis() -downTime) <200) {

                                //檢測應用在前台還是後台

                                if (AppUtils.isAppIsInBackground()) {

                                        AppUtils.moveToFront(CloseActivityUtils.activityList.get(CloseActivityUtils.activityList.size() -1).getClass());

                                } else {

                                        //檢測棧頂是否為SecondActivity 不是就打開SecondActivity

                                      if (!CloseActivityUtils.activityList.get(CloseActivityUtils.activityList.size() -1)

                                                .getClass().getSimpleName().contains("SecondActivity")) {

                                        SecondActivity.launchActivity(CloseActivityUtils.activityList.get(CloseActivityUtils.activityList.size() -1));

                                }

                      }

            }

                        break;

            default:

                        break;

        }

           return false;

    }

}

        @Override

        public void onDestroy() {

            super.onDestroy();

            if (null ==floatView) {

                return;

               }

            windowManager.removeView(floatView);

            windowManager=null;

}

Ⅶ 安卓12懸浮窗卡屏

可能驅動軟體沖突導致的。
建議通過以下步驟解決:1.強制重啟,系統升級,軟體升級。2.若依舊這樣,清理手機系統垃圾,查殺病毒。3.若依舊這樣恢復手機出廠設置。4.若依舊這樣,重新刷機。5.若依舊這樣、多數為主板問題,建議送修服務站維修。
懸浮窗是電腦或智能手機的系統工具,在其他應用的表面懸浮一可移動的窗口,以便打開不同應用,手機使用懸浮窗需要系統授權。

Ⅷ 安卓的懸浮球怎麼設置的啊

打開屏幕上的設置功能。
在下拉菜單中找到【輔助功能】,點擊打開。
1、找到【觸控】,點擊進去會發現,這個功能是處於關閉的狀態,點擊一下【關閉】。
2、在輔助觸控的後方有一個小開關,點擊打開右側的開關按鈕,這個懸浮球就出現在手機屏幕上了。
3、在輔助觸控的後方有一個小開關,點擊打開右側的開關按鈕,這個懸浮球就出現在手機屏幕上了。
4、在懸觸控設置下方,有一個【自定頂層菜單】,點擊進入後,選擇加號便可以添加各種功能。自定頂層菜單下方【單點】、【輕點兩下】、【長按】、【創建新手勢】等各種設置,根據自己的需求設置懸浮球上的功能即可。

Ⅸ android懸浮窗及許可權

懸浮窗許可權是Android提供的許可權中的特殊許可權,要申請後再使用,否則會導致彈框不能顯示、程序崩潰等問題

有的文章說MIUI系統可設置為 WindowManager.LayoutParams.TYPE_TOAST 避開懸浮框許可權的申請,我的實踐經驗是不要這樣設置,否則利用參考文獻中的方法操作後dialog還是顯示不出來

Android 懸浮窗許可權各機型各系統適配大全
Android懸浮窗及許可權 by JustDo23
github項目

Ⅹ 幣安懸浮窗怎麼設置

1、登陸APP後,在我的中點擊設置。
2、點擊懸浮窗設置。
3、進入懸浮窗設置後,打開懸浮窗顯示,然後進行行情選擇。(其中懸浮窗鎖定即固定懸浮窗位置,設置後不能隨意移動。懸浮窗透明度調節中,百分比越小越透明)。
4、點擊行情選擇選擇懸浮窗上顯示的幣種。目前支持58COIN、幣安和火幣的現貨指數。勾選需要顯示的交易對。
5、用戶可通過點擊行情選擇進入懸浮窗行情管理頁面,對已選交易對進行管理。
6、退出APP後,Android系統用戶可在手機桌面看到懸浮窗,並可通過雙擊桌面上的懸浮窗快速進入APP。

閱讀全文

與android系統懸浮窗相關的資料

熱點內容
linux網路編程伺服器 瀏覽:798
海爾32cw空調壓縮機電容多大 瀏覽:747
分區加密了該怎麼辦 瀏覽:101
索尼延時拍攝app怎麼導入 瀏覽:224
冰箱冷凍壞了壓縮機一直響 瀏覽:805
windows伺服器如何組建raid0 瀏覽:180
橡膠壓縮空氣管 瀏覽:556
如果出現編譯錯誤如何解決 瀏覽:924
程序員飾品 瀏覽:430
什麼叫網站伺服器站點 瀏覽:686
java轉義字元雙引號 瀏覽:779
網上考場的app怎麼看真假 瀏覽:644
四層電梯的plc編程 瀏覽:899
程序員的職場 瀏覽:662
圓形平面怎麼編程 瀏覽:67
python開源代碼下載 瀏覽:661
如何連接區域網寬頻連接伺服器地址 瀏覽:171
華為應用王者榮耀方舟編譯器 瀏覽:935
dim是什麼意思在演算法 瀏覽:592
學軍訓命令的感受 瀏覽:938