AutoCompleteTextView和Scroll

2024-08-30 01:32

本文主要是介绍AutoCompleteTextView和Scroll,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

AutoCompleteTextVIew MultiAutoCompleteTextView

最简单的使用

xml布局文件

    <!--completionThreshold : 提示几个completionHint : 自动补全 (--><AutoCompleteTextView
        android:id="@+id/main_auto"android:completionHint="自动补全"android:completionThreshold="1"android:layout_width="match_parent"android:layout_height="wrap_content" />

Activity.java

List<String> list = new ArrayList<>();
list.add("北京");
list.add("上海");
list.add("广东");
list.add("上海");
list.add("上海");
list.add("上海");
list.add("山东");
list.add("山东");
list.add("山东");
ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, list);
AutoCompleteTextView auto= (AutoCompleteTextView) findViewById(R.id.main_auto);
auto.setAdapter(adapter);

自定义拼音, 自动补全

布局文件还是使用上面的

写个实体类, 还有文字和相应的拼音

public class Entry {private String text;//显示的数据private String pinyin;//过滤的数据public Entry(String text, String pinyin) {this.text = text;this.pinyin = pinyin;}public String getText() {return text;}public void setText(String text) {this.text = text;}public String getPinyin() {return pinyin;}public void setPinyin(String pinyin) {this.pinyin = pinyin;}@Overridepublic String toString() {return text;}
}

AutoActivity.java

此处需要注意: public < T extends ListAdapter & Filterable > void setAdapter(T adapter)
这就说明这个适配器, 在需要ListAdapter和Filterable, 所以应该像下面这样写:

package com.lulu.day23;import android.content.Context;
import android.text.TextUtils;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Filter;
import android.widget.Filterable;
import android.widget.TextView;import java.util.ArrayList;
import java.util.Collection;
import java.util.List;/*** Created by Lulu on 2016/8/27.** Filterable: 过滤器*/
public class AutoAdapter extends BaseAdapter implements Filterable {//所有跟画面相关的都需要一个contextprivate Context context;private List<Entry> list;private List<Entry> backup;private Filter filter;public AutoAdapter(Context context, List<Entry> list) {this.context = context;this.list = list;}@Overridepublic int getCount() {return list.size();}//得到数据源中的一条数据@Overridepublic Object getItem(int position) {return list.get(position);}//返回当前ID@Overridepublic long getItemId(int position) {return position;}//指定位置的元素该如何展示在view上@Overridepublic View getView(int position, View convertView, ViewGroup parent) {if (convertView == null) {convertView = new TextView(context);}((TextView) convertView).setText(list.get(position).getText());return convertView;}@Overridepublic Filter getFilter() {if (filter == null) {filter = new AutoFilter();}return filter;}/**过滤* 一定要用非静态的内部类*/public class AutoFilter extends Filter{@Override//产生过滤结果protected FilterResults performFiltering(CharSequence constraint) {if (backup == null) {backup = new ArrayList<>(list);}FilterResults results = new FilterResults();if (!TextUtils.isEmpty(constraint)) {List<Entry> entries = new ArrayList<>();for (Entry  entry: backup) {String pinyin = entry.getPinyin();if (pinyin.startsWith(constraint.toString())) {entries.add(entry);}}results.count = entries.size();results.values = entries;} else {results.count = 0;results.values = new ArrayList<>();}return results;}@Overrideprotected void publishResults(CharSequence constraint, FilterResults results) {list.clear();list.addAll((Collection<? extends Entry>) results.values);notifyDataSetChanged();}}}

MainActivity.java

 List<Entry> list = new ArrayList<>();list.add(new Entry("北京", "beijing"));list.add(new Entry("上海", "shanghai"));list.add(new Entry("广东", "guangdong"));list.add(new Entry("", "shandong"));list.add(new Entry("上海", "shagnhai"));list.add(new Entry("上海", "shagnhai"));AutoAdapter adapter = new AutoAdapter(this, list);AutoCompleteTextView auto = (AutoCompleteTextView) findViewById(R.id.main_auto);auto.setAdapter(adapter);

使用第三方包来实现拼音自动补全

使用的第三方的名字为: com.github.stuxuhai:jpinyin:1.1.7, 需要手动引入

PinyinAdapter.java

package com.lulu.day23;import android.content.Context;
import android.text.TextUtils;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Filter;
import android.widget.Filterable;
import android.widget.TextView;import com.github.stuxuhai.jpinyin.PinyinException;
import com.github.stuxuhai.jpinyin.PinyinFormat;
import com.github.stuxuhai.jpinyin.PinyinHelper;import java.util.ArrayList;
import java.util.Collection;
import java.util.List;/*** Created by Lulu on 2016/8/27.*/
public class PinyinAdapter extends BaseAdapter implements Filterable {private Context context;private List<String> list;private List<String> backup;private Filter filter;public PinyinAdapter(Context context, List<String> list) {this.context = context;this.list = list;}@Overridepublic int getCount() {return list.size();}@Overridepublic Object getItem(int position) {return list.get(position);}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {if (convertView == null) {convertView = new TextView(context);}((TextView) convertView).setText(list.get(position));return convertView;}@Overridepublic Filter getFilter() {if (filter == null) {filter = new PinyinFilter();}return filter;}private class PinyinFilter extends Filter {//必须要备份@Overrideprotected FilterResults performFiltering(CharSequence constraint) {if (backup == null) {backup = new ArrayList<>(list);}FilterResults results = new FilterResults();if (!TextUtils.isEmpty(constraint)) {List<String> strings = new ArrayList<>();for (String str : backup) {try {String pinyin = PinyinHelper.convertToPinyinString(str, "", PinyinFormat.WITH_TONE_MARK);if (pinyin.contains(constraint)) {strings.add(str);} else {String shortPinyin = PinyinHelper.getShortPinyin(str);if (shortPinyin.contains(constraint)) {strings.add(str);}}} catch (PinyinException e) {e.printStackTrace();}results.count = strings.size();results.values = strings;}} else {results.count = 0;results.values = new ArrayList<>();}return results;}@Overrideprotected void publishResults(CharSequence constraint, FilterResults results) {list.clear();list.addAll((Collection<? extends String>) results.values);notifyDataSetChanged();}}
}

MainActivity.java

