首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    悬浮窗开发设计实践

    市面上常见的悬浮窗,如微信视频通话功能,有如下特点:整屏页面能切换到一个小的悬浮窗;悬浮窗能运行在其他app上方;悬浮窗能跳回整屏页面,并且悬浮窗消失需求悬浮窗效果点击缩小按钮,将当前远端视屏加载进悬浮窗...,内部的内容如何无缝衔接继续显示;3.2 关键技术要点悬浮窗权限判断这个需要注意针对不同的版本需要适配权限。...同时要注意,部分手机判断悬浮窗权限Api可能失效……将view添加到悬浮窗上利用addView将View添加在window上,同样的,WindowManager.LayoutParams.type可以设置...如何实现悬浮窗左右边的吸顶效果?监听到手指抬起(UP事件)的动作后,判断当前位置是靠近左边还是右边,靠近左边就以位置动画的方式平移到左边,靠近右边就平移到右边。...第二点:怎么判断滑动?因为点击click也会执行down,move,up等一连串事件。这个时候就要判断最小move距离是否大于系统最小触摸距离,如果是则为拖动,否则是点击!

    2.5K40

    右侧悬浮菜单悬浮窗 css+html css自动判断PC显示手机端隐藏 Alextao html

    感觉还不错,只是部署到博客不太搭配(颜色太鲜艳了),用css加了个设备判断,电脑端显示、手机端隐藏。1221px 界点 预览: css 悬浮菜单 開始--> /*footer*/ .elevator_item .hd-time-limited { display: block; position...--右侧悬浮菜单 結束--> 不锈钢料槽 html actionscriptapacheconfapplescriptaspnetbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyamletbashbasicbatchcclikecoffeescriptcppcsharpcssddartdiffdockerdockerfileerlangfortranfsharpgfmgitglslgographqlhamlhaskellhaxehtmlhttpiconinijjavajavascriptjsjsonjsonpjsxlatexlessluamakefilemarkdownmarkupmathmlmatlabmdmelnginxobjectivecparserpascalperlphppowershellpropertiespythonqrrubyrustsassschemescsssmartysqlstylussvgswifttcltstypescriptvbnetvimwikixmlyaml

    3.6K00

    Android 可拖动悬浮窗实现

    作者:Kuky_xs 博客:https://www.jianshu.com/p/1d22edea2647 最近公司的项目里,需要通过悬浮窗进行控制,悬浮窗根据手势进行拖动。...可能文字表达不够明确,贴一张手绘原理图 原理图 接下来就是代码一波流了,首先定义一个手势监听回调类,主要用来判断 indicatorView 的滑动的距离以及方向,然后悬浮窗可以根据 indicatorView...最后还需要判断最后一下手指的滑动方向,如果和初始的方向相反,则需要将拖出来的悬浮窗自动回滚到初始状态。...); mWindowManager.addView(mContainer, mContainerParams); // 判断悬浮窗是否已经显示的标志位...等到悬浮窗完全展示的时候,点击空白的地方,悬浮窗又需要从当前的位置回滚到初始的位置,其原理和拖出来的原理是一样的。

    2.1K21

    Android 悬浮窗功能的实现

    1.悬浮窗可以显示在其他应用或launchers之上,这个肯定需要悬浮窗权限,而悬浮窗权限属于特殊权限,所以只能通过引导用户去打开无法像危险权限那样直接申请。...2.通话页面隐藏时悬浮窗显示,通话页面显示时悬浮窗隐藏,可以看出悬浮窗和Activity的生命周期相关联,所以悬浮窗的Service和通话页面的Activity是通过bind去绑定的。...判断是否有悬浮窗权限 点击左上角图标时,我们要先判断当前app是否有悬浮窗权限,首先我们在配置文件中添加,悬浮窗的权限。...或者PHONE,我想说不可能的事,TOAST类型的虽然部分机型可以显示但是就是一个普通的TOSAT会自动消失) 那么我们如何判断是否有悬浮窗权限呢,这一块不同厂商处理方案可能不一样,这里我们用一种通用的处理方案...mVideoServiceConnection, Context.BIND_AUTO_CREATE) } } } 我们通过Settings.canDrawOverlays(this)来判断当前应用是否有悬浮窗权限

    6.3K10

    鸿蒙开发实战案例:视频悬浮窗

    将应用隐藏到后台,自动拉起悬浮窗继续播放视频。点击悬浮窗恢复图标,恢复到原始播放界面,视频继续正常播放。原始播放界面视频暂停不会拉起悬浮窗。悬浮窗视频暂停后,再点击恢复图标,原始播放界面视频继续播放。...悬浮窗点击关闭之后,原始播放界面视频暂停。点击原视频界面小窗口图标,可开启悬浮窗。手指在原视频左侧滑动可改变视频页面的亮度(需真机验证)。...PipManager.getInstance().setAutoStart(true) PipManager.getInstance().updatePiPControlStatus() }}悬浮窗的从小窗口恢复到原始播放界面以及关闭悬浮窗...// 表示画中画生命周期执行过程出现了异常 case PiPWindow.PiPState.ERROR: break; default: break; }}因为当悬浮窗的从小窗口恢复到原始播放界面以及关闭悬浮窗时对视频播放状态进行操作...,悬浮窗的播放图标并不会实时更新,所以手动进行更新。

    7710

    Android免权限悬浮窗组件 - FloatingX

    FloatingX ,一个强大的免权限悬浮窗组件,支持全局,以及局部悬浮窗。...背景 在前几个月的业务开发中,我们 app 需要对悬浮窗进行更改,常见的悬浮窗实现方式分为两种: 前者是获取权限后,利用 WindowManager 实现 后者是基于 DecorView 实现的插入悬浮窗...于是我希望有这样一个组件,它必须具备以下基本要求: 无感插入 可拖动 良好的分层设计 这是最开始的功能,但随着封装过程,以及对比知乎等其他悬浮窗,我发现可能可以让这个东西更有意思,而不只是一个工具类。...插入到 DecorView 可以最大程度控制悬浮窗的自由度,即悬浮窗可以真正意义上[全屏]拖动。...感谢 基础 悬浮窗View 源自 EnFloatingView 的 FloatingMagnetView 实现方式,并在其基础上增加了一些改进。

    2.4K21

    实战总结 Android 悬浮窗适配方案

    背景 ---- 游戏内的悬浮窗通常情况下只出现在游戏内,用做切换账号、客服中心等功能的快速入口。...本文将介绍几种实现方案,以及我们踩过的坑 方案一:应用外悬浮窗+栈顶权限/生命周期回调 ---- 通常实现悬浮窗,首先考虑到的会是要使用悬浮窗权限,用 WindowManager 在设备界面上 addView...实现( UI 层级较高,应用外显示) 1、弹出悬浮窗需要用到悬浮窗权限 悬浮窗权限--> 2、判断悬浮窗游戏内外显示...但是这种方案有如下缺点: 适配问题,悬浮窗权限在不同设备上由于不同产商实现不同,适配难 向用户申请权限,打开率较低,体验较差 方案二:addContentView实现 ---- 原理:Activity

    1.3K10

    HarmonyOS Next 悬浮窗拖拽和吸附动画

    效果图预览使用说明按住悬浮窗可以拖拽,松开后悬浮窗自动靠左或靠右,如果悬浮窗超出内容区上下边界,自动吸附在边界位置。...y轴偏移和设备顶部状态栏高度 }) break; }手指抬起时,通过判断悬浮窗中心在水平方向位于窗口中心的左侧或右侧设置悬浮窗靠左或靠右,如果悬浮窗超出内容区上下边界,则将悬浮窗设置在边界位置...源码参考FloatWindowMainPage.ets case TouchType.Up: { // TODO:知识点:通过判断悬浮窗在窗口中的位置,设置悬浮窗贴边,使用curves.springMotion...()弹性动画曲线,可以实现阻尼动画效果 animateTo({ curve: curves.springMotion() }, () => { // 判断悬浮窗中心在水平方向是否超过窗口宽度的一半...pageHeight: number = this.windowRectHeight - this.topRectHeight - this.bottomRectHeight; // 判断悬浮窗是否超出内容区上下边界

    14620

    「 神器 」极简网速监控悬浮窗软件

    前言 很多时候,我们使用xx卫士/管家只是为了使用它的网速监控悬浮功能,这次墙裂推荐一个小众软件TrafficMonitor,极简的网速监控悬浮窗软件,软件虽小但很精致,终于能摆脱xx卫士/管家了~ TrafficMonitor...Traffic Monitor是一款用于Windows平台的网速监控悬浮窗软件,可以显示当前网速、CPU及内存利用率,支持嵌入到任务栏显示,支持更换皮肤、历史流量统计等功能。...更换皮肤、自定义样式 历史流量记录 流量、内存报警 界面 TrafficMonitor 不仅功能全面,界面简洁美观~ 悬浮窗模式 ?...右键 悬浮窗,对显示样式进行自定义设置。 可以选择显示在悬浮窗或任务栏、监控项目、透明度等,十分简单。 ?...进入 “选项”,可以自定义悬浮窗和任务栏的显示效果,包括文本颜色、字体、背景、单位、显示文本等。 以及设置开机自启和流量/内存报警等。 ?

    1.8K10

    Android仿微信文章悬浮窗效果

    序言 前些日子跟朋友聊天,朋友Z果粉,前些天更新了微信,说微信出了个好方便的功能啊,我问是啥功能啊,看看我大Android有没有,他说现在阅读公众号文章如果有人给你发微信你可以把这篇文章当作悬浮窗悬浮起来...,方便你聊完天不用找继续阅读,听完是不是觉得这叫啥啊,我大Android微信版不是早就有这个功能了吗,我看文章的时候看到过有这个悬浮按钮,但是我一直没有使用过,试了一下还是挺方便的,就想着自己实现一下这个功能...实现 1、权限 首先我们要考虑的一个问题就是权限问题,因为要适配Android 7.0 8.0,添加悬浮窗是需要申请权限的,这里参考了Android 悬浮窗权限各机型各系统适配大全这篇文章,适配的比较全...//其他版本 6 mLayoutParams.type = WindowManager.LayoutParams.TYPE_PHONE; 7} 2、添加ViewGroup到Window 判断好权限之后...Window,这里通过使用ActivityLifecycleCallbacks来监听Activity在前台的数量来判断应用程序是在前台还是后台 1class ApplicationLifecycle

    1.5K30
    领券