最近在搞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. JS ES6的变量的结构赋值

    变量的结构赋值用户很多 1.交换变量的值 let x = 1; let y = 2; [x,y] = [y,x] 上面的代码交换变量x和变量y的值,这样的写法不仅简洁,易读,语义非常清晰 2.从函数返 ...

  2. 《前端之路》之四 JavaScript 的闭包、作用域、作用域链

    04:JavaScript 的闭包 一.定义: 常规定义: 闭包的定义: 有权利访问外部函数作用域的函数. 通俗定义: 1.函数内部包含了函数.然后内部函数可以访问外部函数的作用域. 2.内部函数可以 ...

  3. 微信小程序开发02-小程序基本介绍

    前言 前面我们研究了下微信小程序的执行流程,因为拿不到源码,只能算我们的猜想,我们需要更加了解小程序还需要做具体的项目,于是我们将原来那套还算复杂的业务拿出来: [组件化开发]前端进阶篇之如何编写可维 ...

  4. merge和rebase的区别

    前言 我从用git就一直用rebase,但是新的公司需要用merge命令,我不是很明白,所以查了一些资料,总结了下面的内容,如果有什么不妥的地方,还望指正,我一定虚心学习. merge和rebase ...

  5. Spring Boot 2.x基础教程:工程结构推荐

    Spring Boot框架本身并没有对工程结构有特别的要求,但是按照最佳实践的工程结构可以帮助我们减少可能会遇见的坑,尤其是Spring包扫描机制的存在,如果您使用最佳实践的工程结构,可以免去不少特殊 ...

  6. The openssl extension is required for SSL/TLS protection but is not available

    今天使用composer update发现报错:The openssl extension is required for SSL/TLS protection but is not availabl ...

  7. MySQL优化面试

    原则:尽量使用整型表示字符串 存储IP INET_ATON(str),address to number INET_NTOA(number),number to address MySQL内部的枚举类 ...

  8. Vmware安装CentOs7+gitlab(一)

    本篇文章主要介绍了VMware安装Centos7超详细过程(图文),具有一定的参考价值,感兴趣的小伙伴们可以参考一下 1.软硬件准备 软件:推荐使用VMwear,我用的是VMwear 12 镜像:Ce ...

  9. 设计模式系列13:模板方法模式(Template Method Pattern)

    定义 定义一个操作中的算法的骨架,而将一些步骤延迟到子类中.模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤.    --<设计模式GoF> UML类图 使用场景 有 ...

  10. winform 跨线程访问问题

    一.问题描述 进行winform 开发我们在进行数据交换时避免不了使用多线程或异步方法,这样操作也将避免不了跨线程对控件进行操作(赋值.修改属性). 下面通过一个测试说明一下问题 点击一个按钮异步对t ...