android 实现 搜索保存历史记录功能

简介: android 实现 搜索保存历史记录功能

大家应该做这个功能 首先想到的是用AutoCompleteTextView 这个控件非常好用 ,而且代码写起来也是非常简单 而且还是自动匹配提示

image.png

具体实现方法:

代码实现:

<AutoCompleteTextView 
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:id="@+id/autotext"
    />
public class MainActivity extends Activity {
private AutoCompleteTextView autotext;
private ArrayAdapter<String> arrayAdapter;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.test);
        autotext =(AutoCompleteTextView) findViewById(R.id.autotext);
        String [] arr={"aa","aab","aac"};
        arrayAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1,arr);
        autotext.setAdapter(arrayAdapter);
    }
}

这样就可以实现简单的 搜索历史匹配 我们要做的 其实就是缓存输入的内容到 本地 下面就是实现保存 搜索内容到本地 和 清空本地历史的 方法


//保存搜索内容到本地

<pre name="code" class="java">public void save() {
    String text = mKeywordEt.getText().toString();
    String oldText = mSharePreference.getString(SEARCH_HISTORY, "");
    StringBuilder builder = new StringBuilder(text);
    builder.append("," + oldText);
    if (!TextUtils.isEmpty(text) && !oldText.contains(text + ",")) {
        SharedPreferences.Editor myEditor = mSharePreference.edit();
        myEditor.putString(SEARCH_HISTORY, builder.toString());
        myEditor.commit();
    }
    updateData();
}
//清空本地历史
public void cleanHistory() {
    SharedPreferences.Editor editor = mSharePreference.edit();
    editor.clear();
    editor.commit();
    updateData();
    mSearchHistoryLl.setVisibility(View.GONE);
    SingleToast.show(this, getString(R.string.clear_history_success), Toast.LENGTH_SHORT);
}

Ps:AutoCompleteTextView 还有一个小问题  默认是从第二个字符开始匹配的

如果设置输入第一个字符就进行提示 加入下面这行代码autotext.setThreshold(1);

上面大概介绍了一下AutoCompleteTextView这个控件。但是我们的项目要做的是 显示出所有搜索的历史记录 效果图是这样的


image.pngimage.png

image.png

想了一下 用 AutoCompleteTextView 不太合适  决定自己用listView 实现  话不多说 直接上代码

下拉弹出layout布局

<LinearLayout
        android:id="@+id/search_history_ll"
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_below="@id/global_search_action_bar_rl"
        android:layout_height="wrap_content">
        <TextView
            android:id="@+id/contentTextView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="@dimen/text_size_title_h2"
            android:text="@string/search_history"
            android:paddingLeft="10dp"
            android:textColor="@color/text_gray"/>
        <ListView
            android:id="@+id/search_history_lv"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:cacheColorHint="@android:color/transparent"
            android:listSelector="@drawable/list_item_selector">
        </ListView>
        <Button
            android:id="@+id/clear_history_btn"
            android:layout_width="210dp"
            android:layout_height="@dimen/button_common_height"
            android:layout_below="@id/rise_crash_ll"
            android:layout_marginTop="5dp"
            android:textColor="@color/text_btn_selector"
            android:layout_gravity="center"
            android:textSize="@dimen/text_size_title_h2"
            android:layout_centerHorizontal="true"
            android:text="@string/clear_search_history"
            android:background="@drawable/round_btn_selector"
            style="?android:buttonBarButtonStyle"/>
    </LinearLayout>