 List<String> list = new ArrayList<>();list.add("北京");list.add("上海");list.add("广东");list.add("上海");list.add("上海");list.add("上海");list.add("山东");list.add("山东");list.add("山东");PinyinAdapter adapter = new PinyinAdapter(this, list);AutoCompleteTextView auto = (AutoCompleteTextView) findViewById(R.id.main_auto);auto.setAdapter(adapter);

简单的介绍一下MultiAutoCompleteTextView的使用方法

布局文件

   <!--可以补全多个词--><MultiAutoCompleteTextView
       android:completionThreshold="1"android:layout_centerInParent="true"android:id="@+id/mian_muti"android:layout_width="match_parent"android:layout_height="wrap_content" />

MainActivity.java

MultiAutoCompleteTextView multi = (MultiAutoCompleteTextView) findViewById(R.id.mian_muti);
multi.setAdapter(adapter);
MultiAutoCompleteTextView.CommaTokenizer tokenizer = new MultiAutoCompleteTextView.CommaTokenizer();
tokenizer.terminateToken(",");
multi.setTokenizer(tokenizer);

Scroll

同样的道理, 我们一般不会使用原生的Sroll而是使用v4包中的android.support.v4.widget.NestedScrollView

垂直滚动 - 固定表头滑动

继承自FrameLayout, 但是只能放一个子控件, 多个会报错
一般会放一个布局
如果有高度需求: 我们需要使用minHeight 只能给定值
scrollbars=”none: 将滚动条去掉
scrollbarStyle 在里面还是在外面
scrollbarTrackVertical:滚动框
scrollbarThumbVertical : 进度条样式
elevation : 海拔
有些控件默认有海拔, 所有要添加海拔高度覆盖
对于垂直方向来说, ScrollView中的子控件高度是无效的(都是根据父控件的高低来的, 高度未知)
若想在垂直方向有长度, 可以使用minHeight

先查看它的预览效果:

描述

xml 布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:paddingBottom="@dimen/activity_vertical_margin"android:paddingLeft="@dimen/activity_horizontal_margin"android:paddingRight="@dimen/activity_horizontal_margin"android:paddingTop="@dimen/activity_vertical_margin"tools:context="com.lulu.day23_scroll_lxy.MainActivity"><!--ScrollView继承自FrameLayout, 但是只能放一个子控件, 多个会报错一般会放一个布局ScrollView中的子控件高度是无效的(都是根据父控件的高低来的, 高度未知)如果有高度需求: 我们需要使用minHeight 只能给定值scrollbars="none: 将滚动条去掉scrollbarStyle 在里面还是在外面scrollbarTrackVertical:滚动框scrollbarThumbVertical : 进度条样式elevation : 海拔有些控件默认有海拔--><TextView
        android:elevation="5dp"android:text="@string/app_name"android:id="@+id/main_floating"android:textSize="30sp"android:background="#fff"android:layout_width="match_parent"android:layout_height="wrap_content" /><android.support.v4.widget.NestedScrollView
        android:id="@+id/main_scroll"android:layout_width="match_parent"android:layout_height="match_parent"android:scrollbarSize="10dp"android:scrollbars="vertical"><LinearLayout
            android:layout_width="match_parent"android:layout_height="match_parent"android:background="#f00"android:minHeight="400dp"android:orientation="vertical"><TextView
                android:background="#fff"android:text="第一组"android:textSize="30sp"android:layout_width="match_parent"android:layout_height="wrap_content" /><ImageView
                android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@mipmap/ic_launcher" /><ImageView
                android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@mipmap/ic_launcher" />...<TextView
                android:background="#fff"android:text="第八组"android:textSize="30sp"android:layout_width="match_parent"android:layout_height="wrap_content" /><ImageView
                android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@mipmap/ic_launcher" /></LinearLayout></android.support.v4.widget.NestedScrollView>
</RelativeLayout>

MainActivity.java

public class MainActivity extends AppCompatActivity implements NestedScrollView.OnScrollChangeListener{private NestedScrollView scrollView;private TextView floating;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);scrollView = (NestedScrollView) findViewById(R.id.main_scroll);floating = ((TextView) findViewById(R.id.main_floating));scrollView.setOnScrollChangeListener(this);floating.setText("第一组");}@Overridepublic void onScrollChange(NestedScrollView v, int scrollX, int scrollY, int oldScrollX, int oldScrollY) {//因为在ScrollVIew中包裹了一层LinerLayoutLinearLayout layout = (LinearLayout) v.getChildAt(0);//在屏幕上方外部最后一个(部分)TextView text1 = null;//在屏幕中的第一个(完全)TextView text2 = null;for (int i = 0; i < layout.getChildCount(); i++) {View view = layout.getChildAt(i);if(view.getTop() > scrollY) {if(view instanceof  TextView) {text2 = (TextView)view;}break;}if(view instanceof TextView) {text1 = (TextView) view;}}floating.setText(text1.getText());if (text2 != null) {int offset = text2.getTop() - scrollY;floating.setTranslationY(Math.min(offset - text2.getHeight(), 0));} else {floating.setTranslationY(0);}}
}

这篇关于AutoCompleteTextView和Scroll的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119415

相关文章

vue-seamless-scroll(二)点击事件

继上一篇文章vue-seamless-scroll(一)使用 在表格数据滚动的时候想要点击某一行获取当前行的数据,但是当数据在第二轮数据滚动的时候点击没有反应,获取不到数据,该怎么解决? 首先需要在父级添加一个点击事件,然后在这一行添加相同的类名,这样点击这一行就可以获取当前行的数据了 <template><div style="padding: 0 13px"><div class="it

滚动偏移量 scroll offset

滚动偏移量 scroll offset 一、获取滚动偏移量二、滚动事件性能三、使用场景 滚动偏移量(scroll offset):文档在垂直和水平方向上滚动的距离 一、获取滚动偏移量 // 获取上下滚动偏移量const scrollTop = window.pageYOffset || document.documentElement.scrollTop || docu

Elasticsearch 6.x升级7.x 版本Scroll

Trying to create too many scroll contexts. Must be less than or equal to: [500] 异常的描述是scroll快照太多,同时存在的context数量超过500导致异常 kibana命令清除 DELETE _search/scroll/_all JAVA逻辑清除 private RestHighLevelClient

vue3-scroll-seamless 大屏无缝滚动

npm install vue3-scroll-seamless --save//或者yarn add vue3-scroll-seamless 页面中引入 <template><div class="safety_item"><SoftwareHead title="高危及以上组件漏洞TOP10"></SoftwareHead><div class="table" v-if="data

uniapp scroll-view滚动页面

页面滚动固定距离(scrollTop) <template><view><button @click="Test">测试</button><scroll-view style="height: 100px;" :scroll-top="scrollTop" scroll-y="true" class="scroll-Y"><view style="height: 20px;box-sizing:

Harmony Scroll设置对齐方式

在开发鸿蒙应用的时候,如遇到一页内容显示不下就需要用到Scroll组件进行嵌套,让内容进行滚动能够全部显示。在Scroll嵌套的时候就会用到Column或Row容器组件,且Column或Row容器组件不能设置height或width属性,那么此时Scroll嵌套的内容默认就会居中显示,如何设置对齐方式呢,就需要用到align属性了 代码示例以嵌套Column为例 Scroll() {Colu

vue-seamless-scroll实现无缝上下滚动与左右滚动

vue-seamless-scroll实现无缝上下滚动与左右滚动 上下滚动与左右滚动是我们很常见的一个功能,利用vue-seamless-scroll可以实现上下滚动与左右滚动,其官方网站地址是https://www.npmjs.com/package/vue-seamless-scroll,可以查看其用法。首先查看一下效果图:  一、

【ElasticSearch】(七)浅析search_after 及 fromsize,scroll,search_after性能分析

一、"search_after"是什么?      “search_after”是用于查询的dsl,可以起到类似"from & size"分页作用的结构化查询,代码展示如下: GET twitter/_search{"size": 10,"query": {"match" : {"title" : "elasticsearch"}},"search_after": [1000],"sort"

【ElasticSearch】(六)浅析Scroll

【起因】        正常查某索引下全部数据的dsl举例如下: POST /fcar_city/city/_search?scroll=10m{"query": {"bool": {"must": [{"match_all": { }}]}}}        我的意图是把该索引下的全部数据查询出来,上述代码查询结果如下: {"_shards": {"total": 5,"failed

Vue学习笔记:vue-seamless-scroll滚动插件的使用

一、安装 npm install vue-seamless-scroll –save 二、在main.ts中全局挂载 import vueSeamlessScroll from 'vue-seamless-scroll'Vue.use(vueSeamlessScroll) 三、在要使用该插件的子组件中引入 import vueSeamlessScroll from "vue-seaml