最近在搞Android项目,之前并没有系统的去学过这方面的编程,只能边看书边撸代码。在项目的开发的过程中,需要一个IP控件,后面了解到Android中并没有这样的控件,于是网上搜索,发现得到的结果并不符合我的需求,于是我根据网上已有的完善了一下这个自定义控件,记录在此,方便下次再用,也希望能给你们留下一点帮助。

一、IP控件布局

IP控件的布局很简单,四个EditText和三个TextView组合而成的,

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="200dp"
android:layout_gravity="left"
android:layout_height="30dp"
android:background="#f2f2f2"
android:focusable="true"
android:focusableInTouchMode="true"> <EditText
android:id="@+id/Fist_Text"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:layout_gravity="center"
android:gravity="center"
android:inputType="numberDecimal"
android:background="#FFFFFF"
android:textColor="#4f4f4f"
android:textCursorDrawable="@drawable/cursor_color"/> <TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="center"
android:gravity="bottom"
android:textStyle="bold"
android:text="."
android:background="#FFFFFF"/> <EditText
android:id="@+id/Second_Text"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:layout_gravity="center"
android:gravity="center"
android:inputType="numberDecimal"
android:background="#FFFFFF"
android:textColor="#4f4f4f"
android:textCursorDrawable="@drawable/cursor_color"/> <TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="center"
android:gravity="bottom"
android:textStyle="bold"
android:text="."
android:background="#FFFFFF"/> <EditText
android:id="@+id/Third_Text"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="center"
android:inputType="numberDecimal"
android:background="#FFFFFF"
android:textColor="#4f4f4f"
android:textCursorDrawable="@drawable/cursor_color"/> <TextView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="center"
android:gravity="bottom"
android:textStyle="bold"
android:text="."
android:background="#FFFFFF"/> <EditText
android:id="@+id/Four_Text"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_gravity="center"
android:layout_weight="1"
android:gravity="center"
android:inputType="numberDecimal"
android:background="#FFFFFF"
android:textColor="#4f4f4f"
android:textCursorDrawable="@drawable/cursor_color"/> </LinearLayout>

二、IP逻辑实现

我们平时常用的ip控件的每个文本框内容范围都是0~255,而且当其中一个文本框内容已经是三位数或者输入“.”时,则会自动跳转到下一个文本框中。另外当我们删除文本内容,当文本内容为空时,则会自动跳转到上一个文本框中。所以这是我们实现ip控件需要注意的地方。

下面是具体实现代码

public class IPEditText extends LinearLayout {

