zoukankan      html  css  js  c++  java
  • 使用EditText的addTextChangedListener(new TextWatcher())方法

    http://www.cnblogs.com/jdsjlzx/archive/2011/07/19/2110930.html

    setOnClickListener() - 单击事件监听器
    setOnScrollToScreen() - 屏幕滚动切换效果
    addTextChangedListener() - 文本变化监听器
    setOnTouchListener() - 控件按下与松开监听器
     
     

    在使用EditText的addTextChangedListener(new TextWatcher())方法时(即给EditText增加监听器):

    注意:

      1、在使用里面的函数时,不能没有条件的改变本EditText的内容 , 因为这样容易引起死循环,所以必须要加限制条件

    ////////////////////////////////////////////////////
      //给EditText增加监听器
      contentEditText.addTextChangedListener(new TextWatcher() {
       
       int l=0;////////记录字符串被删除字符之前,字符串的长度
       int location=0;//记录光标的位置
       @Override
       public void onTextChanged(CharSequence s, int start, int before, int count) {
        // TODO Auto-generated method stub
        
       }
       
       @Override
       public void beforeTextChanged(CharSequence s, int start, int count,
         int after) {
        // TODO Auto-generated method stub
        l=s.length();
        location=contentEditText.getSelectionStart();
       }
       
       @Override
       public void afterTextChanged(Editable s) {
        // TODO Auto-generated method stub
        if (l>s.toString().length()) {
         gyf.function.face_analysis faceAnalysis=new gyf.function.face_analysis(releaseComment.this);
         SpannableStringBuilder sBuilder=faceAnalysis.getSpannableStringBuilder(s.toString());
         //eText.setText(sBuilder);
         //eText.setText("");
         contentEditText.setText(sBuilder);
         Editable etable=contentEditText.getText();
         Selection.setSelection(etable, location);
         //Toast.makeText(releaseComment.this, "11111", Toast.LENGTH_SHORT).show();
         
        }


        //Toast.makeText(releaseComment.this, "0000", Toast.LENGTH_SHORT).show();
       }
      });

    2、每次刷新EditText时,光标也会跟着重置,即位置跑到了开头

       如上代码所示。

       有关光标的介绍有:

    提起Android的 EditText的光标选择问题,可以通过android.text.Selection包提供的方法来实现,Android SDK提供了有关光标选择的多种方法,比如说getSelectionEnd、getSelectionStart、removeSelection、 selectAll、setSelection,详细的参数声明如下

    final static int  getSelectionEnd(CharSequence text)
    Return the offset of the selection edge or cursor, or -1 if there is no selection or cursor.
    
    final static int  getSelectionStart(CharSequence text)
    Return the offset of the selection anchor or cursor, or -1 if there is no selection or cursor.
    
    final static void  removeSelection(Spannable text)
    Remove the selection or cursor, if any, from the text.
    
    final static void  selectAll(Spannable text)
    Select the entire text.
    
    final static void  setSelection(Spannable text, int index)
    Move the cursor to offset index.
    
    static void  setSelection(Spannable text, int start, int stop)
    Set the selection anchor to start and the selection edge to stop.



    Android123提示大家,从上面的参数来看,可以发现Spannable类型,常规我们的EditText中的编辑中Editable直接实现Spannable接口,所以我们可以通过下面的方法来设置选择:

    1.   Editable ea= etEdit.getText();  //etEdit为EditText
    2.   Selection.setSelection(ea, ea.length()-1); // Android开发网提示这里ea的长度必须大于1。否则会有异常发生
     
     
     

     

    Android onTouchEvent和setOnTouchListener中onTouch的区别

    OnTouchEvent()方法

    是获取的对屏幕的各种操作,比如向左向右滑动,点击返回按钮等等。

    属于一个宏观的屏幕触摸监控。

    OnTouchListener()方法
    是获取某一个控件某一个View的点击监控。
    官方文档:http://developer.android.com/ref ... nTouchListener.html

    两者很容易区分。

    区别如下:

    1、如果setOnTouchListener中的onTouch方法返回值是true(事件被消费)时,则onTouchEvent方法将不会被执行;

    2、只有当setOnTouchListener中的onTouch方法返回值是false(事件未被消费,向下传递)时,onTouchEvent方法才被执行。

    3、以上说的情况适用于View对象(事件会最先被最内层的View对象先响应)而不是ViewGroup对象(事件会最先被最外层的View对象先响应)。

    综合来讲:

    onTouchListener的onTouch方法优先级比onTouchEvent高,会先触发。

    假如onTouch方法返回false,会接着触发onTouchEvent,反之onTouchEvent方法不会被调用。

    内置诸如click事件的实现等等都基于onTouchEvent,假如onTouch返回true,这些事件将不会被触发
     
     
  • 相关阅读:
    java代理的深入浅出(一)-Proxy
    事件分发模型的设计与实现
    LibProject使用theme无效。
    HeaderGridView
    android开源代码
    IOS学习4
    IOS学习3
    IOS学习2
    Mac上添加adb_usb.ini
    OC学习-1
  • 原文地址:https://www.cnblogs.com/misybing/p/4915918.html
Copyright © 2011-2022 走看看