一步一步学习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-29 15:05:57

    php 数组分页 array_slice()函数用法

    今天用到一个函数,非常好用,分享给大家 array_slice() -从数组中取出一段 也就是说用这个函数可以和sql语句一样实现分页,原理是将查询出的数组,取出从指定下标开始到指定长度的数组

  • 2019-12-30 10:17:21

    router-link传递参数,query

    在vue-router中,有两大对象被挂载到了实例this; $route(只读、具备信息的对象); $router(具备功能的函数) 查询字符串: 去哪里 ? <router-link :to="{name:'detail',query:{id:1}}"> xxx </router-link>

  • 2019-12-30 16:48:41

    vue provide/inject详解和用法

    父子组件交互方式多种,props、vuex、 、 emit、localStorage还有就是这个provide/inject了。它适合层级比较深的组件,比如子,子孙,子孙后代的组件有好几个用到父组件的某个属性,就可以用到这个provide/inject,它可以避免写大量繁琐的传值代码 我这里为什么要使用它? 我一个知识库详情父组件中包含了大量的子组件,每个子组件都需要父组件的知识库ID,这时候我不想写大量props,就用到provide/inject进行传值了

  • 2020-01-03 00:36:00

    break和continue详解for循环

    1. break:直接跳出当前循环体(while、for、do while)或程序块(switch)。其中switch case执行时,一定会先进行匹配,匹配成功返回当前case的值,再根据是否有break,判断是否继续输出,或是跳出判断(可参考switch的介绍)。 2. continue:不再执行循环体中continue语句之后的代码,直接进行下一次循环。