一步一步学习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-11-04 02:12:42

    genymotion免费版

    genymotion是一套完整的android虚拟环境工具,相对官方android sdk,它的安装和使用简洁方便不臃肿,但是现在genymotion官方网站不再提供个人的下载,这篇博客记录了如何下载和使用genymotion个人版.

  • 2019-11-07 08:47:00

    详解vue2.6插槽更新v-slot用法总结

    在 2.6.0 中,我们为具名插槽和作用域插槽引入了一个新的统一的语法 (即 v-slot 指令)。这篇文章主要介绍了详解vue2.6插槽更新v-slot用法总结,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  • 2019-11-08 09:34:46

    CSS3 Transition详解和使用

    Transition 可以设置 CSS 属性的过渡效果,它有以下几个属性。 transition-property 用于指定应用过渡属性的名称 transition-duration 用于指定这个过渡的持续时间 transition-delay 用于指定延迟过渡的时间 transition-timing-function 用于指定过渡的类型 transition-property transition-property 用于指定应用过渡的属性名称,可以指定多个属性名称,多个属性名称之间用, 分隔。 默认值为 all 也就是所有的元素都应用过渡效果。 例如,想让容器的宽高有一个过渡的效果,就可以这样写: