返回顶部
首页 > 资讯 > 移动开发 >Android实现带磁性的悬浮窗体效果
  • 718
分享到

Android实现带磁性的悬浮窗体效果

窗体Android 2022-06-06 08:06:29 718人浏览 薄情痞子
摘要

本文实例讲述了Android实现带磁性的悬浮窗体效果。分享给大家供大家参考,具体如下: 带磁性的悬浮窗体,类似于360绿色小人 主要实现的是: 1.悬浮所有窗体之上 2.有吸引

本文实例讲述了Android实现带磁性的悬浮窗体效果。分享给大家供大家参考,具体如下:

带磁性的悬浮窗体,类似于360绿色小人

主要实现的是:

1.悬浮所有窗体之上
2.有吸引力,吸附于屏幕边上
3.有点击效果

下面我就实现上面三点,简单封装了个FloatView

先看下本次Demo的效果图,然后再看代码,

效果图

FloatView代码如下


package com.manymore13.flowwindowdemo;
import android.content.Context;
import android.graphics.PixelFORMat;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.util.Log;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.WindowManager;
import android.view.WindowManager.LayoutParams;
import android.widget.ImageView;

public class FloatView extends ImageView{
  private float mTouchX;
  private float mTouchY;
  private float x;
  private float y;
  private int startX;
  private int startY;
  private Context c;
  private int imgId = R.drawable.ic_launcher;
  private int controlledSpace = 20;
  private int screenWidth;
  boolean isshow = false;
  private OnClickListener mClickListener;
  private WindowManager windowManager ;
  private WindowManager.LayoutParams windowManagerParams = new WindowManager.LayoutParams();
  public FloatView(Context context, AttributeSet attrs) {
    super(context, attrs);
  }
  public FloatView(Context c)
  {
    super(c);
    initView(c);
  }
  // 初始化窗体
  public void initView(Context c)
  {
    windowManager = (WindowManager) c.getApplicationContext().getSystemService(Context.WINDOW_SERVICE);
    screenWidth = windowManager.getDefaultDisplay().getWidth();
    this.setImageResource(imgId);
    windowManagerParams.type = LayoutParams.TYPE_PHONE;
    windowManagerParams.format = PixelFormat.RGBA_8888; // 背景透明
    windowManagerParams.flags = LayoutParams.FLAG_NOT_TOUCH_MODAL
        | LayoutParams.FLAG_NOT_FOCUSABLE;
    // 调整悬浮窗口至左上角,便于调整坐标
    windowManagerParams.gravity = Gravity.LEFT | Gravity.TOP;
    // 以屏幕左上角为原点,设置x、y初始值
    windowManagerParams.x = 0;
    windowManagerParams.y = 200;
    // 设置悬浮窗口长宽数据
    windowManagerParams.width = LayoutParams.WRAP_CONTENT;
    windowManagerParams.height = LayoutParams.WRAP_CONTENT;
  }
  public void setImgResource(int id)
  {
    imgId = id;
  }
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    x = event.getRawX();
    y = event.getRawY();
    switch(event.getAction())
    {
      case MotionEvent.ACTION_DOWN:
      {
        mTouchX = event.getX();
        mTouchY = event.getY();
        startX = (int) event.getRawX();
        startY = (int) event.getRawY();
        break;
      }
      case MotionEvent.ACTION_MOVE:
      {
        updateViewPosition();
        break;
      }
      case MotionEvent.ACTION_UP:
      {
        if(Math.abs(x - startX) < controlledSpace && Math.abs(y - startY) < controlledSpace)
        {
          if(mClickListener != null)
          {
            mClickListener.onClick(this);
          }
        }
        Log.i("tag", "x="+x+" startX+"+startX+" y="+y+" startY="+startY);
        if(x <= screenWidth/2)
        {
          x = 0;
        }else{
          x = screenWidth;
        }
        updateViewPosition();
        break;
      }
    }
    return super.onTouchEvent(event);
  }
  // 隐藏该窗体
  public void hide()
  {
    if(isShow)
    {
      windowManager.removeView(this);
      isShow = false;
    }
  }
  // 显示该窗体
  public void show()
  {
    if(isShow == false)
    {
      windowManager.addView(this, windowManagerParams);
      isShow = true;
    }
  }
  @Override
  public void setOnClickListener(OnClickListener l) {
     this.mClickListener = l;
  }
  private void updateViewPosition() {
     // 更新浮动窗口位置参数
     windowManagerParams.x = (int) (x - mTouchX);
     windowManagerParams.y = (int) (y - mTouchY);
     windowManager.updateViewLayout(this, windowManagerParams); // 刷新显示
  }
}

