笔记:Android AutoComplete TextView创建提供自动完成提示功能的文本字段控件

AutoComplete TextView
在布局文件中加入

   <AutoCompleteTextView
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       android:completionThreshold="1"			//设置输入1个字符时显示自动提示
       android:id="@+id/auto"/>

在res/values/string.xml中定义自动完成提示功能字符串数组资源

<resources>
    <string name="app_name">name_text</string>
    <string-array name="select_array">
        <item>cable</item>
        <item>come</item>
        <item>check</item>
        <item>China</item>
        <item>adsd</item>
        <item>武汉</item>
    </string-array>
</resources>

在java文件中绑定适配器

        AutoCompleteTextView auto= findViewById(R.id.auto);
        String [] selects = getResources().getStringArray(R.array.select_array);
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,selects);
        auto.setAdapter(adapter);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误提示是因为在你的代码中没有定义 `::ttk::Autocomplete::PopdownWindow` 这个命令。为了解决这个问题,可以在你的程序中添加自动补全的实现代码,例如: ``` import tkinter as tk from tkinter import ttk class AutocompleteCombobox(ttk.Combobox): def set_completion_list(self, completion_list): self._completion_list = completion_list self._hits = [] self._hit_index = 0 self.position = 0 self.bind('<KeyRelease>', self.handle_keyrelease) def autocomplete(self, delta=0): if delta: self.delete(self.position, tk.END) else: self.position = len(self.get()) _hits = [] for element in self._completion_list: if element.lower().startswith(self.get().lower()): _hits.append(element) if _hits != self._hits: self._hit_index = 0 self._hits = _hits if _hits: self.delete(0, tk.END) self.insert(0, _hits[self._hit_index]) self.select_range(self.position, tk.END) else: self._hit_index = 0 def handle_keyrelease(self, event): if event.keysym == "BackSpace": self.delete(self.index(tk.INSERT), tk.END) self.position = self.index(tk.END) if event.keysym == "Left": if self.position < self.index(tk.END): self.delete(self.position, tk.END) else: self.position = self.position-1 if event.keysym == "Right": self.position = self.index(tk.END) if len(event.keysym) == 1: self.autocomplete() self.position = self.index(tk.END) def set(self, text): self.delete(0, tk.END) self.insert(0, text) self.position = self.index(tk.END) def get_current_text(self): return self.get() def get(self): return self.tk.call(self._w, 'get') def event_generate(self, sequence, **kw): return self.tk.call(self._w, 'event', 'generate', sequence, **kw) ``` 这个实现代码中,我们创建了一个名为 `AutocompleteCombobox` 的自动补全下拉框控件,并实现了自动补全的功能。你可以将你的下拉框控件改为这个自动补全下拉框控件,然后使用以下代码来实现连续输入和保留下拉选项: ``` def on_material_name_keyrelease(event): # 获取用户输入的内容 user_input = self.material_name1.get() if not user_input: # 如果用户没有输入任何内容,则展示所有选项 self.material_name1.set_completion_list(data_list) else: # 根据用户输入的内容过滤下拉框的选项 filtered_options = [option for option in data_list if user_input in option] if filtered_options: # 如果有符合条件的选项,则更新下拉框的选项并展开下拉框 self.material_name1.set_completion_list(filtered_options) self.material_name1.event_generate('<Down>') else: # 如果没有符合条件的选项,则关闭下拉框 self.material_name1.event_generate('<Escape>') ``` 这样修改后,用户在输入第一个字符时,下拉选项会弹出并展开,同时焦点会被重新设置到下拉框上,用户可以直接继续输入,下拉选项会根据用户输入的内容实时更新。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值