首页 > 系统 > Android > 正文

Android使用WindowManager构造悬浮view

2019-12-12 06:18:28
字体:
来源:转载
供稿:网友

一般在android显示一个View都是通过Activity的setContentView设置的,但是还有一种方法,可以直接使用WindowManager在整个应用的最上层绘制我们需要显示的view,总体的效果类似于AlertDialog的弹出效果。

使用WindowManager构造这样的一个悬浮View也比较简单,直接通过windowmanager.addView()方法即可。

package com.gearmotion.app.windowmanagermotion;import android.content.Context;import android.graphics.PixelFormat;import android.graphics.Rect;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.Gravity;import android.view.LayoutInflater;import android.view.MotionEvent;import android.view.View;import android.view.ViewGroup;import android.view.WindowManager;import android.widget.Button;public class MainActivity extends AppCompatActivity implements View.OnClickListener, View.OnTouchListener { Button mShowBtn; Button mHideBtn; WindowManager mWm; LayoutInflater mLayoutInflater; View mWindowView; @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_main);  mShowBtn = (Button) this.findViewById(R.id.showbtn);  mHideBtn = (Button) this.findViewById(R.id.hidebtn);  mShowBtn.setOnClickListener(this);  mHideBtn.setOnClickListener(this);  init(); } private void init() {  mWm = (WindowManager) this.getApplicationContext().getSystemService(Context.WINDOW_SERVICE);  mLayoutInflater = LayoutInflater.from(this); } @Override public void onClick(View v) {  if (mShowBtn.hashCode() == v.hashCode()) { //显示WindowManager   show();  }  if (mHideBtn.hashCode() == v.hashCode()) { //隐藏windowmanager   hide();  } } private void show() {  mWindowView = mLayoutInflater.inflate(R.layout.item_layout, null);  View popView = mWindowView.findViewById(R.id.root);  //设置popView的触摸事件,以便点击空白区域的时候使悬浮view消失  popView.setOnTouchListener(this);  WindowManager.LayoutParams lp = new WindowManager.LayoutParams();  //窗口类型同系统弹出框  lp.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;  //响应输入法  //lp.flags = WindowManager.LayoutParams.FLAG_ALT_FOCUSABLE_IM;  //透明层  lp.format = PixelFormat.TRANSPARENT;  lp.width = WindowManager.LayoutParams.MATCH_PARENT;  lp.height = WindowManager.LayoutParams.MATCH_PARENT;  lp.gravity = Gravity.CENTER_VERTICAL;  mWm.addView(mWindowView, lp); } private void hide() {  if (mWindowView != null && mWindowView.getParent() != null) {   mWm.removeView(mWindowView);  } } @Override public boolean onTouch(View v, MotionEvent event) {  int x = (int) event.getX();  int y = (int) event.getY();  //获取主view的可视区域  Rect globalRect = new Rect();  //获取悬浮view的可视区域  Rect tmpRect = new Rect();  v.getGlobalVisibleRect(globalRect);  View child = ((ViewGroup) v).getChildAt(0);  child.getHitRect(tmpRect);  if (!tmpRect.contains(x, y) && globalRect.contains(x, y)) {   hide();  }  return true; }}

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=".MainActivity"> <Button  android:id="@+id/showbtn"  android:layout_width="match_parent"  android:layout_height="50dp"  android:gravity="center"  android:text="show" /> <Button  android:id="@+id/hidebtn"  android:layout_width="match_parent"  android:layout_height="50dp"  android:gravity="center"  android:text="hide" /></LinearLayout>

item_layout.xml:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:id="@+id/root" android:orientation="vertical"> <TextView  android:layout_width="match_parent"  android:layout_height="50dp"  android:text="I am WindowManager layout view"  android:textSize="20sp"  android:gravity="center"  android:layout_gravity="center"  android:background="#FFF8DC"  android:textColor="#7AC5CD"/></LinearLayout>

实现效果如下:

以上就是本文的全部内容,希望对大家学习Android有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表