完整实例代码点击此处本站下载

如果需要用上面的类可以这样做


floatView = new FloatView(this); // 创建窗体
floatView.setOnClickListener(this); // 设置事件,你需要实现FloatView里的onclick接口
floatView.show(); // 显示该窗体
floatView.hide(); // 隐藏窗体

PS 不要忘记在manifest里加上权限(更多manifest功能与权限可参考本站:Android Manifest功能与权限描述大全Http://tools.jb51.net/table/AndroidManifest)

上面有个bug 就是点击的时候view下移


public int getStatusBarHeight() {
    int titleBarHeight = 0;
    Rect frame = new Rect();
    Mact.getWindow().getDecorView().getWindowVisibleDisplayFrame(frame);
    titleBarHeight = frame.top;
    if (titleBarHeight == 0) {
      int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");
      if (resourceId > 0) {
        titleBarHeight = getResources().getDimensionPixelSize(resourceId);
      }
    }
    return titleBarHeight;
}

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android编程之activity操作技巧总结》、《Android资源操作技巧汇总》、《Android文件操作技巧汇总》、《Android操作sqlite数据库技巧总结》、《Android操作JSON格式数据技巧总结》、《Android数据库操作技巧总结》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:android编程实现悬浮窗体的方法Android实现悬浮窗体效果


--结束END--

本文标题: Android实现带磁性的悬浮窗体效果

本文链接: https://lsjlt.com/news/24715.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android实现带磁性的悬浮窗体效果
    本文实例讲述了Android实现带磁性的悬浮窗体效果。分享给大家供大家参考,具体如下: 带磁性的悬浮窗体,类似于360绿色小人 主要实现的是: 1.悬浮所有窗体之上 2.有吸引...
    99+
    2022-06-06
    窗体 Android
  • Android实现悬浮窗效果
    本文实例为大家分享了Android实现悬浮窗效果的具体代码,供大家参考,具体内容如下 一、权限: <uses-permission android:name="android....
    99+
    2024-04-02
  • Android悬浮窗效果怎么实现
    要实现Android的悬浮窗效果,可以采用以下几种方法: 使用系统提供的WindowManager类来创建一个悬浮窗口。可以通过...
    99+
    2023-10-22
    Android
  • Android仿腾讯视频实现悬浮窗效果
    前言 相信大家对Android悬浮窗应该是很熟悉了,比如说腾讯视频、爱奇艺等APP都有悬浮窗功能。在你打游戏的同时还可以看视频,充分利用屏幕空间。还有微信,360手机卫士等APP也有...
    99+
    2024-04-02
  • iOS实现应用悬浮窗效果
    本文实例为大家分享了iOS实现应用悬浮窗效果的具体代码,供大家参考,具体内容如下 需求 在一个app应用的最顶部添加一个悬浮窗,就像ios系统AssistiveTouch 可以左右滑...
    99+
    2022-05-24
    iOS 悬浮窗
  • js如何实现悬浮窗效果
    小编给大家分享一下js如何实现悬浮窗效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果图:代码如下:<!DOCTYPE...
    99+
    2024-04-02
  • android编程实现悬浮窗体的方法
    本文实例讲述了android编程实现悬浮窗体的方法。分享给大家供大家参考,具体如下: 突然对悬浮窗体感兴趣,查资料做了个小Demo,效果是点击按钮后,关闭当前Activity,...
    99+
    2022-06-06
    方法 窗体 Android
  • Android仿IOS系统悬浮窗效果
    在一些场合里,我们使用悬浮窗会有很大的便利,比如IOS系统的悬浮窗,360或者其他手机卫士的悬浮窗等等。 本篇博客,我们创造出两个悬浮窗,通过点击小悬浮窗打开或者关闭大悬浮窗(一个播...
    99+
    2024-04-02
  • Android实现顶部悬浮效果
    本文实例为大家分享了Android实现顶部悬浮效果的具体代码,供大家参考,具体内容如下效果图 布局<?xml version="1.0" encoding="utf-8"?><android.su...
    99+
    2023-05-30
    android 顶部悬浮 roi
  • Android实现桌面悬浮窗、蒙板效果实例代码
    现在很多安全类的软件,比如360手机助手,百度手机助手等等,都有一个悬浮窗,可以飘浮在桌面上,方便用户使用一些常用的操作。 今天这篇文章,就是介绍如何实现桌面悬浮窗效果的。 首...
    99+
    2022-06-06
    Android
  • Android悬浮窗如何实现
    小编给大家分享一下Android悬浮窗如何实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果如下:显示浮窗原生ViewManager接口提供了向窗口添加并操纵...
    99+
    2023-06-04
  • vue实现悬浮球效果
    本文实例为大家分享了vue实现悬浮球效果的具体代码,供大家参考,具体内容如下 小球效果 小球移动效果图源码 <template>   <transition>...
    99+
    2024-04-02
  • Android RecyclerView打造悬浮效果的实现代码
    本文介绍了Android RecyclerView悬浮效果,分享给大家,具体如下:先看个效果这是一个City列表,每个City都有所属的Province,需要在滑动的时候,将对应的Province悬浮在顶部。悬浮顶部的Province需要根...
    99+
    2023-05-30
    android recyclerview 悬浮
  • Android实现圆形菜单悬浮窗
    序言 Android悬浮窗的实现,主要有四个步骤: 1. 声明及申请权限2. 构建悬浮窗需要的控件3. 将控件添加到WindowManager4. 必要时更新WindowManage...
    99+
    2024-04-02
  • Flutter实现Android滚动悬浮效果过程
    目录1、计算每个区块的高度2、实现分析-tabBar透明度渐变3、实现分析-app上下滚动触发tabBar4、实现分析-tabBar切换触发app滚动5、源码有以下几种效果 1、ta...
    99+
    2023-01-29
    Flutter滚动悬浮 Flutter滚动悬浮效果
  • Android 实现控件悬浮效果实例代码
    随着移动互联网的快速发展,它已经和我们的生活息息相关了,在公交地铁里面都能看到很多人的人低头看着自己的手机屏幕,从此“低头族”一词就产生了,作为一名移动行业的开发人员,我自己也...
    99+
    2022-06-06
    Android
  • RecyclerVIew实现悬浮吸顶效果
    RecyclerVIew实现悬浮吸顶效果图 这里写图片描述主页面布局<?xml version="1.0" encoding="utf-8"?><FrameLayout xmlns:android="htt...
    99+
    2023-05-30
    recyclerview 悬浮吸顶 recycle
  • Android利用悬浮按钮实现翻页效果
    今天给大家分享下自己用悬浮按钮点击实现翻页效果的例子。 首先,一个按钮要实现悬浮,就要用到系统顶级窗口相关的WindowManager,WindowManager.Layout...
    99+
    2022-06-06
    按钮 Android
  • Kotlin如何实现Android系统悬浮窗
    本篇内容介绍了“Kotlin如何实现Android系统悬浮窗”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Android 弹窗浅谈我们知道 ...
    99+
    2023-06-22
  • Android WindowManger实现桌面悬浮窗功能
    目录效果图使用WindowManager实现分析问题参考如果想实现一个在桌面显示的悬浮窗,用Dialog、PopupWindow、Toast等已经不能实现了,他们基本都是在Activ...
    99+
    2023-05-18
    Android桌面悬浮窗 Android WindowManger悬浮窗
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作