位置: 编程技术 - 正文

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线程间通信的几种方法)

  • 个人名义开工程发票税率是多少
  • 营业成本和生产成本的公式
  • 对公账户转到个人账号能提供发票吗?
  • 公司刚成立没有收入但是有支出怎么记账
  • 库存暂估入账
  • 季度所得税申报表怎么申报
  • 企业前期开办费没有发票怎么入账
  • 企业合并相关舞弊风险有哪些
  • 缴交社保基金会计分录怎么写?
  • 仪器设备校验记录表
  • 用友如何取消月末结转
  • 生产用的软件
  • 如何知道企业是查账征收还是核定征收
  • 审计费用需要计什么科目
  • 建筑业小规模纳税人异地开票
  • 发票上电话可以写手机号吗
  • 安装设备用的材料计入什么科目
  • 零星费用没有发票报销可以做入工资吗
  • 收入和成本都是真实发生的但是不匹配
  • 离退休人员福利
  • 住院材料费包括哪些
  • 公积金社保报销会计分录怎么写?
  • 增值税留抵退税账务处理
  • 怎么做汇算清缴报表
  • bios设置技巧
  • 前端解决页面加载白屏
  • linux查杀webshell
  • 局域网内ip地址冲突怎么找出来
  • 笔记本电脑如何恢复出厂系统
  • 国家占耕地补偿款给谁?
  • php array_map 和 foreach性能
  • php顺序查找和二分查找
  • 商业连锁企业有哪些
  • laravel 5.1下php artisan migrate的使用注意事项总结
  • php 序列化和json性能
  • 微信小程序项目中app.js文件是全局样式文件
  • 取得短期借款会计分录
  • phpcms官网打不开
  • 卖家运费险是不是退货免费
  • 纸质承兑财务章怎么盖
  • 契税计入会计利润总额吗
  • 个人综合所得汇算申报流程
  • 用专项资金支付项目滞纳金合规么
  • mysql存储过程之错误处理
  • 织梦如何给栏目增加缩略图
  • 股票印花税和佣金是一样的吗
  • 汽车租赁属于经营租赁吗
  • 社保是当月计提当月交吗
  • sqlserver数据库版本号怎么查
  • 个人出租商铺如何报税申报,需要什么资料
  • 小规模纳税人免税政策
  • 只知道主营业务怎么办
  • 生物资产转让增值税
  • 软件公司se
  • 用友为什么引入不了账套
  • 资产负债表编制
  • 远程连接sqlserver的数据库和本地连接时不一样
  • 新装mysql设置密码
  • ubuntu注册用户
  • safari 快捷键
  • Linux系统复制图片
  • rancheros github
  • win8系统升级到win10东西还在吗
  • linux系统怎么停止ping
  • win7点关机关不了
  • 如何获取硬盘所有文件的列表
  • img可以设置的属性
  • 粒子form
  • 使用Math.floor与Math.random取随机整数的方法详解
  • node.js怎么样
  • node 操作mysql
  • python socket传输文字到网页
  • ubuntu系统的手机
  • 浅析jQuery Ajax通用js封装
  • 微信收款商业版和个人经营收款码区别
  • 全电发票
  • 互城通怎么用微信充值
  • 丰田威驰2023款1.5自动挡新车报价
  • 为什么医保的钱可以取出来
  • 税收筹划与避税的性质相同
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设