    private EditText firIPEdit;
private EditText secIPEdit;
private EditText thirIPEdit;
private EditText fourIPEdit; private String firstIP ="";
private String secondIP="";
private String thirdIP="";
private String fourthIP=""; public IPEditText(Context context, AttributeSet attributeSet) {
super(context, attributeSet);
View view = LayoutInflater.from(context).inflate(R.layout.ip_text_layout, this); firIPEdit = (EditText) findViewById(R.id.Fist_Text);
secIPEdit = (EditText) findViewById(R.id.Second_Text);
thirIPEdit = (EditText) findViewById(R.id.Third_Text);
fourIPEdit = (EditText) findViewById(R.id.Four_Text); setIPEditTextListener(context);
} public void setIPEditTextListener(final Context context) {
//设置第一个IP字段的事件监听
firIPEdit.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if(s.toString().trim().equals(".")){
firstIP = "";
return;
}
if(s.length() > 2 || s.toString().trim().contains(".")){
if(s.toString().trim().contains(".")){
firstIP = s.toString().trim().substring(0, s.length() - 1);
}else {
firstIP = s.toString().trim();
}
if(Integer.parseInt(firstIP) > 255){
firstIP = "255";
}
secIPEdit.setFocusable(true);
secIPEdit.requestFocus(); }else {
firstIP = s.toString().trim();
}
} @Override
public void afterTextChanged(Editable s) {
firIPEdit.removeTextChangedListener(this);
firIPEdit.setText(firstIP);
firIPEdit.setSelection(firIPEdit.length());
firIPEdit.addTextChangedListener(this);
}
});
//设置第二个IP字段的事件监听
secIPEdit.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
//若长度为0,返回到上一个文本编辑框
if(s.toString().length() == 0){
firIPEdit.setFocusable(true);
firIPEdit.requestFocus();
}
if(s.toString().trim().equals(".")){
secondIP = "";
return;
}
if(s.length() > 2 || s.toString().trim().contains(".")){
if(s.toString().trim().contains(".")){
secondIP = s.toString().trim().substring(0, s.length() - 1);
}else {
secondIP = s.toString().trim();
}
if(Integer.parseInt(secondIP) > 255){
secondIP = "255";
}
thirIPEdit.setFocusable(true);
thirIPEdit.requestFocus();
}else {
secondIP = s.toString().trim();
}
} @Override
public void afterTextChanged(Editable s) {
secIPEdit.removeTextChangedListener(this);
secIPEdit.setText(secondIP);
secIPEdit.setSelection(secondIP.length());
secIPEdit.addTextChangedListener(this);
}
}); //设置第三个IP字段的事件监听
thirIPEdit.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if(s.toString().length() == 0){
secIPEdit.setFocusable(true);
secIPEdit.requestFocus();
}
if(s.toString().trim().equals(".")){
thirdIP = "";
return;
}
if(s.length() > 2 || s.toString().trim().contains(".")){
if(s.toString().trim().contains(".")){
thirdIP = s.toString().trim().substring(0, s.length() - 1);
}else {
thirdIP = s.toString().trim();
}
if(Integer.parseInt(thirdIP) > 255){
thirdIP = "255";
}
fourIPEdit.setFocusable(true);
fourIPEdit.requestFocus();
}else {
thirdIP = s.toString().trim();
}
} @Override
public void afterTextChanged(Editable s) {
thirIPEdit.removeTextChangedListener(this);
thirIPEdit.setText(thirdIP);
thirIPEdit.setSelection(thirdIP.length());
thirIPEdit.addTextChangedListener(this);
}
}); //设置第四个IP字段的事件监听
fourIPEdit.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
if(s.toString().length() == 0){
thirIPEdit.setFocusable(true);
thirIPEdit.requestFocus();
}
if(s.toString().trim().equals(".")){
fourthIP = "";
return;
}
if(s.length() > 2 || s.toString().trim().contains(".")){
if(s.toString().trim().contains(".")){
fourthIP = s.toString().trim().substring(0, s.length() - 1);
}else {
fourthIP = s.toString().trim();
}
if(Integer.parseInt(fourthIP) > 255){
fourthIP = "255";
}
}else {
fourthIP = s.toString().trim();
}
} @Override
public void afterTextChanged(Editable s) {
fourIPEdit.removeTextChangedListener(this);
fourIPEdit.setText(fourthIP);
fourIPEdit.setSelection(fourthIP.length());
fourIPEdit.addTextChangedListener(this);
}
});
} /**
* 返回整个ip地址
* @return
*/
public String getIpText(){
if(TextUtils.isEmpty(firstIP) || TextUtils.isEmpty(secondIP)
|| TextUtils.isEmpty(thirdIP) || TextUtils.isEmpty(fourthIP)){
return null;
}
return firstIP + "." + secondIP + "." + thirdIP + "." + fourthIP;
} /**
* 本地读取的ip地址显示至界面
* @param ipText
*/
public void setIpText(String ipText){
if(TextUtils.isEmpty(ipText) || ipText == null){
return;
}
String[] temp = null;
temp = ipText.split("\\.");
if(temp != null){
firIPEdit.setText(temp[0]);
secIPEdit.setText(temp[1]);
thirIPEdit.setText(temp[2]);
fourIPEdit.setText(temp[3]);
}
}
}

三、控件演示

下载源码

