Android如何實現(xiàn)懸浮窗全系統(tǒng)版本

小編給大家分享一下Android如何實現(xiàn)懸浮窗全系統(tǒng)版本,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

站在用戶的角度思考問題,與客戶深入溝通,找到雜多網(wǎng)站設(shè)計與雜多網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋雜多地區(qū)。

懸浮窗是在系統(tǒng)上顯示的內(nèi)容,好像微信視頻聊天時的小窗口一樣,在退出軟件后依然存在的一個窗口,本博客以窗口中放一個button組件為例,簡單展示懸浮窗,其中包括了對Android 6.0以下、Android 6.0到Android 8.0、Android 8.0以上版本的處理,下面開始介紹實現(xiàn)方法:

1、MainActivity中的代碼

public Button mFloatingButton;
 
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
 
  //初始化view
  initView();
 }
 //初始化view
 private void initView() {
  mFloatingButton=(Button) findViewById(R.id.floating_btn);
  mFloatingButton.setOnClickListener(this);
 }
 
 public void startFloatingButtonService(View view) {
  Log.e("測試流程", "測試流程");
  if (FloatingService_Button.isStarted) {
   Log.e("測試流程2", "測試流程2");
   return;
  }
  if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {//判斷系統(tǒng)版本
   if (!Settings.canDrawOverlays(this)) {
    Toast.makeText(this, "當(dāng)前無權(quán)限,請授權(quán)", Toast.LENGTH_SHORT);
    Log.e("測試流程3", "測試流程3");
    startActivityForResult(new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName())), 0);
   } else {
    Log.e("測試流程4", "測試流程4");
    startService(new Intent(MainActivity.this, FloatingService_Button.class));
   }
  } else {
   startService(new Intent(MainActivity.this, FloatingService_Button.class));
  }
 
 }
 
 @Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  if (requestCode == 0) {
   if (!Settings.canDrawOverlays(this)) {
    Log.e("測試流程5", "測試流程5");
    Toast.makeText(this, "授權(quán)失敗", Toast.LENGTH_SHORT).show();
   } else {
    Log.e("測試流程6", "測試流程6");
    Toast.makeText(this, "授權(quán)成功", Toast.LENGTH_SHORT).show();
    startService(new Intent(MainActivity.this, FloatingService_Button.class));
   }
  }
 }
 
 @Override
 public void onClick(View v) {
  switch (v.getId()){
   case R.id.floating_btn :
    startFloatingButtonService(v);
    break;
  }
 }

思路簡單解釋:點擊彈出懸浮窗按鈕時,獲取版本并判斷“Build.VERSION.SDK_INT >= Build.VERSION_CODES.M”如果系統(tǒng)版本在6.0以下這不需要請求權(quán)限,如果系統(tǒng)版本在6.0以上需要進行權(quán)限檢測以及請求,獲取權(quán)限后,彈出懸浮框

2、activity_main.xml代碼

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context="com.example.jack_lin.suspendwindow.MainActivity">
 
 <Button
  android:id="@+id/floating_btn"
  
  android:text="@string/floating_btn" />
 
 
</LinearLayout>

簡單解釋:xml中沒什么特別東西,線性布局中放一個按鈕

3、FloatingService_Button的代碼

public static boolean isStarted = false;
 
 private WindowManager windowManager;
 private WindowManager.LayoutParams layoutParams;
 
 private Button button;
 
 @Override
 public void onCreate() {
  super.onCreate();
  Log.e("進入服務(wù)1", "進入服務(wù)1");
  isStarted = true;
  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 = 500;
  layoutParams.height = 100;
  layoutParams.x = 300;
  layoutParams.y = 300;
 }
 
 @Nullable
 @Override
 public IBinder onBind(Intent intent) {
  Log.e("進入服務(wù)2", "進入服務(wù)2");
 
  return null;
 }
 
 @Override
 public int onStartCommand(Intent intent, int flags, int startId) {
  Log.e("進入服務(wù)3", "進入服務(wù)3");
  showFloatingWindow();
  return super.onStartCommand(intent, flags, startId);
 }
 
 private void showFloatingWindow() {
  if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {//判斷系統(tǒng)版本
   if (Settings.canDrawOverlays(this)) {
    button = new Button(getApplicationContext());
    button.setText("我是個button窗口");
    button.setBackgroundColor(Color.BLUE);
    windowManager.addView(button, layoutParams);
 
    button.setOnTouchListener(new FloatingOnTouchListener());
   }
  } else {
   button = new Button(getApplicationContext());
   button.setText("我是個button窗口");
   button.setBackgroundColor(Color.BLUE);
   windowManager.addView(button, layoutParams);
 
   button.setOnTouchListener(new FloatingOnTouchListener());
  }
 }
 
 private class FloatingOnTouchListener implements View.OnTouchListener {
  private int x;
  private int y;
 
  @Override
  public boolean onTouch(View view, MotionEvent event) {
   switch (event.getAction()) {
    case MotionEvent.ACTION_DOWN:
     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;
    default:
     break;
   }
   return false;
  }
 }

思路簡單解釋:首先獲取WindowManager服務(wù),然后定義并設(shè)置在window上顯示的layoutParams(此處需注意Android 8.0以上版本中LayoutParam里的type變量變?yōu)門YPE_APPLICATION_OVERLAY與Android 8.0以下版本LayoutParam里的type變量TYPE_PHONE不一樣,需要通過判斷系統(tǒng)版本進行區(qū)分),然后定義并設(shè)置在layoutParams上面顯示的Button按鈕以及監(jiān)聽事件(此處的監(jiān)聽事件主要是懸浮窗口拖動的監(jiān)聽)最后將設(shè)置好的button與layoutParams添加入window中

4、AndroidManifest.xml中權(quán)限添加

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

5、效果圖

Android如何實現(xiàn)懸浮窗全系統(tǒng)版本

以上是“Android如何實現(xiàn)懸浮窗全系統(tǒng)版本”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標題名稱:Android如何實現(xiàn)懸浮窗全系統(tǒng)版本
標題來源:http://muchs.cn/article32/ghegsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、標簽優(yōu)化、全網(wǎng)營銷推廣、商城網(wǎng)站、響應(yīng)式網(wǎng)站企業(yè)網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計