91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android實現懸浮窗體效果

發布時間:2020-10-24 05:34:59 來源:腳本之家 閱讀:223 作者:葉超Luka 欄目:移動開發

突然對懸浮窗體感興趣,查資料做了個小Demo,效果是點擊按鈕后,關閉當前Activity,顯示懸浮窗口,窗口可以拖動,雙擊后消失。效果圖如下:

Android實現懸浮窗體效果

它的使用原理很簡單,就是借用了WindowManager這個管理類來實現的。

1.首先在AndroidManifest.xml中添加使用權限:

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

2.懸浮窗口布局實現

public class DesktopLayout extends LinearLayout {

 public DesktopLayout(Context context) {
  super(context);
  setOrientation(LinearLayout.VERTICAL);// 水平排列
  

  //設置寬高
  this.setLayoutParams( new LayoutParams(LayoutParams.WRAP_CONTENT,
    LayoutParams.WRAP_CONTENT));
  
  View view = LayoutInflater.from(context).inflate( 
    R.layout.desklayout, null); 
  this.addView(view);
 }

3.在activity中讓它顯示出來。

// 取得系統窗體
 mWindowManager = (WindowManager) getApplicationContext()
    .getSystemService("window");

// 窗體的布局樣式
 mLayout = new WindowManager.LayoutParams();

// 設置窗體顯示類型——TYPE_SYSTEM_ALERT(系統提示)
 mLayout.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;

// 設置窗體焦點及觸摸:
// FLAG_NOT_FOCUSABLE(不能獲得按鍵輸入焦點)
 mLayout.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;

// 設置顯示的模式
  mLayout.format = PixelFormat.RGBA_8888;

// 設置對齊的方法
  mLayout.gravity = Gravity.TOP | Gravity.LEFT;

// 設置窗體寬度和高度
  mLayout.width = WindowManager.LayoutParams.WRAP_CONTENT;
  mLayout.height = WindowManager.LayoutParams.WRAP_CONTENT;

詳細 MainActivity 代碼如下:

package com.yc.yc_suspendingform;

import android.app.Activity;
import android.graphics.PixelFormat;
import android.graphics.Rect;
import android.os.Bundle;
import android.util.Log;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.WindowManager;
import android.widget.Button;
import com.yc.yc_floatingform.R;

public class MainActivity extends Activity {
 private WindowManager mWindowManager;
 private WindowManager.LayoutParams mLayout;
 private DesktopLayout mDesktopLayout;
 private long startTime;
 // 聲明屏幕的寬高
 float x, y;
 int top;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);  
  createWindowManager();
  createDesktopLayout();
  Button btn = (Button) findViewById(R.id.btn);
  btn.setOnClickListener(new OnClickListener() {
   public void onClick(View v) {
    showDesk();
   }
  });
 }
 /**
  * 創建懸浮窗體
  */
 private void createDesktopLayout() {
  mDesktopLayout = new DesktopLayout(this);
  mDesktopLayout.setOnTouchListener(new OnTouchListener() {
   float mTouchStartX;
   float mTouchStartY;

   @Override
   public boolean onTouch(View v, MotionEvent event) {
    // 獲取相對屏幕的坐標,即以屏幕左上角為原點
    x = event.getRawX();
    y = event.getRawY() - top; // 25是系統狀態欄的高度
    Log.i("startP", "startX" + mTouchStartX + "====startY"
      + mTouchStartY);
    switch (event.getAction()) {
    case MotionEvent.ACTION_DOWN:
     // 獲取相對View的坐標,即以此View左上角為原點
     mTouchStartX = event.getX();
     mTouchStartY = event.getY();
     Log.i("startP", "startX" + mTouchStartX + "====startY"
       + mTouchStartY);
     long end = System.currentTimeMillis() - startTime;
     // 雙擊的間隔在 300ms以下
     if (end < 300) {
      closeDesk();
     }
     startTime = System.currentTimeMillis();
     break;
    case MotionEvent.ACTION_MOVE:
     // 更新浮動窗口位置參數
     mLayout.x = (int) (x - mTouchStartX);
     mLayout.y = (int) (y - mTouchStartY);
     mWindowManager.updateViewLayout(v, mLayout);
     break;
    case MotionEvent.ACTION_UP:

     // 更新浮動窗口位置參數
     mLayout.x = (int) (x - mTouchStartX);
     mLayout.y = (int) (y - mTouchStartY);
     mWindowManager.updateViewLayout(v, mLayout);

     // 可以在此記錄最后一次的位置

     mTouchStartX = mTouchStartY = 0;
     break;
    }
    return true;
   }
  });
 }

 @Override
 public void onWindowFocusChanged(boolean hasFocus) {
  super.onWindowFocusChanged(hasFocus);
  Rect rect = new Rect();
  // /取得整個視圖部分,注意,如果你要設置標題樣式,這個必須出現在標題樣式之后,否則會出錯
  getWindow().getDecorView().getWindowVisibleDisplayFrame(rect);
  top = rect.top;//狀態欄的高度,所以rect.height,rect.width分別是系統的高度的寬度

  Log.i("top",""+top);
 }

 /**
  * 顯示DesktopLayout
  */
 private void showDesk() {
  mWindowManager.addView(mDesktopLayout, mLayout);
  finish();
 }

 /**
  * 關閉DesktopLayout
  */
 private void closeDesk() {
  mWindowManager.removeView(mDesktopLayout);
  finish();
 }

 /**
  * 設置WindowManager
  */
 private void createWindowManager() {
  // 取得系統窗體
  mWindowManager = (WindowManager) getApplicationContext()
    .getSystemService("window");

  // 窗體的布局樣式
  mLayout = new WindowManager.LayoutParams();

  // 設置窗體顯示類型——TYPE_SYSTEM_ALERT(系統提示)
  mLayout.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;

  // 設置窗體焦點及觸摸:
  // FLAG_NOT_FOCUSABLE(不能獲得按鍵輸入焦點)
  mLayout.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;

  // 設置顯示的模式
  mLayout.format = PixelFormat.RGBA_8888;

  // 設置對齊的方法
  mLayout.gravity = Gravity.TOP | Gravity.LEFT;

  // 設置窗體寬度和高度
  mLayout.width = WindowManager.LayoutParams.WRAP_CONTENT;
  mLayout.height = WindowManager.LayoutParams.WRAP_CONTENT;

 }

}

 源代碼地址:Android實現懸浮窗體效果

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

延川县| 富裕县| 九寨沟县| 金山区| 蓬莱市| 合肥市| 台山市| 陆川县| 封丘县| 虎林市| 鄂托克旗| 乌拉特后旗| 偏关县| 灌阳县| 呼伦贝尔市| 乌海市| 隆子县| 卢龙县| 光山县| 张家川| 文登市| 正安县| 探索| 岫岩| 青冈县| 烟台市| 贵溪市| 彭山县| 潮安县| 荣昌县| 筠连县| 云南省| 当雄县| 贵州省| 宜阳县| 寿光市| 温州市| 吉木萨尔县| 和顺县| 礼泉县| 罗源县|