时间:2021-05-20
本文实例为大家分享了Android实现触摸移动的悬浮窗的具体代码,供大家参考,具体内容如下
1.触摸移动的悬浮窗的快速实现 UI
2. 悬浮窗实现
2.1 悬浮窗权限
为了偷懒,我SDK选择比较低的17,如果不配置权限,则应用会运行报错
正规流程,查询是否有悬浮窗权限,如果没有需要提示,并跳转到悬浮窗设置界面“即是否允许运行在其他应用上面”
<uses-sdk android:minSdkVersion="17" android:targetSdkVersion="17" /><uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />2.2 悬浮窗配置初始化
这里主要关注 mParams.type 和 mParams.flags 这两个参数是核心,我们也可以使用View来加载一个布局,为了侧重悬浮窗界面,我直接使用TextView演示
private void initFloatWindow() { if (mShow == null) { mWm = (WindowManager) getSystemService(Context.WINDOW_SERVICE); mShow = new TextView(this); mShow.setText("I Love You"); mShow.setTextColor(Color.RED); mShow.setTextSize(50); mShow.setOnTouchListener(new View.OnTouchListener() { int lastX = 0; int lastY = 0; int paramX = 0; int paramY = 0; @Override public boolean onTouch(View view, MotionEvent motionEvent) { switch (motionEvent.getAction()) { case MotionEvent.ACTION_DOWN: lastX = (int) motionEvent.getRawX(); lastY = (int) motionEvent.getRawY(); paramX = mParams.x; paramY = mParams.y; break; case MotionEvent.ACTION_MOVE: int dx = (int) motionEvent.getRawX() - lastX; int dy = (int) motionEvent.getRawY() - lastY; mParams.x = paramX + dx; mParams.y = paramY + dy; mWm.updateViewLayout(mShow, mParams); break; } return true; } }); mParams = new WindowManager.LayoutParams(); mParams.width = WindowManager.LayoutParams.WRAP_CONTENT; mParams.height = WindowManager.LayoutParams.WRAP_CONTENT; mParams.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT; // 实现悬浮窗可以移动的属性 mParams.flags = WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL | WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE; mParams.format = PixelFormat.TRANSPARENT; } }2.3 悬浮窗显示
mWm.addView(mShow, mParams);2.4 悬浮窗隐藏
mWm.removeView(mShow);2.5 完整示例代码
package com.wu.sufadi;import android.app.Activity;import android.content.Context;import android.graphics.Color;import android.graphics.PixelFormat;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.view.LayoutInflater;import android.view.MotionEvent;import android.view.View;import android.view.WindowManager;import android.widget.TextView;public class MainActivity extends Activity { private TextView mShow; private WindowManager mWm; private WindowManager.LayoutParams mParams; private static final int MSG_SHOW_WINDOW = 1; private static final int MSG_HIDE_WINDOW = 2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initFloatWindow(); } public void click_show(View view) { showFloatWindow(); } public void click_hide(View view) { hideFloatWindow(); } Handler handler = new Handler() { @Override public void handleMessage(Message msg) { super.handleMessage(msg); switch (msg.what) { case MSG_SHOW_WINDOW: mWm.addView(mShow, mParams); break; case MSG_HIDE_WINDOW: mWm.removeView(mShow); break; default: break; } } }; private void showFloatWindow() { handler.sendEmptyMessage(MSG_SHOW_WINDOW); } private void hideFloatWindow() { handler.sendEmptyMessage(MSG_HIDE_WINDOW); } private void initFloatWindow() { if (mShow == null) { mWm = (WindowManager) getSystemService(Context.WINDOW_SERVICE); mShow = new TextView(this); mShow.setText("I Love You"); mShow.setTextColor(Color.RED); mShow.setTextSize(50); mShow.setOnTouchListener(new View.OnTouchListener() { int lastX = 0; int lastY = 0; int paramX = 0; int paramY = 0; @Override public boolean onTouch(View view, MotionEvent motionEvent) { switch (motionEvent.getAction()) { case MotionEvent.ACTION_DOWN: lastX = (int) motionEvent.getRawX(); lastY = (int) motionEvent.getRawY(); paramX = mParams.x; paramY = mParams.y; break; case MotionEvent.ACTION_MOVE: int dx = (int) motionEvent.getRawX() - lastX; int dy = (int) motionEvent.getRawY() - lastY; mParams.x = paramX + dx; mParams.y = paramY + dy; mWm.updateViewLayout(mShow, mParams); break; } return true; } }); mParams = new WindowManager.LayoutParams(); mParams.width = WindowManager.LayoutParams.WRAP_CONTENT; mParams.height = WindowManager.LayoutParams.WRAP_CONTENT; mParams.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT; // 实现悬浮窗可以移动的属性 mParams.flags = WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL | WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE; mParams.format = PixelFormat.TRANSPARENT; } }}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Android编程实现悬浮窗获取并显示当前内存使用量的方法。分享给大家供大家参考,具体如下:运行效果:其中:这一块就是悬浮窗,可以随意拖动,动态显
现在很多应用都会用到悬浮窗,很多国产rom把悬浮窗权限加入控制了,你就需要判断是否有悬浮窗权限,然后做对应操作。Android原生有自带权限管理的,只是被隐藏了
悬浮窗是电脑或智能手机的系统工具,在其他应用的表面悬浮一可移动的窗口,以便打开不同应用,手机使用悬浮窗需要系统授权。 悬浮窗,可以及时提醒内存占用较高状态,点
vue移动端实现div拖拽移动,供大家参考,具体内容如下本文讲述,在使用VUE的移动端实现类似于iPhone的悬浮窗的效果。相关知识点touchstart当在屏
以苹果iOS移动端为例,苹果iOS移动端仅支持在钉钉程序内悬浮窗小窗观看直播,不支持在退出钉钉后的悬浮窗观看。所以说无法设置在其它应用上同时显示。 钉钉(Di