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

【Android TV 开发】焦点处理 ( 父容器与子组件焦点获取关系处理 | 不同电视设备上的兼容问题 | 触摸获取焦点 | 按键获取焦点 )

Android TV 开发系列文章目录 【Android TV 开发】安卓电视调试 ( 开启网络远程调试 ) 【Android TV 开发】焦点处理 ( 父容器与子组件焦点获取关系处理 | 不同电视设备上的兼容问题...; 二、不同电视设备上的兼容问题 ---- 在开发时遇到这样一种情况 , 布局的样式是 ScrollView 中嵌入一个 ConstraintLayout 布局 , 在 ConstraintLayout...布局中设置了很多需要获取焦点的子组件 ; 运行正常的情况 : 在 Google 提供的模拟器上运行时 , 正常运行 , ScrollView 的子组件中可以正常获取焦点 ; 运行失败的情况 : 但是在真实的国产电视盒子中...: 在子组件中 , 将需要获取焦点的组件都添加 android:focusable=“true” 属性 , 这样就解决了上述问题 ; 由此可见 , 相同的代码 , 在不同型号 , 版本 , 厂家 的电视设备上..., 焦点的获取 , 移动 , 表现是不一样的 , 因此这里就涉及到了焦点的兼容问题 ; 本次在 康佳 电视盒子中 , ScrollView 会阻断子组件的焦点获取 , 但是在其它界面 , 没有添加 android

3.3K40

C001Android学习笔记-初级控件(一)

一、屏幕显示 1、像素 安卓支持的像素单位: px(像素)、in(英寸)、mm(毫米)、pt(磅,1/72英寸)、dp(与设备无关的显示单位)、dip(就是dp)、sp(用于设置字体大小); 安卓常用的三种像素单位...: px:手机屏幕上可显示的最小单位; dp:按照屏幕尺寸计量,与物理设备无关; sp:原理跟dp差不多,专用于设置字体大小; 2、颜色 概述: 安卓中的颜色由透明度alpha和RGB(红、绿、蓝)组成...、paddingRight分别表示上下左右; visibility:指定该视图的可是类型,visible:可见,默认;invisible,不可见,占位置;gone,不可见,不占位置; 代码中常用的设置视图的方法...():设置该视图的内边距; setVisibility():设置该视图的可见类型; Android视图分为两类: 布局:布局本质上是各容器,内部还可以再放子布局或者子控件; 控件:控件是一个单一的实体,...; 3、滚动布局ScrollView 垂直滚动视图: ScrollView,layout_width要设置为wrap_content; 水平滚动视图: HorizontalScrollView,layout_height

6710
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    看完还不会解决滑动冲突?呵呵,我食屎!!

    安卓设备由于由于屏幕的限制,如果想要在有限的屏幕中展示更多的内容,列表和弹窗就是一种非常好的解决方案,列表尤其是华滑动列表。...同样也是面试必问的知识点,所以说掌握安卓滑动冲突的解决方案是安卓程序员必不可少的一项技能 下面这个例子是一个非常典型的一个嵌套滑动的例子(scrollview嵌套webview)。...需求也很简单:整个页面是需要上下滑动的,另外呢上面一部分的webview加载的全景视图也是需要能够自己左右滑动上下滑动的。下面请看效果图。 ?...像这种scrollview嵌套webview的页面肯定会产生滑动冲突的。具体的表现呢就是:webview里面内容绝对不会自己的滑动的,滑动的只是滑动外层的scrollview。...其中的原理才是我们真正需要掌握的。 因为产品的脑袋永远不是正常人的脑袋。ui的手也永远不是正常人的手。当他们用一个个列表设设计出来千奇百怪的交互的时候。你当时的心态简直就是日了狗。

    49510

    Android中文API——ScrollView

    此方法将视图滚动到顶部或者底部,并且将焦点置于新的可视区域的最顶部/最底部组件。若没有适合的组件做焦点,当前的ScrollView会收回焦点。...此方法将向上或者向下滚动一屏,并且将焦点置于新可视区域的最上/最下。如果没有适合的component作为焦点,当前scrollView将收回焦点。...参数 child 要获得焦点的父视图的子视图。此视图包含了焦点视图。如果没有特殊徐要求,此视图实际上就是焦点视图。...* 为使矩形区域全部可见,视图将可以被滚动显示 参数 child 发出请求的子视图 rectangle 子项目坐标系内的矩形,即此子项目希望在屏幕上的定位 immediate 设为true.../ScrollView2 添加自动滚动和智能焦点切换 [Android学习指南]使用ScrollView实现滚动效果 Android中ScrollView与ListView共用问题的解决方案   示例代码

    4.6K30

    React Native之ScrollView控件详解

    5:on-drag 当拖拽开始的时候隐藏软键盘。 6:interactive 软键盘伴随拖拽操作同步地消失,并且如果往上滑动会恢复键盘。安卓设备上不支持这个选项,会表现的和none一样。...7:keyboardShouldPersistTaps bool 当此属性为false的时候,在软键盘激活之后,点击焦点文本输入框以外的地方,键盘就会隐藏。...8:onContentSizeChange function 此函数会在ScrollView内部可滚动内容的视图发生变化时调用。...11:removeClippedSubviews bool (实验特性):当此属性为true时,屏幕之外的子视图(子视图的overflow样式需要设为hidden)会被移除。...41:(ios)zoomScale number 滚动视图内容初始的缩放比例。默认值为1.0。 ScrollView代码 ?

    5.9K70

    基础篇章:React Native之 ScrollView 的讲解

    on-drag 当拖拽开始的时候隐藏软键盘。 interactive 软键盘伴随拖拽操作同步地消失,并且如果往上滑动会恢复键盘。安卓设备上不支持这个选项,会表现的和none一样。...keyboardShouldPersistTaps 当此属性为false的时候,在软键盘激活之后,点击焦点文本输入框以外的地方,键盘就会隐藏。...onContentSizeChange function 该函数方法会在ScrollView内部可滚动内容的视图发生变化时调用。...pagingEnabled 如果为true,滚动视图的滚动视图大小的倍数滚动时停止。这可用于水平分页。默认值false。...在ScrollView视图之外的视图(该视图的overflow属性值必须要为hidden)会从被暂时移除,该设置可以提高滚动的性能。

    1.9K50

    【React Native 安卓开发】----侧边栏的实现DrawerLayoutAndroid以及第三方框架react-native-side-menu的使用【第六篇】

    前言 做过安卓原生开发的童鞋们应该都做过侧边栏这个东西,而且对于开源框架SlidingMenu和android官方侧滑菜单DrawerLayout应该都不陌生。...DrawerLayoutAndroid 介绍 封装了平台DrawerLayout(仅限安卓平台)的React组件。...抽屉(通常用于导航切换)是通过renderNavigationView方法渲染的,并且DrawerLayoutAndroid的直接子视图会成为主视图(用于放置你的内容)。...导航视图一开始在屏幕上并不可见,不过可以从drawerPosition指定的窗口侧面拖拽出来,并且抽屉的宽度可以使用drawerWidth属性来指定。...drawerWidth number 指定抽屉的宽度,也就是从屏幕边缘拖进的视图的宽度。

    6.8K40

    基础篇章:关于 React Native 之 Touchable 系列组件的讲解

    提示:前天文章,重发,不想看的请略过,上次失误忘了加效果图 (友情提示:RN学习,从最基础的开始,大家不要嫌弃太基础,会的同学请自行略过,希望不要耽误已经会的同学的宝贵时间) 在上篇 ScrollView...,不知道的去看View的style underlayColor 当视图被触摸或者点击时,显示的颜色 效果展示 我们还是拿前面那个Image和ScrollView中使用的例子,只不过我们现在给它加上按压效果...我们推荐使用以下的静态方法之一来创建这个对象: TouchableNativeFeedback.SelectableBackground() - 会创建一个对象,表示安卓主题默认的对于被选中对象的背景。...attr/selectableItemBackground) TouchableNativeFeedback.SelectableBackgroundBorderless() - 会创建一个对象,表示安卓主题默认的对于被选中的无边框对象的背景...是true,那么涟漪还会渲染到视图的范围之外。

    2K90

    基础篇章:关于 React Native 之 Touchable 系列组件的讲解

    【回复“1024”,送你一个特别推送】 (友情提示:RN学习,从最基础的开始,大家不要嫌弃太基础,会的同学请自行略过,希望不要耽误已经会的同学的宝贵时间) 在上篇 ScrollView 的讲解的实例中,...,不知道的去看View的style underlayColor 当视图被触摸或者点击时,显示的颜色 效果展示 我们还是拿前面那个Image和ScrollView中使用的例子,只不过我们现在给它加上按压效果...我们推荐使用以下的静态方法之一来创建这个对象: TouchableNativeFeedback.SelectableBackground() - 会创建一个对象,表示安卓主题默认的对于被选中对象的背景。...attr/selectableItemBackground) TouchableNativeFeedback.SelectableBackgroundBorderless() - 会创建一个对象,表示安卓主题默认的对于被选中的无边框对象的背景...是true,那么涟漪还会渲染到视图的范围之外。

    1.6K90

    深入了解 SwiftUI 5 中 ScrollView 的新功能

    不限于 ScrollView,支持所有可滚动容器(包括 List、TextEditor 等)。 将可滚动容器内的所有子视图视为一个整体,并为其添加 margin。...任何超出边界的部分将不会显示。 当 scrollClipDisable 为 true 时,滚动内容不会被裁剪。它可以延伸超出滚动容器的边界,从而显示更多内容。...} } .scrollTargetLayout(isEnabled: isEnabled) } scrollPosition(initialAnchor:) 使用此修饰符可以指定滚动视图内容最初可见部分的锚点...scrollTargetBehavior scrollTargetBehavior 用于设置 ScrollView 的滚动行为:分页还是与子视图对齐。...目前定义了三种阶段状态(Phase): topLeading: 视图滑入滚动容器的可见区域 identity: 表示视图目前在可见区域中 bottomTrailing: 视图滑出滚动容器的可见区域 scrollTransition

    92720

    View的有效曝光监控(下)|ScrollView NestScrollView篇

    ScrollView NestScrollView 的滑动监控怎么做。 View有没有像RecyclerView一样的attach和detch方法,超过1.5s的曝光时间。 View出现一半。...滑动监控 一般人肯定告诉你,这个你自定义个scrollview,然后在onScrollChanged实现个滑动监听的回调什么的。不好意思,我偏不,带你看看另外一个神奇的方法。...当视图树的布局发生改变或者View在视图树的可见状态发生改变时会调用的接口 ViewTreeObserver.OnGlobalFocusChangeListener 当一个视图树的焦点状态改变时,会调用的接口...当视图树的触摸模式发生改变时,会调用的接口格 各位老哥有没有发现一些奇怪的东西混在里面,哈哈哈。...当滑动监听触发的时候调用之前的view是否被遮挡的方法来判断当前的view是不是在视图上出现了,然后调用onVisibleChange来通知视图是否已经从window上移除。

    1.4K30

    自定义tab吸顶效果一(原理)

    实现原理:创建两个布局,这两个布局处于重叠状态,一个布局上面显示   背景为蓝色+导航栏+数据内容,注意这里的导航栏随着布局可移动,第二个布局显示导航栏但处于影藏状态,当滑动屏幕时,蓝色部分全部被拉上去后...1:首先重写ScrollView里的滑动方法,可创建一个接口,来实现接口里的方法即可 public interface ScrollViewListener { void onScrollChanged...尚未有统一中文名称,中国大陆地区较多人使用“安卓”或“安致”。Android操作系统最初由Andy Rubin开发,主要支持手机。2005年8月由Google收购注资。...Android逐渐扩展到平板电脑及其他领域上,如电视、数码相机、游戏机等。2011年第一季度,Android在全球的市场份额首次超过塞班系统,跃居全球第一。...,在xml文件中,蓝色背景的部分为300px,如果是300dp,则要把dp转成px单位。

    2.2K130

    UIScrollView视觉差动画

    [普通的浏览效果.gif] 二、分析动画效果,提出解决方案 注意:这里的left和right是区分拖动中可见的两个视图。 1 ....,尾尾相连,且滑动过程中,当前可见的图片有渐进的裁剪效果;前者就像是平铺在一起的一行书,一块儿左右平移,而后者就像是翻书时看到的效果,当前页left内容由边到内逐渐消失,而下一页right内容由边缘到里逐渐显示...我们可以在拖拽过程中相对应的改变right/left图片在父视图WSLAnimationView上的X坐标,把right图片的坐标位置放到相对于left图片的正下/偏右方位置,然后随着拖拽滑动逐渐改变right...以及left图片的相对位置X坐标,直至复位,回到它们在WSLAnimationView上的初始位置X=0,超出父视图的部分裁剪掉,也是设置WSLAnimationView对象的clipsToBounds...; NSInteger leftIndex = x/SCROLLVIEW\_WIDTH; //这里的left和right是区分拖动中可见的两个视图 WSLAnimationView

    849140

    UIScrollView视觉差动画

    普通的浏览效果.gif 二、分析动画效果,提出解决方案 注意:这里的left和right是区分拖动中可见的两个视图。 1....,尾尾相连,且滑动过程中,当前可见的图片有渐进的裁剪效果;前者就像是平铺在一起的一行书,一块儿左右平移,而后者就像是翻书时看到的效果,当前页left内容由边到内逐渐消失,而下一页right内容由边缘到里逐渐显示...我们可以在拖拽过程中相对应的改变right/left图片在父视图WSLAnimationView上的X坐标,把right图片的坐标位置放到相对于left图片的正下/偏右方位置,然后随着拖拽滑动逐渐改变right...以及left图片的相对位置X坐标,直至复位,回到它们在WSLAnimationView上的初始位置X=0,超出父视图的部分裁剪掉,也是设置WSLAnimationView对象的clipsToBounds...; NSInteger leftIndex = x/SCROLLVIEW_WIDTH; //这里的left和right是区分拖动中可见的两个视图 WSLAnimationView

    72160

    【Hybrid开发高级系列】ReactNative(三)——RN能力简介

    ,例如iOS的UITabBar或安卓的Drawer。...同时还提供了高度封装的组件如TouchableHighlight等,可以直接嵌入到ScrollView或者其它的元素中,无需额外配置。...除此之外,我们还吸纳了web生态系统中的通用标准,并在必要的时候为这些API提供兼容层。如此一来,npm上的许多库就可以在React Native中直接使用。...尽管如此,使用自定义的原生视图和模块来扩展ReactNative也非常容易 —— 这意味着你现有的所有工作都可以被复用,你喜欢的各种原生库都可以被导入。...创建一个基础的安卓模块,需要先创建一个继承自ReactContentBaseJavaModule的类,然后使用@ReactMethod标注(Annotation)来标记那些你希望通过Javascript

    32830

    【IOS开发基础系列】UIScrollView专题

    下面就需要在你创建的视图控制器中,创建一个重用的视图数组,用来把这些要显示的视图放入内存中,这里虽然界面上显示的是2排2列的四个视图,但是当拖动的时候,可能出现前面一排的视图显示一部分,末尾一排的视图显示一部分的情况...        if (firstViewYOffset scrollView.contentOffset.y) {             //改变数组中第一排可见视图的位置。             ...如果判断滚到离开了可视范围,然后就是要改变重用视图数组中第一个视图的位置了。这里用了firstViewIndex来记录scrollView中第一个可见视图的位置, 循环使用这6个视图达到重用的目的。...所以这里需要改变重用视图中firstViewIndex即第一个可见视图的位置。...ScrollView的行为         创建一个子类         重写一些功能并改变行为         关于这种方式的争议         应用程序的逻辑和行为变成了视图本身的一部分,就像,你可能有一些定制的滚轴逻辑

    66030

    阅读器多种翻页的设计与实现

    { ret = [self getRandomVCWithIndex:index + 1]; } } return ret; } 2、仿真 相对安卓...分解UI层的实现,整个动画可以用以下流程来表示: 1、页面初始化,直接显示页面,监听用户pan手势; 2、用户pan手势开始,根据方向确定左滑还是右滑,获取新的VC; 3、处理用户左右滑动,视图跟随用户滑动...效果分解: 1、当用户滑动的过程,视图要跟随手指的移动; 2、当用户往上滑然后松开时,视图要带有加速度的往上滑动;(附加特性:在滑动过程中用户可以通过重复这个行为加速滑动) 3、在视图滑动的过程中...同理,我们可以处理向上滑动的情况。至此,我们可以不依赖UITableView完成无限视图的滚动,同时避免各类touch事件处理和加速度计算。 ?...简单的实现效果 上图的实现过程非常简短: - (void)scrollViewDidScroll:(UIScrollView *)scrollView { if (self.scrollView.contentOffset.y

    3.4K10

    从源码出发浅析 Android TV 的焦点移动原理(下篇)

    ,进行一次遍历比较,得到最“近”的视图作为下一个焦点视图。...小结 经过对源码的分析,系统本身寻找下一个焦点视图的过程是: 首先寻找用户指定了id的视图,从当前焦点视图的节点开始遍历,直到找到匹配该id的视图。...也许存在多个相同id的视图,但是只会找到视图节点树中最近的一个。 如果没有指定id,则遍历找出所有isFocusable的视图,统一坐标系,然后计算出指定方向上离当前焦点视图最近的一个视图。...指定nextFocusId 系统自动从所有isFocusable的视图中找下一个焦点视图 以上任一处都可以指定焦点,一旦使用了就不再往下走。...很多视图控件就重写了其中一些方法。 比如ScrollView,它会在dispatchKeyEvent的时候,自己去处理,用来进行内部的焦点移动或者整体滑动。

    3.6K10
    领券