因为项目需要,设计了一个下图样的验证码输入框(ps:个人认为还不如直接一个EditText,用户友好度可能更好,何况这页面99.9%的用户不会使用,但是没办法,别人才是专业的设计师)。
data:image/s3,"s3://crabby-images/e93a9/e93a9ad26ef227fc0f2c6cbb23cf37a3111ee04d" alt=""
其实界面很简单,一个弹出框口,中间几个简单控件。也就验证码输入框需要自定义一下。首先看到,觉得继承个EditText或者View绘制下,然后监听下输入框情况就可以了。但是,本人比较懒,能用系统提供方法实现的话就尽量少去搞自定义。然后就变成了六个EditText接收值,但是如果每个EditText都搞监听,太浪费资源了,性能开销太大,输入也不流畅。之后,换下思维, 用了个十分粗暴但简单实用的方式:六个TextView+一个不可见EditText。
大概思路,六个带边框的TextView, 然后一个完全透明的EditText覆盖在六个TextView上用来接收键盘的输入(这样的好处事,不用自己处理键盘事件,也因此少了键盘带来的各种兼容性问题)。然后给EditText加一个监听,将接收到的收入值复制给每个TextView。
data:image/s3,"s3://crabby-images/c772e/c772eb2c7c3dcc7734a602897e339b9669ef4a45" alt=""
在TextWatcher的afterTextChanged(Editable s)中
data:image/s3,"s3://crabby-images/3493d/3493dfcfa238d599ceefc5495995546e6a3f7bfd" alt=""
另外提供清除方法
data:image/s3,"s3://crabby-images/fa272/fa272fd0e2454dd75f54d0373d1744d97212c134" alt=""
和输入完成回调
data:image/s3,"s3://crabby-images/09537/09537ef7d565c14a7af4e165dd5f1bfa5b030031" alt=""
使用很简单
data:image/s3,"s3://crabby-images/0017f/0017f2a3f6e5872f11d6f4857d26e2ed6ea50b26" alt=""
然后在Java代码中
data:image/s3,"s3://crabby-images/cecd3/cecd38e5e5e6434c18cabd026971cd07d0fe2af6" alt=""
这样做可以算是很简单粗暴的方式了,而且在UI发生变化时,也方便做一些调整。当然比较高级的Android玩家可能更喜欢去做一些标准的自定义控件,但我更推崇的是,在性能差别不大的情况下,使用最简单最快捷的方式去处理问题。
源码地址:http://git.oschina.net/thinkin/NumberEditText
转自我的oschina
网友评论