首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Android:将触摸传递到浮动视图下的视图(另一个应用)

Android中,要将触摸事件传递到浮动视图下的视图(另一个应用),可以使用以下方法:

  1. 使用WindowManager.LayoutParams设置浮动视图的类型为TYPE_APPLICATION_OVERLAY,以确保它位于其他应用程序之上。
  2. 创建一个透明的Activity,并将其设置为浮动视图的内容。可以通过设置Activity的主题为透明,去除标题栏和边框,使其看起来像一个浮动视图。
  3. 在透明Activity中,使用View.setOnTouchListener()方法来监听触摸事件。
  4. 在触摸事件的回调方法中,可以通过WindowManager.LayoutParams将触摸事件传递给浮动视图下的视图。具体可以使用WindowManager.LayoutParams的属性x和y来设置浮动视图的位置,使用WindowManager.LayoutParams的属性flags来设置浮动视图的行为,使用WindowManager.LayoutParams的属性token来设置浮动视图所在的窗口。
  5. 为了确保浮动视图下的视图可以接收触摸事件,可以使用WindowManager.LayoutParams的属性flags设置FLAG_NOT_TOUCH_MODAL,以允许触摸事件传递到浮动视图下的视图。
  6. 如果需要在浮动视图下的视图中显示内容,可以使用WebView加载网页或者使用SurfaceView进行绘制。

总结: Android中,要将触摸事件传递到浮动视图下的视图,可以通过设置浮动视图的类型、创建透明的Activity、监听触摸事件并传递给浮动视图下的视图来实现。具体实现过程中,可以使用WindowManager.LayoutParams来设置浮动视图的属性,以及设置浮动视图下的视图可以接收触摸事件的属性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • iOS界面布局的核心以及TangramKit介绍

    TangramKit是iOS系统下用Swift编写的第三方界面布局框架。他集成了iOS的AutoLayout和SizeClass以及Android的五大容器布局体系以及HTML/CSS中的float和flex-box的布局功能和思想,目的是为iOS开发人员提供一套功能强大、多屏幕灵活适配、简单易用的UI布局解决方案。Tangram的中文即七巧板的意思,取名的寓意表明这个布局库可以非常灵巧和简单的解决各种复杂界面布局问题。他的同胞框架:MyLayout是一套用objective-C实现的界面布局框架。二者的主体思想相同,实现原理则是通过扩展UIView的属性,以及重载layoutSubviews方法来完成界面布局,只不过在一些语法和属性设置上略有一些差异。可以这么说TangramKit是MyLayout布局库的一个升级版本。大家可以通过访问下面的github站点去下载最新的版本:

    03

    Android开发笔记(二十二)瀑布流网格WaterfallGridView

    Android中展示门类信息一般使用列表视图ListView或者网格视图GridView,特别是电商类APP的首页,除了顶部导航、底部标签、上方横幅外,主要页面都是展示各种商品和活动的网格视图。一般情况下GridView就够用了,不过GridView中规中矩,每个网格的大小都是一样的,有时显得有些死板。比如不同商品的外观尺寸很不一样,冰箱是高高的在纵向上长,空调则是在横向上长,所以若用一样规格的网格来展示,必然有的商品图片被压缩得很小。再比如像新闻摘要,每篇摘要的字数都不一样,为了把文字显示完全,也需要对每个网格自适应高度,字数多的网格分配较小的高度,字数较多的网格分配较大的高度。可惜GridView不支持自适配网格高度,所以我们得自己写个瀑布流网格控件来实现这样的效果了。 先来理下瀑布流控件的思路,因为GridView每个网格的宽和高都是一样的,所以无法基于GridView进行改造。如果是ListView,每行高度一样,一行内每个元素的长度是可以自定义的,但每列元素的长度必须一样,所以改造ListView的效果也很有限。改造GridView也不行,改造ListView也不行,看来得换个思路了,把复杂问题简单化试试。例如这个页面上只有四个视图:左上区块0、右上区块1、左下区块2、右下区块3,直接用布局文件xml编写的话也不难,可能大家多半会想到采用相对布局RelativeLayout来处理。

    06
    领券