位置: 编程技术 - 正文

Android快速自定义控件+实战演示(三)完整键盘和组合回调!(android 自定义)

编辑:rootadmin

推荐整理分享Android快速自定义控件+实战演示(三)完整键盘和组合回调!(android 自定义),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:android 自定义view三个方法,android 自定义view三个方法,安卓自定义快捷键,android自定义loading,安卓怎么自动化,android 自定义,android 自动操作,android 自定义,内容如对您有帮助,希望把文章链接给更多的朋友!

此文接着《Android快速自定义控件+实战演示(二)组合自定义view+回调》继续讲解。

这一节会提供的知识点: 1.如何把之前做好的单一控件组合成一个完整的键盘控件 2.如何在新的键盘控件里进行回调操作,使得能够选中点击某个数字/字母时,进行相关操作(比如打印出来)

回顾一下项目目标

我们要实现一种用在机顶盒端的自定义键盘,效果图如下

在上一节,我们已经实现了单个自定义按键的切换,现在就是通过布局,把它们排列成九宫格(如果包括最下面一行应该是十二宫格)就可以了。

自定义键盘

看了前两节教程,现在是不是觉得自定义控件超简单的。

自定义布局

首先取名custom_keyboard.xml,因为按键与按键之间有重叠的部分(所有按键都以圆盘形式展开的话,可发现有重叠),我用了RelativeLayout,所以自定义view的时候继承RelativeLayout。

自定义View类

新建一个类,名为CustomKeyboard.java继承RelativeLayout。 依旧在所有构造方法里加上我们的新方法load(),在load()方法里初始化布局(inflateLayout()),UI(initUI())和数据(initData())。 在布局里引入custom_keyboard.xml。

在initUI()里将所有的按键获取到,包括清空和删除按钮。

因为键盘的ABC…以及数字排列都是固定的,我们把数据以数组的格式存在custom_keyboard_arrays.xml里面

然后在设置数据的时候,一一对应。

这一段我个人都觉得看得非常冗余,要是能优化一下,弄成一个循环就好了!(如果你有好的想法,欢迎提出来哦!)

运行,基本界面就出来了。

监听按键响应事件(组合回调)Android快速自定义控件+实战演示(三)完整键盘和组合回调!(android 自定义)

响应的事件比如字母、数字按OK键就打印相应字符,删除和清除按OK键就删除一个字符或者清空所有字符。

分析:点击某个按键的时候,数字按键会先变成圆盘按键,然后圆盘按键点击OK键,能够监听点击并得到当前选中的字符;而现在自定义键盘或者更外层,需要能够继续处理该点击事件。故得到当前字符写在圆盘按键类里,并通过回调传值给自定义键盘类,且自定义键盘类能够继续处理点击事件。

下面我用代码来解释说明。

先定义一个监听器类OnDpadCenterListener,定义三个方法分别响应点击字符、删除和清除事件。其中字符要传值给代理(实现者)。

