JTextComponent.select()或者selectAll()方法没有选中效果

 

public void select(int selectionStart, int selectionEnd)

选定指定的开始和结束位置之间的文本。

此方法设置选定文本的开始位置和结束位置,并强行限制开始位置必须大于等于零。结束位置必须大于等于开始位置,并大于等于文本组件的文本长度。

如果调用者提供不一致或超出限度的值,则该方法静默地实施这些限制,并且不会失败。要特别指出的是,如果开始位置或结束位置大于文本长度,则将它重置为等于文本长度。如果开始位置小于零,则将它重置为零,如果结束位置小于开始位置,则将它重置为开始位置。

此调用是为向后兼容性提供的。将其作为调用 setCaretPosition 的途径,接着再调用 moveCaretPosition。管理选定的首选方法是直接调用这些方法。

参数:

selectionStart - 文本的起始位置

selectionEnd - 文本的结束位置

另请参见:

setCaretPosition(int), moveCaretPosition(int)

 

以上是swing中文本控件JTextComponent的select方法的api说明,JTextComponent是一个抽象类,在实际使用中,我们一般经常接触到的是其子类JTextField、JTextArea。

select方法很好理解,即将文本框中的指定位置的文字内容设置为选中状态,就显示状态来说,被选中的文字内容,其前景色和背景色将与未选中的文字内容区别显示,如下图所示。

 

我编写了一个文字搜索对话框,可以对控件中的文字进行搜索。

 

第一个例子

我在JTextArea中执行搜索操作时,一切功能正常。

 

第二个例子

当我在对一个JTextField执行搜索时,被搜索到的文字并没有产生选中效果,而当我关闭搜索对话框后,搜索到的文字显示出了选中效果。由此可以推测出,搜索功能实际上已经成功执行了,只是文字的选中效果没有表现出来。而选中效果之所以没有表现出来,显然与焦点有关。当搜索对话框没有关闭的时候,焦点被搜索对话框持有,所以JTextField中被选中的文字不能显示选中效果,当搜索对话框被关闭后,焦点回到了JTextField中,被选中的文字正常显示显示效果。

 

讲道理,在第一个例子中,JTextArea也是在没有持有焦点的情况之下,但为什么被选中文字却能够正常显示选中效果呢?晕~

 

如何解决第二个例子中遇到的问题?

方法一

既然是焦点的问题,那就用焦点来解决。在搜索完成之后,强制将焦点还给JTextField。

修改前:

textField.select(start, end);

修改后:

textField.requestFocus();

textField.select(start, end);

也可以修改为:

textField.requestFocusInWindow ();

textField.select(start, end);

 

但问题来了。

问题一:焦点能否成功获取。

首先,requestFocus和requestFocusInWindow这两个方法都是请求焦点,但能否请求成功是不受到保证的,事实上,某些情况下请求焦点是不会成功的。其次,这两个方法不但名称不一样,它们的实际执行效果也未必一致,某些情况下,其中一个方法能够成功获取焦点,而另一个却不行。总而言之,这俩货根本不受开发者控制,能否成功获得焦点完全是听天由命。

 

问题二:连续搜索问题。

在搜索这件事上,连续搜索是必须考虑的,用户可以按着回车键一路搜索下去,只到搜索结束或者用户看到自己期望的内容。

如果要实现连续搜索,那搜索框就应该一直持有焦点,而不应该将焦点还回被搜索的控件,因此,该解决方案与用户需求是存在冲突的。

 

方法二

使用高亮显示类Highlighter,这才是好东西,开发者可以一次性在一个文本控件中多个位置设置选中状态,甚至可以在不同的地方使用不同的选中样式。而select方法则只能在文本框中存在一个选中状态。

     public void selectText(int start, int end)

     {

         Highlighter highlighter = this.textField.getHighlighter();

         highlighter.removeAllHighlights();

         highlighter.addHighlight(start, end, HIGHLIGHT_PAINTER);

     }

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
删除之类操作需要全选功能,方便选择 public class MainActivity extends Activity { private ListView lv; private MyAdapter mAdapter; private ArrayList list; private Button bt_selectall; // private Button bt_cancel; // private Button bt_deselectall; private int checkNum; // 记录选中的条目数量 private TextView tv_show;// 用于显示选中的条目数量 /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); /* 实例化各个控件 */ lv = (ListView) findViewById(R.id.lv); bt_selectall = (Button) findViewById(R.id.bt_selectall); // bt_cancel = (Button) findViewById(R.id.bt_cancelselectall); // bt_deselectall = (Button) findViewById(R.id.bt_deselectall); tv_show = (TextView) findViewById(R.id.tv); list = new ArrayList(); // 为Adapter准备数据 initDate(); // 实例化自定义的MyAdapter mAdapter = new MyAdapter(list, this); // 绑定Adapter lv.setAdapter(mAdapter); // 全选按钮的回调接口 bt_selectall.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 遍历list的长度,将MyAdapter的map值全部设为true for (int i = 0; i < list.size(); i++) { MyAdapter.getIsSelected().put(i, true); } // 数量设为list的长度 checkNum = list.size(); // 刷新listview和TextView的显示 dataChanged(); } }); // 反选按钮的回调接口 // bt_cancel.setOnClickListener(new OnClickListener() { // @Override // public void onClick(View v) { // // 遍历list的长度,将已选的设为未选,未选的设为已选 // for (int i = 0; i < list.siz
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值