Android实现一个带清除和提交按钮的清爽圆角搜索框

运行效果:

放入Toolbar的效果 

 

 清除按钮有内容才显示:

 下面是教程:

实现一个圆角搜索框,可以使用CardView来实现,同时可以添加一个EditText和两个ImageView作为清除和提交按钮。

activity_main

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#1e90ff"
        android:padding="10dp"
        tools:context=".MainActivity">

    <androidx.cardview.widget.CardView
            android:id="@+id/search_edit"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:cardCornerRadius="16dp"
            tools:ignore="MissingConstraints"
            android:layout_marginTop="20dp">

        <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="horizontal">

            <EditText
                    android:id="@+id/search_edit_text"
                    android:layout_width="0dp"
                    android:layout_height="match_parent"
                    android:layout_weight="1"
                    android:background="@null"
                    android:hint="Search"
                    android:maxLines="1"
                    android:padding="8dp"
                    android:textSize="16sp"
                    android:drawableLeft="@drawable/ic_baseline_search_24"
                    android:drawablePadding="6dp"
                    />

            <ImageView
                    android:id="@+id/search_clear_button"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:padding="8dp"
                    android:src="@drawable/ic_baseline_clear_24"/>

            <ImageView
                    android:id="@+id/search_submit_button"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:padding="8dp"
                    android:src="@drawable/ic_baseline_search_24"/>

        </LinearLayout>

    </androidx.cardview.widget.CardView>


</androidx.constraintlayout.widget.ConstraintLayout>

其中,EditTextbackground设置为@null,使其没有边框,从而使CardView的边框成为搜索框的边框,同时设置android:padding来控制搜索框的内边距。

ImageViewsrc属性可以设置为自己定义的图标,如清除按钮和提交按钮的图标。

接下来,在代码中获取EditText、清除按钮和提交按钮,并为它们设置相应的事件监听:

 MainActivity

package com.example.round_search;

import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        final EditText searchEditText = findViewById(R.id.search_edit_text);
        ImageView searchClearButton = findViewById(R.id.search_clear_button);
        ImageView searchSubmitButton = findViewById(R.id.search_submit_button);

       // 为清除按钮设置点击事件监听器
        searchClearButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                searchEditText.setText("");
            }
        });

        // 为提交按钮设置点击事件监听器
        searchSubmitButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                String keyword = searchEditText.getText().toString();
                Toast.makeText(MainActivity.this,keyword,Toast.LENGTH_SHORT).show();
                searchEditText.setText("");
                // TODO: 处理搜索关键字
            }
        });
    }
}

原创,转载请注明出处

猜你喜欢

转载自blog.csdn.net/wh445306/article/details/130414032