然后,本来的思路应该是,我们接着在圆盘按键类里面的onKey事件里面的分类KEYCODE_DPAD_CENTER里加上如果本类的属性mOnDpadCenterListener 不为 null,就调用onDpadCenter(getSelectedString(())。

但其实我发现,我之前写过一个OnKeyWorkListener,是用来供组合自定义按键回调的,监听了数字按键的OK键和圆盘按键的Back键,而圆盘按键类(CustomCircleKeyboardItem)本身已经有了这个监听器属性,原来只监听了Back键,现在我们就可以加上监听OK键:

然后在组合按键(CustomKeyboardItem)里加上新属性

并且在onDpadCenter(View view)方法里加上新的判断if (view == circleKeyboardItem)如果是圆盘按键被点击OK键,就传给mOnDpadCenterListener去处理:

好了,该写的都写好了,现在只要在哪写好OnDpadCenterListener传进来就可以了。

我同样给了CustomKeyboard类一个OnDpadCenterListener属性,让外层将实现传给CustomKeyboard,再由CustomKeyboard分发给它的子控件。

当其他地方(比如MainActivity)传入监听器OnDpadCenterListener的实现,就可以响应响应按键了。

如果你有任何问题,欢迎留言告诉我。

版权声明:本文为博主原创文章,未经博主允许不得转载。

Android线程交互(Handler+Thread 和 AsyncTask) 为什么需要线程假设需要开发一个联网应用程序,需要从一个网址抓取网页内容,这里读取的网页地址是笔者在本地机器上自己建立的服务器地址。当

Android listView 动态加载数据,下拉加载数据,上拉加载数据 先上效果图本图为上拉到顶部实现数据加载下图为下拉到底部,实现数据加载下面展示代码,其中用到了三方开源控件pulltoRefresh,朋友们可以在网上自行

Android的AsyncTask官方API谷歌翻译版 公共抽象类AsyncTask的扩展对象的java.lang.Object↳android.os.AsyncTaskPARAMS,进展,结果类概述AsyncTask的正确实现,易于使用的用户界面线程。此类允许执行后

标签: android 自定义

本文链接地址:https://www.jiuchutong.com/biancheng/371029.html 转载请保留说明!

上一篇:Android自定义捕获Application全局异常(android 自定义)

下一篇:Android线程交互(Handler+Thread 和 AsyncTask)(android线程间通信的几种方法)

  • 企业取得被投资单位的长期股权可以享有
  • 期初存货中固定制造费用
  • 无发票的费用怎样补交所得税
  • 税务局买税盘
  • 人力资源公司代招的岗位可以去吗
  • 支付宝公户可以转私户吗
  • 残值要不要做分录
  • 银行承兑汇票手续费是多少
  • 上市公司现金流充足说明什么
  • 企业注销清算方案
  • 进项税发票已经认证但对方又作废
  • 年终奖可以分几次发吗?
  • 为什么报税资料老是显示有
  • 国税代开普通发票现需作废需要哪些资料?
  • 如何计算房地产容积率与土地面积
  • 不是房屋产权人可以卖房吗
  • 预警期内的应收账款管理
  • 房企行业其他应收账款的来源是什么
  • 个人代公司付货款要证明吗
  • 租金和物业费怎么计算
  • 电脑开机故障不开机
  • 应付票据包括哪些票
  • mac big sur 菜单栏
  • PHP:oci_server_version()的用法_Oracle函数
  • adb是什么程序
  • 差额征税的项目有哪些
  • win10任务栏隐藏正在运行的程序
  • 股权转让所得怎么做账
  • 另一种答案
  • 承包经营税率表
  • yolo 源码
  • php编程入门教程
  • yolov5训练参数说明
  • unigui 小程序
  • 其他科技推广服务业可以加计扣除吗
  • vue遇到的问题和解决方法
  • 你要和我一起爬山吗
  • 长期待摊费用是什么科目
  • 工会经费计提比例是2%还是0.8%
  • 购买备用品会计分录
  • python怎么运行程序
  • 发票抬头能否开分支机构
  • 核定征收方式包括哪几种
  • 现流表与资产负债表的关系
  • 建筑公司增值税专用发票税率是多少
  • 未达起征点附加税还需要扣税嘛
  • php配置文件在哪
  • 购车的车辆购置税计入固定资产可以所得税一次性扣除吗
  • 饭店房屋的租赁合同范本
  • 小中央空调多少钱一台
  • 纳税实务的涉税业务分几类
  • 固定资产盘亏如何做账务处理
  • 充值优惠怎么写
  • 更新改造过程中的固定资产需要计提折旧吗
  • 公司要注销账面怎么处理
  • 短期借款的相关法规
  • 免税收入啥意思
  • 利润表的营业成本包括管理费用吗
  • 固定资产折旧度怎么计算
  • 资产负债表基本公式
  • 息税前利润变动百分比计算公式
  • 建账的要点
  • sqlserver 储存过程
  • mysql配置文件优化详解
  • mysql 正则表达式分组替换
  • mysql 5.7.28安装
  • winXP设备管理器在哪
  • 在linux系统中,用来存在系统所需
  • win8如何升级到win10系统版本
  • win8使用教程和技能
  • windows10的操作中心
  • linux怎么添加一个用户
  • windows7word文档打不开怎么办
  • Cocos2d-x之getVisibleSize,getContentSize,boundingBox,getContentSizeInPixels,convertToGL,convertToUI
  • js取数字的每位数
  • angular获取数据给后端
  • 安卓开发viewpager的用法
  • 电子税务局如何下载财务报表
  • 江西省国家税务局总局官网
  • 2021年个税退税条件
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设