模仿qq视频通话的悬浮按钮的实例代码,如下所示;
public class FloatingWindowService extends Service{
private static final String TAG="OnTouchListener";
private static View mView = null;
private static WindowManager mWindowManager = null;
private static Context mContext = null;
public static Boolean isShown = false;
public WindowManager.LayoutParams params = null;
private int pixel;
private int TheOffset;
@Override
public void onCreate() {
super.onCreate();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
pixel = intent.getIntExtra("pixel",1);
showPopupWindow(this);
return super.onStartCommand(intent, flags, startId);
}
/**
* 显示弹出框
*
* @param context
*
*/
private void showPopupWindow(final Context context) {
if (isShown) {
return;
}
isShown = true;
// 获取应用的Context
mContext = context.getApplicationContext();
// 获取WindowManager
mWindowManager = (WindowManager) mContext.getSystemService(Context.WINDOW_SERVICE);
params = new WindowManager.LayoutParams();
mView = setUpView(context);
// 类型
params.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;
int flags=WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;
params.flags = flags;
params.format = PixelFormat.TRANSLUCENT;
params.width = WindowManager.LayoutParams.WRAP_CONTENT;
params.height = WindowManager.LayoutParams.WRAP_CONTENT;
params.gravity = Gravity.CENTER;
mWindowManager.addView(mView, params);
}
/**
* 隐藏弹出框
*/
private static void hidePopupWindow() {
if (isShown && null != mView) {
mWindowManager.removeView(mView);
isShown = false;
}
}
private int x=0;
private int y=0;
private int startX=0;
private int startY=0;
private View setUpView(final Context context) {
View view = LayoutInflater.from(context).inflate(R.layout.popupwindow,
null);
TextView tv= (TextView) view.findViewById(R.id.title);
int w = View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED);
int h = View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED);
tv.measure(w, h);
TheOffset=(pixel-tv.getMeasuredWidth())/2-50;
tv.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent =new Intent(context,MainActivity.class);
context.startActivity(intent);
// Toast.makeText(context,"点击事件",Toast.LENGTH_LONG).show();
}
});
tv.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()){
case MotionEvent.ACTION_MOVE:
int newX= (int) (event.getRawX()-x);
int newY= (int) (event.getRawY()-y);
params.x=newX+startX;
params.y=newY+startY;
mWindowManager.updateViewLayout(mView,params);
break;
case MotionEvent.ACTION_DOWN:
x= (int) event.getRawX();
y= (int) event.getRawY();
break;
case MotionEvent.ACTION_UP:
if(params.x>=0){
params.x=TheOffset;
mWindowManager.updateViewLayout(mView,params);
}
if(params.x<=-0){
params.x=-TheOffset;
mWindowManager.updateViewLayout(mView,params);
}
Log.i(TAG,params.x+"");
Log.i(TAG,params.y+"");
//判断 从按住到抬起时候的移动距离, 如果如果移动距离大于20 那么就拦截事件,否则就不拦截事件,主要是处理点击事件的冲突
if(Math.abs(startX-params.x)>20 ||Math.abs(startY-params.y)>20 ){
//记录上一次的偏移量
startX=params.x;
startY=params.y;
return true;
}else {
startX=params.x;
startY=params.y;
return false;
}
}
return false;
}
});
return view;
}
@Nullable
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onDestroy() {
super.onDestroy();
if (mView != null) {
isShown=false;
mWindowManager.removeView(mView);
}
}
}
Main
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.open).setOnClickListener(this);
findViewById(R.id.close).setOnClickListener(this);
}
-点击开启 关闭悬浮按钮
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.open:
//判断是否拥有悬浮权限
//op 的值是 0 ~ 47,其中0代表粗略定位权限,1代表精确定位权限,24代表悬浮窗权限。(具体可以看看Android源码在android.app下就有个AppOpsManager类)
if(utils.checkOp(this,24)==0) {
Intent intent=new Intent(MainActivity.this, FloatingWindowService.class);
intent.putExtra("pixel",utils.pixel(this)[0]);
startService(intent);
}else {
//引导用户进入悬浮权限设置界面
Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,
Uri.parse("package:" + getPackageName()));
startActivityForResult(intent, 200);
}
break;
case R.id.close:
stopService(new Intent(MainActivity.this,FloatingWindowService.class));
break;
}
}
判断权限 -获取屏幕的宽高
public class utils {
public static int checkOp(Context context, int op){
final int version = Build.VERSION.SDK_INT;
if (version >= 19){
Object object = context.getSystemService("appops");
Class c = object.getClass();
try {
Class[] cArg = new Class[3];
cArg[0] = int.class;
cArg[1] = int.class;
cArg[2] = String.class;
Method lMethod = c.getDeclaredMethod("checkOp", cArg);
return (Integer) lMethod.invoke(object, op, Binder.getCallingUid(), context.getPackageName());
} catch(NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
return -1;
}
/**
* 获取屏幕的宽高
* @param context
* @return
*/
public static int[] pixel(Activity context){
DisplayMetrics dm = new DisplayMetrics();
context.getWindowManager().getDefaultDisplay().getMetrics(dm);
return new int[]{dm.widthPixels,dm.heightPixels};
}
}
--popupwindow填充布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:id="@+id/popup_window"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@android:color/white"
android:orientation="vertical" >
<TextView
android:background="@mipmap/ic_launcher"
android:id="@+id/title"
android:layout_width="50dp"
android:layout_height="50dp"/>
</LinearLayout>
</LinearLayout>
以上所述是小编给大家介绍的Android开发模仿qq视频通话悬浮按钮(实例代码),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# android
# 悬浮按钮
# Android基于腾讯云实时音视频仿微信视频通话最小化悬浮
# Android仿微信多人音视频通话界面
# Android 8.0 中如何实现视频通话的画中画模式的示例
# 声网SDK教程Android UIKit 实时视频通话添加自定义背景
# 弹出
# 小编
# 有个
# 在此
# 就不
# 给大家
# 所示
# 所述
# 给我留言
# 感谢大家
# 主要是
# 判断是否
# 疑问请
# 有任何
# 偏移量
# startX
# removeView
# startY
# popupwindow
# TextView
相关文章:
如何在香港服务器上快速搭建免备案网站?
建站之星下载版如何获取与安装?
太原网站制作公司有哪些,网约车营运证查询官网?
如何在腾讯云服务器上快速搭建个人网站?
如何选择高效便捷的WAP商城建站系统?
如何高效完成独享虚拟主机建站?
如何通过PHP快速构建高效问答网站功能?
如何快速搭建响应式可视化网站?
名字制作网站免费,所有小说网站的名字?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
成都网站制作报价公司,成都工业用气开户费用?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何通过云梦建站系统实现SEO快速优化?
番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?
如何在腾讯云服务器快速搭建个人网站?
网站制作话术技巧,网站推广做的好怎么话术?
如何获取免费开源的自助建站系统源码?
制作网站怎么制作,*游戏网站怎么搭建?
如何彻底卸载建站之星软件?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
如何通过虚拟主机快速完成网站搭建?
如何快速使用云服务器搭建个人网站?
如何访问已购建站主机并解决登录问题?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
c# await 一个已经完成的Task会发生什么
Bpmn 2.0的XML文件怎么画流程图
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
C++中引用和指针有什么区别?(代码说明)
北京营销型网站制作公司,可以用python做一个营销推广网站吗?
如何用PHP工具快速搭建高效网站?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
建站主机无法访问?如何排查域名与服务器问题
Android使用GridView实现日历的简单功能
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
内部网站制作流程,如何建立公司内部网站?
建站主机与服务器功能差异如何区分?
如何在云服务器上快速搭建个人网站?
定制建站方案优化指南:企业官网开发与建站费用解析
如何用AWS免费套餐快速搭建高效网站?
建站之星Pro快速搭建教程:模板选择与功能配置指南
北京企业网站设计制作公司,北京铁路集团官方网站?
电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?
如何快速搭建高效WAP手机网站吸引移动用户?
如何在阿里云ECS服务器部署织梦CMS网站?
如何获取上海专业网站定制建站电话?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
*请认真填写需求信息,我们会在24小时内与您取得联系。