中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

Android可拖動懸浮窗如何實現

小億
236
2024-01-26 11:57:17
欄目: 編程語言

實現 Android 可拖動懸浮窗的步驟如下:

  1. 創建一個布局文件,用于顯示懸浮窗的界面。
  2. 創建一個 Service,用于啟動懸浮窗并處理拖動事件。
  3. 在 Service 中,使用 WindowManager.LayoutParams 類來設置懸浮窗的屬性,例如寬高、位置、類型等。
  4. 在 Service 的 onStartCommand() 方法中,使用 WindowManager.addView() 方法將懸浮窗添加到窗口中。
  5. 在布局文件中,使用觸摸事件監聽用戶的手勢操作,例如 ACTION_DOWN、ACTION_MOVE、ACTION_UP 等。
  6. 在觸摸事件的回調方法中,根據用戶手勢的變化,更新懸浮窗的位置。可以使用 WindowManager.updateViewLayout() 方法來更新懸浮窗的位置。
  7. 在 Service 的 onDestroy() 方法中,使用 WindowManager.removeView() 方法將懸浮窗從窗口中移除。

下面是一個簡單的示例代碼,用于實現可拖動的懸浮窗:

  1. 創建一個布局文件 float_window.xml,用于顯示懸浮窗的界面:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@android:color/white"
    android:orientation="vertical">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Floating Window" />

</LinearLayout>
  1. 創建一個 Service 類 FloatWindowService,用于啟動懸浮窗并處理拖動事件:
public class FloatWindowService extends Service implements View.OnTouchListener {

    private WindowManager windowManager;
    private WindowManager.LayoutParams layoutParams;

    private int initialX;
    private int initialY;
    private float initialTouchX;
    private float initialTouchY;

    @Override
    public void onCreate() {
        super.onCreate();

        // 創建懸浮窗的布局參數
        layoutParams = new WindowManager.LayoutParams(
                WindowManager.LayoutParams.WRAP_CONTENT,
                WindowManager.LayoutParams.WRAP_CONTENT,
                WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY,
                WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE,
                PixelFormat.TRANSLUCENT);

        // 創建窗口管理器
        windowManager = (WindowManager) getSystemService(WINDOW_SERVICE);
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        // 創建懸浮窗的視圖
        LinearLayout floatLayout = (LinearLayout) LayoutInflater.from(this).inflate(R.layout.float_window, null);
        floatLayout.setOnTouchListener(this);

        // 將懸浮窗添加到窗口中
        windowManager.addView(floatLayout, layoutParams);

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

    @Override
    public void onDestroy() {
        super.onDestroy();

        // 將懸浮窗從窗口中移除
        if (windowManager != null) {
            windowManager.removeView(floatLayout);
        }
    }

    @Override
    public boolean onTouch(View view, MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                // 記錄懸浮窗的初始位置
                initialX = layoutParams.x;
                initialY = layoutParams.y;
                initialTouchX = event.getRawX();
                initialTouchY = event.getRawY();
                return true;
            case MotionEvent.ACTION_MOVE:
                // 更新懸浮窗的位置
                layoutParams.x = initialX + (int) (event.getRawX() - initialTouchX);
                layoutParams.y = initialY + (int) (event.getRawY() - initialTouchY);
                windowManager.updateViewLayout(view, layoutParams);
                return true;
            case MotionEvent.ACTION_UP:
                // 手指抬起時不處理事件
                return true;
        }
        return false;
    }

    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }
}
  1. 在 AndroidManifest.xml 文件中注冊 FloatWindowService:
<service
    android:name=".FloatWindowService"
    android:enabled="true"
    android:exported="false" />
  1. 在需要啟動懸浮窗的地方,使用 startService() 方法啟動 FloatWindowService:
startService(new Intent(MainActivity.this, FloatWindowService.class));

這樣就實現了一個簡單的

0
南投市| 齐齐哈尔市| 淄博市| 华亭县| 东乌珠穆沁旗| 诏安县| 南阳市| 日照市| 宜阳县| 沈丘县| 泰安市| 高阳县| 凌云县| 文化| 都昌县| 米易县| 安新县| 双城市| 怀化市| 天全县| 尼木县| 紫云| 呼图壁县| 松江区| 科尔| 甘泉县| 灵石县| 安国市| 恭城| 凤冈县| 岳阳市| 济阳县| 德惠市| 厦门市| 广平县| 康乐县| 休宁县| 紫阳县| 巴中市| 惠东县| 临潭县|