一步一步学习Android TV/盒子开发(一)

2020-03-09 21:57:48


参考地址 一步一步学习Android TV/盒子开发(一)

写在前面的话:

本人做了几年的机顶盒和Android电视上的应用开发,写这些文章只是为了让初次接触大屏开发的同学能够快速上手。


TV端因为没有触控操作,只有遥控操作,所以焦点处理、控制以及按键监听是其主要特点。


焦点处理

设置可获取焦点

布局中需要设置某个控件可获取焦点需要加上:


android:focusable="true"

1

代码中:


view.setFocusable(true);

1

焦点监听

view.setOnFocusChangeListener(new View.OnFocusChangeListener() {

    @Override

    public void onFocusChange(View v, boolean hasFocus) {

        if (hasFocus) {

            // 获取焦点时操作,常见的有放大、加边框等

        } else {

            // 失去焦点时操作,恢复默认状态

        }

    }

});

1

2

3

4

5

6

7

8

9

10

在已知其他View ID的情况下设置下一个焦点:

布局文件中:


 android:nextFocusDown="@id/button1"

 android:nextFocusUp="@id/button2"

 android:nextFocusLeft="@id/button3"

 android:nextFocusRight="@id/button4"

1

2

3

4

代码中:


 view.setNextFocusDownId(R.id.button1);

 view.setNextFocusUpId(R.id.button2);

 view.setNextFocusLeftId(R.id.button3);

 view.setNextFocusRightId(R.id.button4);

1

2

3

4

按键监听

Activity中有onKeyDown(…),可以拦截按键处理相关操作,如按两次返回键退出等。


View获取焦点后捕获按键的方式如下:


view.setOnKeyListener(new View.OnKeyListener() {

        @Override

        public boolean onKey(View v, int keyCode, KeyEvent event) {

            if (keyCode == KeyEvent.KEYCODE_BACK && event.getAction() == KeyEvent.ACTION_DOWN) {

                // 这种情况就是当按下遥控器返回键时

                return true;

            }

            return false;

        }

    });


常用的遥控器按键:

KeyEvent.KEYCODE_BACK // 返回键

KeyEvent.KEYCODE_DPAD_DOWN // 下键

KeyEvent.KEYCODE_DPAD_UP // 上键

KeyEvent.KEYCODE_DPAD_LEFT // 左键

KeyEvent.KEYCODE_DPAD_RIGHT // 右键

KeyEvent.KEYCODE_MENU // 菜单键

KeyEvent.KEYCODE_SETTINGS // 设置键


跟手机开发一样,HOME键监听不到



  • 2019-12-11 16:22:04

    Vue中的scoped和scoped穿透,scoped原理

    在Vue文件中的style标签上有一个特殊的属性,scoped。当一个style标签拥有scoped属性时候,它的css样式只能用于当前的Vue组件,可以使组件的样式不相互污染。如果一个项目的所有style标签都加上了scoped属性,相当于实现了样式的模块化。

  • 2019-12-12 14:19:32

    laravel自定义分页LengthAwarePaginator

    有时候我们使用larave提供的后台分页数据库查询,有时候限制太多,我们需要自己定制分页功能。 下面是我给大家一个例子,我们可以根据例子,制作自己的分页功能。

  • 2019-12-14 21:04:05

    聊聊keep-alive组件的使用及其实现原理

    keep-alive是Vue.js的一个内置组件。它能够不活动的组件实例保存在内存中,而不是直接将其销毁,它是一个抽象组件,不会被渲染到真实DOM中,也不会出现在父组件链中。 它提供了include与exclude两个属性,允许组件有条件地进行缓存。

  • 2019-12-14 21:06:58

    vue----keep-alive缓存,activated,deactivated两个生命周期函数,,meta实现缓存

    如果没有缓存,每点击一次导航,内容区就会创建一个组件,该组件会经历整个生命周期,每点击一次,就会创建一个组件,比较浪费性能, 这时,我们就要考虑到是否能将点击过的已创建的组件进行缓存,当再次点击已访问过的组件时,这时,就会从缓存中获取该组件,而不会重新创建,