zoukankan      html  css  js  c++  java
  • Android开发第六讲EditText 编辑框

    Android开发第六讲EditText 编辑框

    一丶EditText编辑框属性

    EditText 继承自 TextView 所以它的属性我们可以使用. TextView不支持文字的编辑.而EditText支持文字的编辑.

    那么说一下常用的属性吧

    android:hint = "提示文字"   加上这个编辑框会提示你要输入的文字
    android:inputType="textPassworld" 加上这个,表示编辑框输入的时候文字是密文密码形式
    android:inputType 可以规定编辑框输入的各种形式.比如密码形式 指定输入数字等.
    android:drawableleft 可以给编辑框加图片.这样可以做一个很好的登录框
    

    使用常用属性配合Button做一个登录框,并且给Button添加监听事件响应消息.

    Xml如下

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".EdtActive">
    <!--设置用户名提示框-->
        <EditText
            android:id="@+id/EdtView1"
            android:layout_width="match_parent"
            android:layout_height="50dp"
            android:hint="请输入用户名"
            android:maxLines="1"
            android:singleLine="true"
            android:paddingLeft="15dp"
            android:background="@drawable/btn_shape1"
            android:layout_marginTop="50dp"
            android:drawableLeft="@drawable/user"
            android:textSize="20sp">
    
        </EditText>
    
    
        <!--设置密码提示框-->
        <EditText
            android:id="@+id/EdtView2"
            android:layout_width="match_parent"
            android:layout_height="50dp"
            android:hint="请输入密码"
            android:paddingLeft="15dp"
            android:background="@drawable/btn_shape1"
            android:inputType="textPassword"
            android:layout_below="@id/EdtView1"
            android:layout_marginTop="10dp"
            android:drawableLeft="@drawable/lock"
            android:drawablePadding="10dp"
            android:textSize="20sp">
    
        </EditText>
    <!--创建按钮-->
        <Button
            android:id="@+id/btn_login"
            android:layout_below="@id/EdtView2"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="10dp"
            android:textSize="30sp"
            android:text="登录"
            android:background="@drawable/btn_4"
            android:textColor="#ffff00">
    
        </Button>
    </RelativeLayout>
    

    其中我使用了user图片以及 lock图片.这个可以在网址上找到. 下载32*32资源即可.

    https://www.flaticon.com/search?word=user

    然后使用之前的 状态选择器布局.

    状态选择器 布局如下

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!--    状态选择器 android:state_pressed = true代表按压-->
        <item android:state_pressed="true">
    <!--        如果是按压,那么我们使用shape画一个-->
            <shape>
    <!--            设置实心颜色,并且设置圆角-->
                <solid android:color="#ff0000"></solid>
                <corners android:radius="10dp"></corners>
            </shape>
        </item>
    
    <!--    否则设置为绿色-->
        <item android:state_pressed="false">
            <!--        如果是按压,那么我们使用shape画一个-->
            <shape>
                <!--            设置实心颜色,并且设置圆角-->
                <solid android:color="#0ca30c"></solid>
                <corners android:radius="10dp"></corners>
            </shape>
        </item>
    </selector>
    

    最后实现按钮点击事件

    package com.ibinary.myapplication;
    
    import androidx.appcompat.app.AppCompatActivity;
    
    import android.os.Bundle;
    import android.view.View;
    import android.widget.Button;
    import android.widget.Toast;
    
    public class EdtActive extends AppCompatActivity {
    
    //    响应按钮事件
        private Button m_Login;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_edt_active);
            m_Login = (Button) findViewById(R.id.btn_login);
            m_Login.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Toast.makeText(EdtActive.this, "登录成功", Toast.LENGTH_SHORT).show();
                }
            });
        }
    }
    

    你的Button是定义在EdtView中的.所以我们的代码要写在 EdtActive.java中

    效果如下

    按钮提示文字 分别是请输入用户名 以及请输入密码. 而且都加了图标.

    登录按钮加了状态选择器

    点击登录提示登录成功

    二丶编辑框响应监听事件

    响应监听事件就需要写代码了.

    响应的是 编辑框的 addTextChangedListener

    代码如下

    package com.ibinary.myapplication;
    
    import androidx.appcompat.app.AppCompatActivity;
    
    import android.os.Bundle;
    import android.text.Editable;
    import android.text.TextWatcher;
    import android.util.Log;
    import android.view.View;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.Toast;
    
    public class EdtActive extends AppCompatActivity {
    
    //    响应按钮事件
        private Button m_Login;
        private EditText m_EdtUser;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_edt_active);
            m_Login = (Button) findViewById(R.id.btn_login);
            m_Login.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Toast.makeText(EdtActive.this, "登录成功", Toast.LENGTH_SHORT).show();
                }
            });
    
            m_EdtUser = (EditText)findViewById(R.id.EdtView1);
            m_EdtUser.addTextChangedListener(new TextWatcher() {
                //三个方法,分别是 在修改之前监听 在修改之中监听 以及在修改之后监听
                @Override
                public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {
    
                }
    
                @Override
                public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                    //CharSequence 参数1是我们输入的字符.可以在调试输出窗口中数据
                    Log.d("EditText = ", charSequence.toString());
                }
    
                @Override
                public void afterTextChanged(Editable editable) {
    
                }
            });
        }
    }
    

    在修改中输出消息.可以在Android Studio的日志窗口中看到

    至此基本的ExitText属性就到这

  • 相关阅读:
    Windows Server 2008 R2 免费使用 7200天 激活
    ceph部署步骤
    for循环间隔修改(解决把以空格隔开需要把一整行作为整体)
    my_learn
    fiddler-抓包
    基础软件搭建
    【原创】一层Nginx反向代理K8S化部署实践
    【原创】K8S使用ceph-csi持久化存储之CephFS
    【原创】K8S使用ceph-csi持久化存储之RBD
    [原创]自动化部署K8S(v1.10.11)集群
  • 原文地址:https://www.cnblogs.com/iBinary/p/13585700.html
Copyright © 2011-2022 走看看