Android中自定义IP控件的更多相关文章

  1. Android中自定义组合控件

    Android中自定义控件的情况非常多,一般自定义控件可以分为两种:继承控件及组合控件.前者是通过继承View或其子类,重写方法实现自定义的显示及事件处理方式:后者是通过组合已有的控件,来实现结构的简 ...

  2. android中的EditView控件

    android中的EditView控件 EditText继承关系:View-->TextView-->EditText ,EditText是可编辑文本框 1.EditText默认情况下,光 ...

  3. C#自定义ip控件

    前言:由于项目中有ip输入,但C#中又没有IP控件,如果直接放4个TextBox感觉又怎么好,还不好控制,于是可以通过自定义控件的方式来解决,就又了下面的自定义ip控件,该控件功能基本完善,如果还有未 ...

  4. Android中通过WebView控件实现与JavaScript方法相互调用的地图应用

    在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavascriptInterface方法,这样html才能调用andro ...

  5. Android Studio自定义组合控件

    在Android的开发中,为了能够服用代码,会把有一定共有特点的控件组合在一起定义成一个自定义组合控件. 本文就详细讲述这一过程.虽然这样的View的组合有一个粒度的问题.粒度太大了无法复用,粒度太小 ...

  6. android中的TextView控件

    我以前是搞ssh开发的,现在在搞android开发,所以简单学习了一下,对于自己所了解的做一个记录,也算是一个笔记吧,如果有什么不对的,希望大家给予一定的指导.  一.TextView的基本使用 Te ...

  7. asp.net中自定义验证控件

    在windows2003中,可能iis版本太底,不支持TextBox的类型设为Number类型,所以会报错,所以去掉后直接用验证控件来控制必须输入数字好了. <asp:RegularExpres ...

  8. android中去掉ListView控件中的分割线

    通过设置android:divider="@null" ,可以去掉ListView控件中的分割线 也可以自定义分割线的颜色,比如: <ListView android:id= ...

  9. Android中动态改变控件的大小的一种方法

    在Android中有时候我们需要动态改变控件的大小.有几种办法可以实现  一是在onMeasure中修改尺寸,二是在onLayout中修改位置和尺寸.这个是可以进行位置修改的,onMeasure不行. ...

随机推荐

  1. RecyclerFullyManagerDemo【ScrollView里嵌套Recycleview的自适应高度功能】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 对于Recyclerview自己的LinearLayoutManager和GridLayoutManager,在版本23.2.0之后 ...

  2. Spring Boot 2.x 系列教程:WebFlux REST API 全局异常处理 Error Handling

    摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 本文内容 为什么要全局异常处理? WebFlux REST 全 ...

  3. Reactor 典型的 NIO 编程模型

    Doug Lea 在 Scalable IO in Java 的 PPT 中描述了 Reactor 编程模型的思想,大部分 NIO 框架和一些中间件的 NIO 编程都与它一样或是它的变体.本文结合 P ...

  4. Do you have an English name? 你有英文名吗?

    文中提到的所有人名都是虚构的,如有雷同,纯属巧合. 当然,你的洋名儿也可能是德文.法文.意大利文,等々々々. 全球化时代,和老外的交流也多了."高端"的程序员想要进欧美系外企,想要 ...

  5. 在线生成二维码的API接口

    现在很多大网站都有这样的一个功能,使用手机扫描一下网页上的二维码便可快速在手机上访问网站.想要实现这样的功能其实很简单,下面麦布分享几个在线生成网址二维码的API接口.都是采用http协议接口,无需下 ...

  6. Jquer + Ajax 制作上传图片文件

    没什么 说的  直接 上代码 //选择图片并上传 function selectImg(node){ var f = node.value; var file = node.files[0]; if( ...

  7. c# Lambda操作类封装

    using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; us ...

  8. 大数据---Ranger-1

    背景:从软通出来,告别华为外包,离开H区,进入了一家搞大数据的创业公司,感觉周围都好陌生,记录下自己大数据的career! 2019-03-4新的征程-入职第一天: 一.办理入职手续 公司人比较少,没 ...

  9. Mac电脑 怎么导出安卓手机的相册

    1.mac上下载一个HandShaker 2.把电脑和手机设置在同一个wifi下 3.安卓手机上下载一个HandShaker 参考:https://zhidao.baidu.com/question/ ...

  10. swing Jframe 界面风格

    用法:在jframe里面 UIManager.setLookAndFeel("com.sun.java.swing.plaf.windows.WindowsLookAndFeel" ...