activity 的代码
import android.content.SharedPreferences;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextUtils;
import android.text.TextWatcher;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import com.ccvideo.R;
import com.yizhibo.video.adapter.SearchAdapter;
import com.yizhibo.video.app.YZBApplication;
import com.yizhibo.video.base.BaseListActivity;
import com.yizhibo.video.utils.Constants;
import com.yizhibo.video.utils.SingleToast;
import com.yizhibo.video.utils.Utils;
public class SearchListActivity extends BaseListActivity implements View.OnClickListener {
    public static final String EXTRA_KEY_TYPE = "extra_key_type";
    private static final String PRE_SEARCH_HISTORY = "pre_search_history";
    private static final String SEARCH_HISTORY = "search_history";
    private EditText mKeywordEt;
    private TextView mOperationTv;
    private ArrayAdapter<String> mArrAdapter;
    private SharedPreferences mSharePreference;
    private LinearLayout mSearchHistoryLl;
      private List<String> mHistoryKeywords;
    private ListView mListView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mSharePreference = YZBApplication.getApp().getSharedPreferences(PRE_SEARCH_HISTORY, 0);
        setContentView(R.layout.activity_search_list);
        mKeywordEt = (EditText) findViewById(R.id.tab_bar_keyword_et);
mHistoryKeywords = new ArrayList<String>();
       mKeywordEt.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.length() == 0) {
                    mAdapter.clear();
                    mAdapter.notifyDataSetChanged();
                    mOperationTv.setText(R.string.cancel);
                    mEmptyView.hide();
                    clearKeywordIv.setVisibility(View.GONE);
                    if (mHistoryKeywords.size() > 0) {
                        mSearchHistoryLl.setVisibility(View.VISIBLE);
                    } else {
                        mSearchHistoryLl.setVisibility(View.GONE);
                    }
                } else {
                    mSearchHistoryLl.setVisibility(View.GONE);
                    mOperationTv.setText(R.string.search);
                    clearKeywordIv.setVisibility(View.VISIBLE);
                }
            }
            @Override
            public void afterTextChanged(Editable s) {
            }
        });
        mKeywordEt.requestFocus();
        mOperationTv = (TextView) findViewById(R.id.tab_bar_cancel_tv);
        mOperationTv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (mKeywordEt.getText().length() > 0) {
                    hideInputMethod();
                    save();
                } else {
                    finish();
                }
            }
        });
        initSearchHistory();
    }
   public void initSearchHistory() {
        mSearchHistoryLl = (LinearLayout) findViewById(R.id.search_history_ll);
        ListView listView = (ListView) findViewById(R.id.search_history_lv);
        findViewById(R.id.clear_history_btn).setOnClickListener(this);
        String history = mPref.getString(Preferences.KEY_SEARCH_HISTORY_KEYWORD);
        if (!TextUtils.isEmpty(history)){
            List<String> list = new ArrayList<String>();
            for(Object o : history.split(",")) {
                list.add((String)o);
            }
            mHistoryKeywords = list;
        }
        if (mHistoryKeywords.size() > 0) {
            mSearchHistoryLl.setVisibility(View.VISIBLE);
        } else {
            mSearchHistoryLl.setVisibility(View.GONE);
        }
        mArrAdapter = new ArrayAdapter<String>(this, R.layout.item_search_history, mHistoryKeywords);
        listView.setAdapter(mArrAdapter);
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
                mKeywordEt.setText(mHistoryKeywords.get(i));
                mSearchHistoryLl.setVisibility(View.GONE);
            }
        });
        mArrAdapter.notifyDataSetChanged();
    }
    public void save() {
        String text = mKeywordEt.getText().toString();
        String oldText = mPref.getString(Preferences.KEY_SEARCH_HISTORY_KEYWORD);
        if (!TextUtils.isEmpty(text) && !oldText.contains(text)) {
            mPref.putString(Preferences.KEY_SEARCH_HISTORY_KEYWORD, text + "," + oldText);
            mHistoryKeywords.add(0,text);
        }
        mArrAdapter.notifyDataSetChanged();
    }
  public void cleanHistory() {
        mPref.remove(Preferences.KEY_SEARCH_HISTORY_KEYWORD);
        mHistoryKeywords.clear();
        mArrAdapter.notifyDataSetChanged();
        mSearchHistoryLl.setVisibility(View.GONE);
        SingleToast.show(this, getString(R.string.clear_history_success), Toast.LENGTH_SHORT);
    }
    public void updateData(){
        String history = mSharePreference.getString(SEARCH_HISTORY, "");
        mHistoryArr = history.split(",");
        mArrAdapter = new ArrayAdapter<String>(this,
                R.layout.activity_searchhistory, mHistoryArr);
        mListView.setAdapter(mArrAdapter);
        mArrAdapter.notifyDataSetChanged();
    }
    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.clear_history_btn:
                cleanHistory();
                break;
        }
    }
}

