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

溫馨提示×

溫馨提示×

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

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

Android中怎么實現微信視屏懸浮窗效果

發布時間:2021-08-11 13:49:56 來源:億速云 閱讀:539 作者:Leah 欄目:編程語言

今天就跟大家聊聊有關Android中怎么實現微信視屏懸浮窗效果,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

1.懸浮窗效果:點擊縮小按鈕,將當前遠端視屏加載進懸浮窗,且懸浮窗可拖拽,不影響其他界面焦點;點擊懸浮窗可返回原來的Activity

2.實現懸浮窗需要:

在androidManifest中申請懸浮窗權限<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>

在androidManifest中注冊FloatWindowService

3.視屏activity實現:

-將activity置于后臺關鍵代碼:moveTaskToBack(true);//將activity置于后臺-開啟懸浮窗

/**   * 定義服務綁定的回調 開啟視頻通話服務連接   */  private ServiceConnection mVideoCallServiceConnection = new ServiceConnection() {    @Override    public void onServiceConnected(ComponentName name, IBinder service) {      // 獲取服務的操作對象      FloatWindowService.MyBinder binder = (FloatWindowService.MyBinder) service;      binder.getService();    }    @Override    public void onServiceDisconnected(ComponentName name) {    }  };/*   * 開啟懸浮Video服務   */  private void startVideoService() {    //最小化Activity    moveTaskToBack(true);//將activity置于后臺    //開啟服務顯示懸浮框    Intent serviceVideoIntent = new Intent(this, FloatWindowService.class);    mServiceBound = bindService(serviceVideoIntent, mVideoCallServiceConnection, Context.BIND_AUTO_CREATE);//綁定Service  }

-懸浮窗結束時

//在onDestroy()與onReStart()中解綁并銷毀相關內容if (mServiceBound) {      unbindService(mVideoCallServiceConnection);//解綁      mServiceBound = false;    }

4.懸浮窗實現相關代碼:

/** * 視頻懸浮窗服務 */public class FloatWindowService extends Service implements View.OnTouchListener {  private WindowManager mWindowManager;  private WindowManager.LayoutParams wmParams;  private LayoutInflater inflater;  //浮動布局view  private View mFloatingLayout;  //容器父布局  private View mMainVIew;   //開始觸控的坐標,移動時的坐標(相對于屏幕左上角的坐標)  private int mTouchStartX, mTouchStartY, mTouchCurrentX, mTouchCurrentY;  //開始時的坐標和結束時的坐標(相對于自身控件的坐標)  private int mStartX, mStartY, mStopX, mStopY;  //判斷懸浮窗口是否移動,這里做個標記,防止移動后松手觸發了點擊事件  private boolean isMove;    @Override  public void onCreate() {    super.onCreate();    initWindow();//設置懸浮窗基本參數(位置、寬高等)   }   @Nullable  @Override  public IBinder onBind(Intent intent) {    currentBigUserId = intent.getStringExtra("localUserId");    remoteUserId = intent.getStringExtra("remoteUserId");    initFloating();//懸浮框點擊事件的處理    return new MyBinder();  }   public class MyBinder extends Binder {    public FloatWindowService getService() {      return FloatWindowService.this;    }  }    @Override  public int onStartCommand(Intent intent, int flags, int startId) {    return super.onStartCommand(intent, flags, startId);  }   @Override  public void onDestroy() {    super.onDestroy();    if (mFloatingLayout != null) {      // 移除懸浮窗口      mWindowManager.removeView(mFloatingLayout);      mFloatingLayout = null;    }  }   /**   * 設置懸浮框基本參數(位置、寬高等)   */  private void initWindow() {    mWindowManager = (WindowManager) getApplicationContext().getSystemService(Context.WINDOW_SERVICE);    //設置好懸浮窗的參數    wmParams = getParams();    // 懸浮窗默認顯示以左上角為起始坐標    wmParams.gravity = Gravity.RIGHT | Gravity.TOP;    //懸浮窗的開始位置,因為設置的是從右上角開始,所以屏幕左上角是x=屏幕最大值;y=0    wmParams.x = 10;    wmParams.y = 120;    //得到容器,通過這個inflater來獲得懸浮窗控件    inflater = LayoutInflater.from(getApplicationContext());    // 獲取浮動窗口視圖所在布局    mFloatingLayout = inflater.inflate(R.layout.dlg_floatview, null);    // 添加懸浮窗的視圖    mWindowManager.addView(mFloatingLayout, wmParams);  }    private WindowManager.LayoutParams getParams() {    wmParams = new WindowManager.LayoutParams();    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {      wmParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;    } else {      wmParams.type = WindowManager.LayoutParams.TYPE_PHONE;    }    //設置可以顯示在狀態欄上    wmParams.flags = WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE | WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL |        WindowManager.LayoutParams.FLAG_LAYOUT_IN_SCREEN | WindowManager.LayoutParams.FLAG_LAYOUT_INSET_DECOR |        WindowManager.LayoutParams.FLAG_WATCH_OUTSIDE_TOUCH;     //設置懸浮窗口長寬數據    wmParams.width = WindowManager.LayoutParams.WRAP_CONTENT;    wmParams.height = WindowManager.LayoutParams.WRAP_CONTENT;    return wmParams;  }   //加載遠端視屏:在這對懸浮窗內內容做操作  private void initFloating() {    //將子View加載進懸浮窗View    mMainView = mFloatingLayout.findViewById(R.id.trtc_video_view_layout_float);//懸浮窗父布局    View mChildView = renderView.getChildView();//加載進懸浮窗的子View,這個VIew來自天轉過來的那個Activity里面的那個需要加載的View    mMainView.addView(mChildView);//將需要懸浮顯示的Viewadd到mTXCloudVideoView中        //懸浮框觸摸事件,設置懸浮框可拖動    mTXCloudVideoView.setOnTouchListener(this::onTouch);    //懸浮框點擊事件    mTXCloudVideoView.setOnClickListener(new View.OnClickListener() {      @Override      public void onClick(View v) {        //在這里實現點擊重新回到Activity        Intent intent =         new Intent(FloatWindowService.this, RtcActivity.class);//從該service跳轉至該activity會將該activity從后臺喚醒,所以activity會走onReStart()        intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);//從Service跳轉至RTCActivity,需要Intent.FLAG_ACTIVITY_NEW_TASK,不然會崩潰        startActivity(intent);      }    });   }   //觸摸事件  @Override  public boolean onTouch(View v, MotionEvent event) {    int action = event.getAction();    switch (action) {      case MotionEvent.ACTION_DOWN:        isMove = false;        mTouchStartX = (int) event.getRawX();        mTouchStartY = (int) event.getRawY();        mStartX = (int) event.getX();        mStartY = (int) event.getY();        break;      case MotionEvent.ACTION_MOVE:        mTouchCurrentX = (int) event.getRawX();        mTouchCurrentY = (int) event.getRawY();        wmParams.x += mTouchStartX - mTouchCurrentX;        wmParams.y += mTouchCurrentY - mTouchStartY;        ALog.dTag("FloatingListener() onTouch",mTouchCurrentX,mTouchStartX,mTouchCurrentY,mTouchStartY);        mWindowManager.updateViewLayout(mFloatingLayout, wmParams);         mTouchStartX = mTouchCurrentX;        mTouchStartY = mTouchCurrentY;        break;      case MotionEvent.ACTION_UP:        mStopX = (int) event.getX();        mStopY = (int) event.getY();        if (Math.abs(mStartX - mStopX) >= 1 || Math.abs(mStartY - mStopY) >= 1) {          isMove = true;        }        break;      default:        break;    }    //如果是移動事件不觸發OnClick事件,防止移動的時候一放手形成點擊事件    return isMove;  } }

ps:使用Service做懸浮窗的載體是為了,將懸浮框的開啟關閉與服務Service的綁定解綁所關聯起來,開啟服務即相當于開啟我們的懸浮框,解綁服務則相當于關閉懸浮框,以此來達到更好的控制效果。

看完上述內容,你們對Android中怎么實現微信視屏懸浮窗效果有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

青冈县| 钟祥市| 北安市| 元谋县| 三穗县| 宿州市| 黄大仙区| 平乐县| 浑源县| 新化县| 大同县| 沅陵县| 五指山市| 云和县| 沂源县| 察隅县| 苏尼特左旗| 通江县| 化隆| 长寿区| 普定县| 延边| 蒲城县| 错那县| 武鸣县| 登封市| 遂昌县| 万年县| 齐齐哈尔市| 樟树市| 金湖县| 文水县| 门头沟区| 琼中| 河南省| 原阳县| 富蕴县| 富民县| 兴隆县| 丹巴县| 台中县|