之前的这个demo里面少了share  commit的操作,导致会有搜索记录没有去重的问题,已经更新。附上新的源码下载地址  源码demo  ,同时谢谢ysc123shift同学的善意提醒!做技术互相帮助和分享很重要。谢谢!

相关文章
|
2月前
|
Android开发
Android开发表情emoji功能开发
本文介绍了一种在Android应用中实现emoji表情功能的方法,通过将图片与表情字符对应,实现在`TextView`中的正常显示。示例代码展示了如何使用自定义适配器加载emoji表情,并在编辑框中输入或删除表情。项目包含完整的源码结构,可作为开发参考。视频演示和源码详情见文章内链接。
74 4
Android开发表情emoji功能开发
|
2月前
|
安全 Android开发 iOS开发
Android vs iOS:探索移动操作系统的设计与功能差异###
【10月更文挑战第20天】 本文深入分析了Android和iOS两个主流移动操作系统在设计哲学、用户体验、技术架构等方面的显著差异。通过对比,揭示了这两种系统各自的独特优势与局限性,并探讨了它们如何塑造了我们的数字生活方式。无论你是开发者还是普通用户,理解这些差异都有助于更好地选择和使用你的移动设备。 ###
55 3
|
4月前
|
编解码 测试技术 Android开发
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
本文详细介绍了如何利用CameraX库实现高质量的照片及视频拍摄功能,包括添加依赖、初始化、权限请求、配置预览与捕获等关键步骤。此外,还特别针对不同分辨率和帧率的视频拍摄提供了性能优化策略,确保应用既高效又稳定。
414 1
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
|
3月前
|
Android开发 开发者
Android平台无纸化同屏如何实现实时录像功能
Android平台无纸化同屏,如果需要本地录像的话,实现难度不大,只要复用之前开发的录像模块的就可以,对我们来说,同屏采集这块,只是数据源不同而已,如果是自采集的其他数据,我们一样可以编码录像。
|
4月前
|
图形学 Android开发
小功能⭐️Unity调用Android常用事件
小功能⭐️Unity调用Android常用事件
|
6月前
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
270 2
|
6月前
|
Android开发
Android中如何快速的实现RecycleView的拖动重排序功能
使用`ItemTouchHelper`和自定义`Callback`,在`RecyclerView`中实现拖动排序功能。定义`ItemTouchHelperAdapter`接口,`Adapter`实现它以处理`onItemMove`方法。`SimpleItemTouchHelperCallback`设置拖动标志,如`LEFT`或`RIGHT`(水平拖动),并绑定到`RecyclerView`以启用拖动。完成这些步骤后,即可实现拖放排序。关注公众号“AntDream”获取更多内容。
126 3
|
7月前
|
移动开发 监控 Android开发
构建高效Android应用:从内存优化到电池寿命代码之美:从功能实现到艺术创作
【5月更文挑战第28天】 在移动开发领域,特别是针对Android系统,性能优化始终是关键议题之一。本文深入探讨了如何通过细致的内存管理和电池使用策略,提升Android应用的运行效率和用户体验。文章不仅涵盖了现代Android设备上常见的内存泄漏问题,还提出了有效的解决方案,包括代码级优化和使用工具进行诊断。同时,文中也详细阐述了如何通过减少不必要的后台服务、合理管理设备唤醒锁以及优化网络调用等手段延长应用的电池续航时间。这些方法和技术旨在帮助开发者构建更加健壮、高效的Android应用程序。
|
7月前
|
Android开发 数据安全/隐私保护 iOS开发
ios和安卓测试包发布网站http://fir.im的注册与常用功能
ios和安卓测试包发布网站http://fir.im的注册与常用功能
319 0
ios和安卓测试包发布网站http://fir.im的注册与常用功能
|
6月前
|
存储 数据库 Android开发
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
215 0